@etherisc/gif-next 0.0.2-96b5b72-170 → 0.0.2-97aac30-275
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 +2 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +193 -164
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +114 -321
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +120 -82
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +72 -108
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +22 -48
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +2 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +25 -6
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +56 -22
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +53 -18
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +708 -0
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationsLib.sol/InstanceAuthorizationsLib.json +132 -28
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +458 -331
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +133 -59
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +110 -32
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1103 -308
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +318 -0
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +10 -0
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.json +2 -2
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +8 -116
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- 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/mock/Dip.sol/Dip.dbg.json +4 -0
- package/artifacts/contracts/mock/Dip.sol/Dip.json +376 -0
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +4 -0
- package/artifacts/contracts/{instance/module/ISetup.sol/ISetup.json → oracle/IOracle.sol/IOracle.json} +2 -2
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +759 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +662 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +4 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +1146 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +997 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +718 -0
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +69 -252
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +105 -55
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +8 -53
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +134 -86
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +121 -133
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +239 -92
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +170 -368
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +98 -72
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +69 -153
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +105 -31
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +95 -203
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +118 -56
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +7 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +7 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +81 -25
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +27 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +230 -107
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +0 -55
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +164 -299
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +106 -92
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +139 -160
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +130 -40
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +334 -146
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +29 -214
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +88 -34
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +163 -61
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +256 -65
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +378 -67
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +407 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +272 -68
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +87 -35
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +799 -127
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.dbg.json +4 -0
- package/artifacts/contracts/registry/ServiceAuthorizationsLib.sol/ServiceAuthorizationsLib.json +137 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +314 -138
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerCustom.sol/AccessManagerCustom.json +1193 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtended.sol/AccessManagerExtended.json +1715 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedInitializeable.sol/AccessManagerExtendedInitializeable.json +1728 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisable.sol/AccessManagerExtendedWithDisable.json +1806 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol/AccessManagerExtendedWithDisableInitializeable.json +1824 -0
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +184 -11
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +908 -49
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +792 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +4 -0
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +526 -0
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +2 -2
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtended.sol/IAccessManagerExtended.json +1562 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.dbg.json +4 -0
- package/artifacts/contracts/shared/IAccessManagerExtendedWithDisable.sol/IAccessManagerExtendedWithDisable.json +1600 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +172 -4
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +4 -0
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +867 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +80 -22
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/IKeyValueStore.sol/IKeyValueStore.json +1 -11
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +4 -0
- package/artifacts/contracts/{instance/base → shared}/ILifecycle.sol/ILifecycle.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +7 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +21 -3
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +7 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +7 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +39 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +176 -24
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +4 -0
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +571 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +4 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +194 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +4 -0
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.json +306 -0
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +13 -7
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +31 -13
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +64 -16
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +21 -7
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +7 -1
- 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/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1103 -172
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +497 -49
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +444 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1247 -56
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +167 -30
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +592 -0
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +605 -78
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +122 -28
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +2189 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +571 -0
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.json +2 -2
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +68 -4
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +53 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +34 -34
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +47 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +15 -2
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +204 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +76 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +17 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +2 -2
- package/contracts/distribution/Distribution.sol +27 -51
- package/contracts/distribution/DistributionService.sol +55 -106
- package/contracts/distribution/DistributionServiceManager.sol +9 -18
- package/contracts/distribution/IDistributionComponent.sol +3 -8
- package/contracts/distribution/IDistributionService.sol +2 -8
- package/contracts/instance/IInstance.sol +12 -7
- package/contracts/instance/IInstanceService.sol +13 -5
- package/contracts/instance/Instance.sol +30 -23
- package/contracts/instance/InstanceAdmin.sol +331 -0
- package/contracts/instance/InstanceAuthorizationsLib.sol +210 -141
- package/contracts/instance/InstanceReader.sol +64 -42
- package/contracts/instance/InstanceService.sol +141 -87
- package/contracts/instance/InstanceServiceManager.sol +10 -20
- package/contracts/instance/InstanceStore.sol +125 -55
- package/contracts/instance/base/BalanceStore.sol +118 -0
- package/contracts/instance/base/ObjectCounter.sol +21 -0
- package/contracts/instance/module/IAccess.sol +2 -10
- package/contracts/instance/module/IBundle.sol +1 -4
- package/contracts/instance/module/IComponents.sol +15 -4
- package/contracts/instance/module/IPolicy.sol +8 -2
- package/contracts/mock/Dip.sol +26 -0
- package/contracts/oracle/IOracle.sol +20 -0
- package/contracts/oracle/IOracleComponent.sol +32 -0
- package/contracts/oracle/IOracleService.sol +65 -0
- package/contracts/oracle/Oracle.sol +145 -0
- package/contracts/oracle/OracleService.sol +277 -0
- package/contracts/oracle/OracleServiceManager.sol +42 -0
- package/contracts/pool/BundleService.sol +63 -149
- package/contracts/pool/BundleServiceManager.sol +9 -18
- package/contracts/pool/IBundleService.sol +4 -16
- package/contracts/pool/IPoolComponent.sol +2 -4
- package/contracts/pool/IPoolService.sol +45 -9
- package/contracts/pool/Pool.sol +37 -40
- package/contracts/pool/PoolService.sol +195 -145
- package/contracts/pool/PoolServiceManager.sol +9 -18
- package/contracts/product/ApplicationService.sol +111 -43
- package/contracts/product/ApplicationServiceManager.sol +9 -6
- package/contracts/product/ClaimService.sol +21 -21
- package/contracts/product/ClaimServiceManager.sol +9 -6
- package/contracts/product/IApplicationService.sol +1 -1
- package/contracts/product/IClaimService.sol +7 -1
- package/contracts/product/IPolicyService.sol +6 -8
- package/contracts/product/IPricingService.sol +3 -1
- package/contracts/product/IProductComponent.sol +5 -4
- package/contracts/product/IProductService.sol +1 -8
- package/contracts/product/PolicyService.sol +226 -127
- package/contracts/product/PolicyServiceManager.sol +9 -21
- package/contracts/product/PricingService.sol +74 -48
- package/contracts/product/PricingServiceManager.sol +9 -18
- package/contracts/product/Product.sol +45 -47
- package/contracts/product/ProductService.sol +26 -112
- package/contracts/product/ProductServiceManager.sol +9 -21
- package/contracts/registry/ChainNft.sol +1 -0
- package/contracts/registry/IRegistry.sol +38 -24
- package/contracts/registry/IRegistryService.sol +31 -31
- package/contracts/registry/Registry.sol +176 -105
- package/contracts/registry/RegistryAdmin.sol +237 -0
- package/contracts/registry/RegistryService.sol +44 -82
- package/contracts/registry/RegistryServiceManager.sol +21 -23
- package/contracts/registry/ReleaseManager.sol +450 -210
- package/contracts/registry/ServiceAuthorizationsLib.sol +173 -0
- package/contracts/registry/TokenRegistry.sol +261 -62
- package/contracts/shared/AccessManagerCustom.sol +736 -0
- package/contracts/shared/AccessManagerExtended.sol +470 -0
- package/contracts/shared/AccessManagerExtendedInitializeable.sol +13 -0
- package/contracts/shared/AccessManagerExtendedWithDisable.sol +137 -0
- package/contracts/shared/AccessManagerExtendedWithDisableInitializeable.sol +14 -0
- package/contracts/shared/Component.sol +153 -49
- package/contracts/shared/ComponentService.sol +561 -93
- package/contracts/shared/ComponentServiceManager.sol +35 -0
- package/contracts/shared/ComponentVerifyingService.sol +117 -0
- package/contracts/shared/ERC165.sol +1 -1
- package/contracts/shared/IAccessManagerExtended.sol +74 -0
- package/contracts/shared/IAccessManagerExtendedWithDisable.sol +18 -0
- package/contracts/shared/IComponent.sol +20 -8
- package/contracts/shared/IComponentService.sol +102 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +5 -11
- package/contracts/{instance/base → shared}/IKeyValueStore.sol +6 -6
- package/contracts/{instance/base → shared}/ILifecycle.sol +3 -3
- package/contracts/shared/INftOwnable.sol +1 -1
- package/contracts/shared/IPolicyHolder.sol +6 -1
- package/contracts/shared/IService.sol +1 -1
- package/contracts/shared/InitializableCustom.sol +177 -0
- package/contracts/shared/InstanceLinkedComponent.sol +51 -178
- package/contracts/{instance/base → shared}/KeyValueStore.sol +30 -72
- package/contracts/{instance/base → shared}/Lifecycle.sol +12 -3
- package/contracts/shared/NftIdSetManager.sol +65 -0
- package/contracts/shared/NftOwnable.sol +2 -13
- package/contracts/shared/PolicyHolder.sol +21 -13
- package/contracts/shared/ProxyManager.sol +31 -1
- package/contracts/shared/Registerable.sol +2 -2
- package/contracts/shared/Service.sol +7 -2
- package/contracts/staking/IStaking.sol +146 -8
- package/contracts/staking/IStakingService.sol +83 -39
- package/contracts/staking/StakeManagerLib.sol +179 -0
- package/contracts/staking/Staking.sol +503 -17
- package/contracts/staking/StakingManager.sol +22 -14
- package/contracts/staking/StakingReader.sol +187 -0
- package/contracts/staking/StakingService.sol +246 -44
- package/contracts/staking/StakingServiceManager.sol +8 -4
- package/contracts/staking/StakingStore.sol +572 -0
- package/contracts/staking/TargetManagerLib.sol +207 -0
- package/contracts/type/AddressSet.sol +1 -1
- package/contracts/type/Amount.sol +20 -1
- package/contracts/type/Blocknumber.sol +20 -3
- package/contracts/type/Fee.sol +17 -16
- package/contracts/type/NftId.sol +14 -16
- package/contracts/type/NftIdSet.sol +1 -1
- package/contracts/type/ObjectType.sol +12 -10
- package/contracts/type/Referral.sol +1 -1
- package/contracts/type/RequestId.sol +75 -0
- package/contracts/type/RiskId.sol +1 -1
- package/contracts/type/RoleId.sol +18 -4
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/StateId.sol +27 -2
- package/contracts/type/Timestamp.sol +6 -2
- package/contracts/type/Version.sol +1 -1
- package/package.json +4 -3
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +0 -4
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +0 -1348
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +0 -581
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +0 -4
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +0 -194
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +0 -4
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.json +0 -10
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +0 -4
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +0 -285
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +0 -4
- package/artifacts/contracts/shared/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +0 -1206
- package/contracts/instance/InstanceAccessManager.sol +0 -543
- package/contracts/instance/module/ISetup.sol +0 -33
- package/contracts/instance/module/ITreasury.sol +0 -23
- package/contracts/registry/RegistryAccessManager.sol +0 -207
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +0 -13
@@ -1,6 +1,7 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
+
import {Amount, AmountLib} from "../type/Amount.sol";
|
4
5
|
import {Seconds} from "../type/Seconds.sol";
|
5
6
|
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
6
7
|
import {ObjectType} from "../type/ObjectType.sol";
|
@@ -9,7 +10,6 @@ import {Fee} from "../type/Fee.sol";
|
|
9
10
|
import {ReferralId} from "../type/Referral.sol";
|
10
11
|
import {RiskId} from "../type/RiskId.sol";
|
11
12
|
import {PRODUCT, DISTRIBUTION, PRICE} from "../type/ObjectType.sol";
|
12
|
-
import {Amount} from "../type/Amount.sol";
|
13
13
|
import {IRegistry} from "../registry/IRegistry.sol";
|
14
14
|
|
15
15
|
import {IProductComponent} from "./IProductComponent.sol";
|
@@ -19,17 +19,16 @@ import {InstanceReader} from "../instance/InstanceReader.sol";
|
|
19
19
|
import {IComponents} from "../instance/module/IComponents.sol";
|
20
20
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
21
21
|
import {IBundle} from "../instance/module/IBundle.sol";
|
22
|
-
import {ISetup} from "../instance/module/ISetup.sol";
|
23
22
|
import {IDistribution} from "../instance/module/IDistribution.sol";
|
24
23
|
|
25
|
-
import {
|
24
|
+
import {ComponentVerifyingService} from "../shared/ComponentVerifyingService.sol";
|
26
25
|
|
27
26
|
import {IPricingService} from "./IPricingService.sol";
|
28
27
|
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
29
28
|
|
30
29
|
|
31
30
|
contract PricingService is
|
32
|
-
|
31
|
+
ComponentVerifyingService,
|
33
32
|
IPricingService
|
34
33
|
{
|
35
34
|
using UFixedLib for UFixed;
|
@@ -45,12 +44,13 @@ contract PricingService is
|
|
45
44
|
virtual override
|
46
45
|
initializer()
|
47
46
|
{
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
47
|
+
(
|
48
|
+
address registryAddress,,
|
49
|
+
//address managerAddress
|
50
|
+
address authority
|
51
|
+
) = abi.decode(data, (address, address, address));
|
52
52
|
|
53
|
-
initializeService(registryAddress,
|
53
|
+
initializeService(registryAddress, authority, owner);
|
54
54
|
registerInterface(type(IPricingService).interfaceId);
|
55
55
|
|
56
56
|
_distributionService = IDistributionService(_getServiceAddress(DISTRIBUTION()));
|
@@ -85,14 +85,14 @@ contract PricingService is
|
|
85
85
|
{
|
86
86
|
// verify product
|
87
87
|
(
|
88
|
-
IRegistry.ObjectInfo memory
|
88
|
+
IRegistry.ObjectInfo memory registryInfo,
|
89
89
|
IInstance instance
|
90
|
-
) =
|
90
|
+
) = _getAndVerifyComponentInfo(productNftId, PRODUCT(), false);
|
91
91
|
|
92
92
|
reader = instance.getInstanceReader();
|
93
93
|
|
94
94
|
// calculate net premium
|
95
|
-
netPremiumAmount = IProductComponent(
|
95
|
+
netPremiumAmount = IProductComponent(registryInfo.objectAddress).calculateNetPremium(
|
96
96
|
sumInsuredAmount,
|
97
97
|
riskId,
|
98
98
|
lifetime,
|
@@ -102,46 +102,45 @@ contract PricingService is
|
|
102
102
|
|
103
103
|
{
|
104
104
|
// get configurations for all involed objects
|
105
|
-
|
106
|
-
|
107
|
-
bytes memory componentData = reader.getComponentInfo(productSetup.poolNftId).data;
|
108
|
-
IComponents.PoolInfo memory poolInfo = abi.decode(componentData, (IComponents.PoolInfo));
|
105
|
+
IComponents.ProductInfo memory productInfo = reader.getProductInfo(productNftId);
|
109
106
|
|
110
107
|
IBundle.BundleInfo memory bundleInfo = reader.getBundleInfo(bundleNftId);
|
111
|
-
if(bundleInfo.poolNftId !=
|
112
|
-
revert ErrorIPricingServiceBundlePoolMismatch(bundleNftId, bundleInfo.poolNftId,
|
108
|
+
if(bundleInfo.poolNftId != productInfo.poolNftId) {
|
109
|
+
revert ErrorIPricingServiceBundlePoolMismatch(bundleNftId, bundleInfo.poolNftId, productInfo.poolNftId);
|
113
110
|
}
|
114
111
|
|
115
|
-
NftId distributionNftId = productSetup.distributionNftId;
|
116
|
-
ISetup.DistributionSetupInfo memory distSetup = reader.getDistributionSetupInfo(distributionNftId);
|
117
|
-
|
118
112
|
// calculate premium, order is important
|
119
113
|
premium = _getFixedFeeAmounts(
|
120
114
|
netPremiumAmount,
|
121
|
-
|
122
|
-
poolInfo,
|
123
|
-
distSetup,
|
115
|
+
productInfo,
|
124
116
|
bundleInfo
|
125
117
|
);
|
126
118
|
|
127
119
|
premium = _calculateVariableFeeAmounts(
|
128
120
|
premium,
|
129
|
-
|
130
|
-
poolInfo,
|
131
|
-
distSetup,
|
121
|
+
productInfo,
|
132
122
|
bundleInfo
|
133
123
|
);
|
134
124
|
|
135
125
|
premium = _calculateDistributionOwnerFeeAmount(
|
136
126
|
premium,
|
137
|
-
|
127
|
+
productInfo,
|
138
128
|
referralId,
|
139
|
-
distributionNftId,
|
140
129
|
reader
|
141
130
|
);
|
142
131
|
|
132
|
+
premium = _calculateTargetWalletAmounts(premium);
|
133
|
+
|
143
134
|
// sanity check to validate the fee calculation
|
144
|
-
if
|
135
|
+
if(AmountLib.toAmount(premium.premiumAmount) !=
|
136
|
+
premium.productFeeAmount
|
137
|
+
+ premium.distributionFeeAndCommissionAmount
|
138
|
+
+ premium.poolPremiumAndFeeAmount)
|
139
|
+
{
|
140
|
+
revert ErrorPricingServiceTargetWalletAmountsMismatch();
|
141
|
+
}
|
142
|
+
|
143
|
+
if (premium.distributionOwnerFeeFixAmount < productInfo.minDistributionOwnerFee.fixedFee) {
|
145
144
|
revert ErrorIPricingServiceFeeCalculationMismatch(
|
146
145
|
premium.distributionFeeFixAmount,
|
147
146
|
premium.distributionFeeVarAmount,
|
@@ -168,13 +167,11 @@ contract PricingService is
|
|
168
167
|
// internal functions
|
169
168
|
function _getFixedFeeAmounts(
|
170
169
|
Amount netPremiumAmount,
|
171
|
-
|
172
|
-
IComponents.PoolInfo memory poolInfo,
|
173
|
-
ISetup.DistributionSetupInfo memory distInfo,
|
170
|
+
IComponents.ProductInfo memory productInfo,
|
174
171
|
IBundle.BundleInfo memory bundleInfo
|
175
172
|
)
|
176
173
|
internal
|
177
|
-
|
174
|
+
pure
|
178
175
|
returns (
|
179
176
|
IPolicy.Premium memory premium
|
180
177
|
)
|
@@ -187,7 +184,7 @@ contract PricingService is
|
|
187
184
|
premium.productFeeFixAmount = t;
|
188
185
|
premium.fullPremiumAmount += t;
|
189
186
|
|
190
|
-
t =
|
187
|
+
t = productInfo.poolFee.fixedFee;
|
191
188
|
premium.poolFeeFixAmount = t;
|
192
189
|
premium.fullPremiumAmount += t;
|
193
190
|
|
@@ -195,20 +192,18 @@ contract PricingService is
|
|
195
192
|
premium.bundleFeeFixAmount = t;
|
196
193
|
premium.fullPremiumAmount += t;
|
197
194
|
|
198
|
-
t =
|
195
|
+
t = productInfo.distributionFee.fixedFee;
|
199
196
|
premium.distributionFeeFixAmount = t;
|
200
197
|
premium.fullPremiumAmount += t;
|
201
198
|
}
|
202
199
|
|
203
200
|
function _calculateVariableFeeAmounts(
|
204
201
|
IPolicy.Premium memory premium,
|
205
|
-
|
206
|
-
IComponents.PoolInfo memory poolInfo,
|
207
|
-
ISetup.DistributionSetupInfo memory distInfo,
|
202
|
+
IComponents.ProductInfo memory productInfo,
|
208
203
|
IBundle.BundleInfo memory bundleInfo
|
209
204
|
)
|
210
205
|
internal
|
211
|
-
|
206
|
+
pure
|
212
207
|
returns (
|
213
208
|
IPolicy.Premium memory intermadiatePremium
|
214
209
|
)
|
@@ -219,7 +214,7 @@ contract PricingService is
|
|
219
214
|
premium.productFeeVarAmount = t;
|
220
215
|
premium.fullPremiumAmount += t;
|
221
216
|
|
222
|
-
t = (netPremiumAmount *
|
217
|
+
t = (netPremiumAmount * productInfo.poolFee.fractionalFee).toInt();
|
223
218
|
premium.poolFeeVarAmount = t;
|
224
219
|
premium.fullPremiumAmount += t;
|
225
220
|
|
@@ -227,7 +222,7 @@ contract PricingService is
|
|
227
222
|
premium.bundleFeeVarAmount = t;
|
228
223
|
premium.fullPremiumAmount += t;
|
229
224
|
|
230
|
-
t = (netPremiumAmount *
|
225
|
+
t = (netPremiumAmount * productInfo.distributionFee.fractionalFee).toInt();
|
231
226
|
premium.distributionFeeVarAmount = t;
|
232
227
|
premium.fullPremiumAmount += t;
|
233
228
|
|
@@ -236,24 +231,25 @@ contract PricingService is
|
|
236
231
|
|
237
232
|
function _calculateDistributionOwnerFeeAmount(
|
238
233
|
IPolicy.Premium memory premium,
|
239
|
-
|
234
|
+
IComponents.ProductInfo memory productInfo,
|
235
|
+
// ISetup.DistributionSetupInfo memory distInfo,
|
240
236
|
ReferralId referralId,
|
241
|
-
NftId distributionNftId,
|
242
237
|
InstanceReader reader
|
243
238
|
)
|
244
239
|
internal
|
245
240
|
view
|
246
241
|
returns (IPolicy.Premium memory finalPremium)
|
247
242
|
{
|
243
|
+
|
248
244
|
// if the referral is not valid, then the distribution owner gets everything
|
249
|
-
if (! _distributionService.referralIsValid(distributionNftId, referralId)) {
|
245
|
+
if (! _distributionService.referralIsValid(productInfo.distributionNftId, referralId)) {
|
250
246
|
premium.distributionOwnerFeeFixAmount = premium.distributionFeeFixAmount;
|
251
247
|
premium.distributionOwnerFeeVarAmount = premium.distributionFeeVarAmount;
|
252
248
|
premium.premiumAmount = premium.fullPremiumAmount;
|
253
249
|
return premium;
|
254
250
|
}
|
255
251
|
|
256
|
-
Fee memory minDistributionOwnerFee =
|
252
|
+
Fee memory minDistributionOwnerFee = productInfo.minDistributionOwnerFee;
|
257
253
|
|
258
254
|
// if the referral is valid, the the commission and discount are calculated based in the full premium
|
259
255
|
// the remaing amount goes to the distribution owner
|
@@ -265,11 +261,41 @@ contract PricingService is
|
|
265
261
|
uint256 commissionAmount = UFixedLib.toUFixed(premium.netPremiumAmount).mul(distributorTypeInfo.commissionPercentage).toInt();
|
266
262
|
premium.commissionAmount = commissionAmount;
|
267
263
|
premium.discountAmount = UFixedLib.toUFixed(premium.fullPremiumAmount).mul(referralInfo.discountPercentage).toInt();
|
268
|
-
premium.distributionOwnerFeeFixAmount =
|
264
|
+
premium.distributionOwnerFeeFixAmount = minDistributionOwnerFee.fixedFee;
|
269
265
|
premium.distributionOwnerFeeVarAmount = premium.distributionFeeVarAmount - commissionAmount - premium.discountAmount;
|
270
266
|
premium.premiumAmount = premium.fullPremiumAmount - premium.discountAmount;
|
271
267
|
}
|
272
268
|
|
273
269
|
return premium;
|
274
270
|
}
|
271
|
+
|
272
|
+
|
273
|
+
function _calculateTargetWalletAmounts(
|
274
|
+
IPolicy.Premium memory premium
|
275
|
+
)
|
276
|
+
internal
|
277
|
+
virtual
|
278
|
+
view
|
279
|
+
returns (
|
280
|
+
IPolicy.Premium memory premiumWithTargetWalletAmounts
|
281
|
+
)
|
282
|
+
{
|
283
|
+
// fees for product owner
|
284
|
+
premium.productFeeAmount = AmountLib.toAmount(
|
285
|
+
premium.productFeeFixAmount + premium.productFeeVarAmount);
|
286
|
+
|
287
|
+
// fees for distribution owner + distributor commission
|
288
|
+
premium.distributionFeeAndCommissionAmount = AmountLib.toAmount(
|
289
|
+
premium.distributionFeeFixAmount + premium.distributionOwnerFeeVarAmount
|
290
|
+
+ premium.commissionAmount);
|
291
|
+
|
292
|
+
// net premium + fees for pool owner + bundle owner
|
293
|
+
premium.poolPremiumAndFeeAmount = AmountLib.toAmount(
|
294
|
+
premium.netPremiumAmount
|
295
|
+
+ premium.poolFeeFixAmount + premium.poolFeeVarAmount
|
296
|
+
+ premium.bundleFeeFixAmount + premium.bundleFeeVarAmount);
|
297
|
+
|
298
|
+
premiumWithTargetWalletAmounts = premium;
|
299
|
+
}
|
300
|
+
|
275
301
|
}
|
@@ -12,31 +12,22 @@ contract PricingServiceManager is ProxyManager {
|
|
12
12
|
|
13
13
|
PricingService private _pricingService;
|
14
14
|
|
15
|
-
/// @dev initializes proxy manager with
|
15
|
+
/// @dev initializes proxy manager with pricing service implementation and deploys instance
|
16
16
|
constructor(
|
17
|
-
address
|
17
|
+
address authority,
|
18
|
+
address registryAddress,
|
19
|
+
bytes32 salt
|
18
20
|
)
|
19
21
|
ProxyManager(registryAddress)
|
20
22
|
{
|
21
|
-
PricingService pricingSrv = new PricingService();
|
22
|
-
bytes memory data = abi.encode(registryAddress, address(this));
|
23
|
-
IVersionable versionable =
|
23
|
+
PricingService pricingSrv = new PricingService{salt: salt}();
|
24
|
+
bytes memory data = abi.encode(registryAddress, address(this), authority);
|
25
|
+
IVersionable versionable = deployDetermenistic(
|
24
26
|
address(pricingSrv),
|
25
|
-
data
|
27
|
+
data,
|
28
|
+
salt);
|
26
29
|
|
27
30
|
_pricingService = PricingService(address(versionable));
|
28
|
-
|
29
|
-
// TODO `thi` must have a role or own nft to register service
|
30
|
-
//Registry registry = Registry(registryAddress);
|
31
|
-
//address registryServiceAddress = registry.getServiceAddress(REGISTRY(), _distributionService.getMajorVersion());
|
32
|
-
//RegistryService registryService = RegistryService(registryServiceAddress);
|
33
|
-
//registryService.registerService(_distributionService);
|
34
|
-
|
35
|
-
// TODO no nft to link yet
|
36
|
-
// link ownership of instance service manager ot nft owner of instance service
|
37
|
-
//_linkToNftOwnable(
|
38
|
-
// address(registryAddress),
|
39
|
-
// address(_distributionService));
|
40
31
|
}
|
41
32
|
|
42
33
|
//--- view functions ----------------------------------------------------//
|
@@ -1,14 +1,15 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
|
-
pragma solidity ^0.8.
|
2
|
+
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
6
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
7
7
|
import {ClaimId} from "../type/ClaimId.sol";
|
8
8
|
import {InstanceLinkedComponent} from "../shared/InstanceLinkedComponent.sol";
|
9
|
-
import {Fee} from "../type/Fee.sol";
|
9
|
+
import {Fee, FeeLib} from "../type/Fee.sol";
|
10
10
|
import {IRisk} from "../instance/module/IRisk.sol";
|
11
11
|
import {IApplicationService} from "./IApplicationService.sol";
|
12
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
12
13
|
import {IPolicyService} from "./IPolicyService.sol";
|
13
14
|
import {IProductService} from "./IProductService.sol";
|
14
15
|
import {IClaimService} from "./IClaimService.sol";
|
@@ -16,7 +17,7 @@ import {IPricingService} from "./IPricingService.sol";
|
|
16
17
|
import {IProductComponent} from "./IProductComponent.sol";
|
17
18
|
import {NftId, NftIdLib} from "../type/NftId.sol";
|
18
19
|
import {PayoutId} from "../type/PayoutId.sol";
|
19
|
-
import {PRODUCT, APPLICATION, POLICY, CLAIM, PRICE } from "../type/ObjectType.sol";
|
20
|
+
import {COMPONENT, PRODUCT, APPLICATION, POLICY, CLAIM, PRICE } from "../type/ObjectType.sol";
|
20
21
|
import {ReferralId} from "../type/Referral.sol";
|
21
22
|
import {RiskId, RiskIdLib} from "../type/RiskId.sol";
|
22
23
|
import {Seconds} from "../type/Seconds.sol";
|
@@ -27,7 +28,6 @@ import {TokenHandler} from "../shared/TokenHandler.sol";
|
|
27
28
|
|
28
29
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
29
30
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
30
|
-
import {ISetup} from "../instance/module/ISetup.sol";
|
31
31
|
import {IComponents} from "../instance/module/IComponents.sol";
|
32
32
|
import {Pool} from "../pool/Pool.sol";
|
33
33
|
import {Distribution} from "../distribution/Distribution.sol";
|
@@ -45,33 +45,30 @@ abstract contract Product is
|
|
45
45
|
IPolicyService _policyService;
|
46
46
|
IClaimService _claimService;
|
47
47
|
IPricingService _pricingService;
|
48
|
-
|
49
|
-
Distribution _distribution;
|
50
|
-
Fee _initialProductFee;
|
51
|
-
Fee _initialProcessingFee;
|
52
|
-
TokenHandler _tokenHandler;
|
48
|
+
IComponentService _componentService;
|
53
49
|
NftId _poolNftId;
|
54
50
|
NftId _distributionNftId;
|
51
|
+
Pool _pool;
|
52
|
+
Distribution _distribution;
|
55
53
|
}
|
56
54
|
|
57
55
|
function initializeProduct(
|
58
56
|
address registry,
|
59
57
|
NftId instanceNftId,
|
58
|
+
address initialOwner,
|
60
59
|
string memory name,
|
61
60
|
address token,
|
62
61
|
bool isInterceptor,
|
63
62
|
address pool,
|
64
63
|
address distribution,
|
65
|
-
|
66
|
-
|
67
|
-
address initialOwner,
|
68
|
-
bytes memory registryData // writeonly data that will saved in the object info record of the registry
|
64
|
+
bytes memory registryData, // writeonly data that will saved in the object info record of the registry
|
65
|
+
bytes memory componentData // writeonly data that will saved in the object info record of the registry
|
69
66
|
)
|
70
67
|
public
|
71
68
|
virtual
|
72
69
|
onlyInitializing()
|
73
70
|
{
|
74
|
-
|
71
|
+
initializeInstanceLinkedComponent(registry, instanceNftId, name, token, PRODUCT(), isInterceptor, initialOwner, registryData, componentData);
|
75
72
|
|
76
73
|
ProductStorage storage $ = _getProductStorage();
|
77
74
|
// TODO add validation
|
@@ -81,18 +78,25 @@ abstract contract Product is
|
|
81
78
|
$._policyService = IPolicyService(_getServiceAddress(POLICY()));
|
82
79
|
$._claimService = IClaimService(_getServiceAddress(CLAIM()));
|
83
80
|
$._pricingService = IPricingService(_getServiceAddress(PRICE()));
|
81
|
+
$._componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
84
82
|
$._pool = Pool(pool);
|
85
83
|
$._distribution = Distribution(distribution);
|
86
|
-
$._initialProductFee = productFee;
|
87
|
-
$._initialProcessingFee = processingFee;
|
88
|
-
$._tokenHandler = new TokenHandler(token);
|
89
84
|
$._poolNftId = getRegistry().getNftId(pool);
|
90
85
|
$._distributionNftId = getRegistry().getNftId(distribution);
|
91
86
|
|
92
87
|
registerInterface(type(IProductComponent).interfaceId);
|
93
88
|
}
|
94
89
|
|
95
|
-
|
90
|
+
|
91
|
+
function register()
|
92
|
+
external
|
93
|
+
virtual
|
94
|
+
onlyOwner()
|
95
|
+
{
|
96
|
+
_getProductStorage()._componentService.registerProduct();
|
97
|
+
}
|
98
|
+
|
99
|
+
|
96
100
|
function setFees(
|
97
101
|
Fee memory productFee,
|
98
102
|
Fee memory processingFee
|
@@ -102,7 +106,7 @@ abstract contract Product is
|
|
102
106
|
restricted()
|
103
107
|
override
|
104
108
|
{
|
105
|
-
|
109
|
+
_getProductStorage()._componentService.setProductFees(productFee, processingFee);
|
106
110
|
}
|
107
111
|
|
108
112
|
function _createRisk(
|
@@ -327,8 +331,26 @@ abstract contract Product is
|
|
327
331
|
return AmountLib.toAmount(sumInsuredAmount.toInt() / 10);
|
328
332
|
}
|
329
333
|
|
330
|
-
|
331
|
-
|
334
|
+
|
335
|
+
function getInitialProductInfo()
|
336
|
+
public
|
337
|
+
virtual
|
338
|
+
view
|
339
|
+
returns (IComponents.ProductInfo memory poolInfo)
|
340
|
+
{
|
341
|
+
ProductStorage storage $ = _getProductStorage();
|
342
|
+
|
343
|
+
return IComponents.ProductInfo({
|
344
|
+
distributionNftId: $._distributionNftId,
|
345
|
+
poolNftId: $._poolNftId,
|
346
|
+
productFee: FeeLib.zero(),
|
347
|
+
processingFee: FeeLib.zero(),
|
348
|
+
distributionFee: FeeLib.zero(),
|
349
|
+
minDistributionOwnerFee: FeeLib.zero(),
|
350
|
+
poolFee: FeeLib.zero(),
|
351
|
+
stakingFee: FeeLib.zero(),
|
352
|
+
performanceFee: FeeLib.zero()
|
353
|
+
});
|
332
354
|
}
|
333
355
|
|
334
356
|
function getPoolNftId() external view override returns (NftId poolNftId) {
|
@@ -339,32 +361,8 @@ abstract contract Product is
|
|
339
361
|
return getRegistry().getNftId(address(_getProductStorage()._distribution));
|
340
362
|
}
|
341
363
|
|
342
|
-
function
|
343
|
-
|
344
|
-
setupInfo = reader.getProductSetupInfo(getNftId());
|
345
|
-
|
346
|
-
// fallback to initial setup info (wallet is always != address(0))
|
347
|
-
if(setupInfo.wallet == address(0)) {
|
348
|
-
setupInfo = _getInitialSetupInfo();
|
349
|
-
}
|
350
|
-
}
|
351
|
-
|
352
|
-
function _getInitialSetupInfo() internal view returns (ISetup.ProductSetupInfo memory setupInfo) {
|
353
|
-
ProductStorage storage $ = _getProductStorage();
|
354
|
-
|
355
|
-
ISetup.DistributionSetupInfo memory distributionSetupInfo = $._distribution.getSetupInfo();
|
356
|
-
IComponents.PoolInfo memory poolInfo = $._pool.getPoolInfo();
|
357
|
-
|
358
|
-
return ISetup.ProductSetupInfo(
|
359
|
-
getToken(),
|
360
|
-
$._tokenHandler,
|
361
|
-
$._distributionNftId,
|
362
|
-
$._poolNftId,
|
363
|
-
$._initialProductFee,
|
364
|
-
$._initialProcessingFee,
|
365
|
-
false,
|
366
|
-
getWallet()
|
367
|
-
);
|
364
|
+
function _toRiskId(string memory riskName) internal pure returns (RiskId riskId) {
|
365
|
+
return RiskIdLib.toRiskId(riskName);
|
368
366
|
}
|
369
367
|
|
370
368
|
function _getProductStorage() private pure returns (ProductStorage storage $) {
|