@etherisc/gif-next 0.0.2-b38343e-249 → 0.0.2-b44ae3c-205
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 +6 -83
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/components/Component.sol/Component.json +115 -95
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +182 -195
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IComponent.sol/IComponent.json +190 -67
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +207 -150
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +389 -181
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +213 -158
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +334 -249
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +135 -183
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +64 -50
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.json +5 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +306 -2137
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +193 -75
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +432 -2883
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +491 -127
- 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 +425 -242
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +231 -287
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +38 -75
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2788 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +1 -1
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +8 -13
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.json +123 -33
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +56 -73
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +186 -126
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +29 -38
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +443 -240
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +74 -39
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +722 -81
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +147 -32
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +732 -111
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +147 -44
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +126 -95
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +300 -187
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.json +395 -50
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +424 -64
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +212 -133
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +787 -46
- package/artifacts/contracts/instance/service/IPricingService.sol/IPricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPricingService.sol/IPricingService.json +510 -0
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +95 -26
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +387 -215
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +84 -61
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +958 -52
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +96 -37
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingService.sol/PricingService.json +1004 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PricingServiceManager.sol/PricingServiceManager.json +688 -0
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +152 -54
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +28 -37
- 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 +19 -0
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +5 -26
- 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 +31 -12
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +2 -2
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +23 -39
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +21 -34
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +23 -11
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +10 -23
- 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/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +0 -13
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +69 -9
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +0 -13
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +0 -13
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +95 -26
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +6 -19
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +80 -26
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +14 -27
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +7 -20
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +102 -28
- 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/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +7 -20
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +117 -39
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +2 -2
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +281 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +83 -4
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +74 -19
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +116 -7
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +38 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/Component.sol +115 -85
- package/contracts/components/Distribution.sol +27 -50
- package/contracts/components/IComponent.sol +52 -17
- package/contracts/components/IDistributionComponent.sol +1 -30
- package/contracts/components/IPoolComponent.sol +75 -48
- package/contracts/components/IProductComponent.sol +8 -6
- package/contracts/components/Pool.sol +178 -130
- package/contracts/components/Product.sol +164 -74
- package/contracts/instance/BundleManager.sol +10 -9
- package/contracts/instance/Cloneable.sol +7 -2
- package/contracts/instance/IInstance.sol +40 -55
- package/contracts/instance/IInstanceService.sol +28 -14
- package/contracts/instance/Instance.sol +123 -185
- package/contracts/instance/InstanceAccessManager.sol +404 -160
- package/contracts/instance/InstanceAuthorizationsLib.sol +308 -0
- package/contracts/instance/InstanceReader.sol +90 -15
- package/contracts/instance/InstanceService.sol +173 -341
- package/contracts/instance/InstanceStore.sol +212 -0
- package/contracts/instance/ObjectManager.sol +6 -8
- package/contracts/instance/base/ComponentService.sol +53 -39
- package/contracts/instance/base/KeyValueStore.sol +13 -36
- package/contracts/instance/base/Lifecycle.sol +26 -6
- package/contracts/instance/module/IAccess.sol +21 -14
- package/contracts/instance/module/IBundle.sol +8 -5
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +3 -0
- package/contracts/instance/module/IPolicy.sol +39 -9
- package/contracts/instance/module/ISetup.sol +7 -21
- package/contracts/instance/service/ApplicationService.sol +68 -150
- package/contracts/instance/service/BundleService.sol +223 -139
- package/contracts/instance/service/ClaimService.sol +318 -32
- package/contracts/instance/service/DistributionService.sol +171 -100
- package/contracts/instance/service/IApplicationService.sol +11 -31
- package/contracts/instance/service/IBundleService.sol +92 -28
- package/contracts/instance/service/IClaimService.sol +52 -23
- package/contracts/instance/service/IDistributionService.sol +33 -11
- package/contracts/instance/service/IPolicyService.sol +24 -33
- package/contracts/instance/service/IPoolService.sol +97 -3
- package/contracts/instance/service/IPricingService.sol +37 -0
- package/contracts/instance/service/PolicyService.sol +168 -266
- package/contracts/instance/service/PoolService.sol +313 -19
- package/contracts/instance/service/PricingService.sol +275 -0
- package/contracts/instance/service/PricingServiceManager.sol +51 -0
- package/contracts/instance/service/ProductService.sol +37 -60
- package/contracts/registry/ChainNft.sol +8 -0
- package/contracts/registry/IRegistry.sol +2 -0
- package/contracts/registry/IRegistryService.sol +2 -3
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +23 -20
- package/contracts/registry/RegistryService.sol +29 -26
- package/contracts/registry/ReleaseManager.sol +20 -18
- package/contracts/shared/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/shared/IPolicyHolder.sol +23 -9
- package/contracts/shared/IRegistryLinked.sol +0 -1
- package/contracts/shared/IService.sol +6 -4
- package/contracts/shared/NftOwnable.sol +0 -2
- package/contracts/shared/PolicyHolder.sol +30 -17
- package/contracts/shared/Registerable.sol +12 -11
- package/contracts/shared/RegistryLinked.sol +0 -5
- package/contracts/shared/Service.sol +21 -7
- package/contracts/shared/TokenHandler.sol +14 -6
- package/contracts/test/TestService.sol +1 -1
- package/contracts/types/Amount.sol +109 -0
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +25 -2
- package/contracts/types/Fee.sol +17 -8
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/ObjectType.sol +10 -5
- package/contracts/types/PayoutId.sol +33 -5
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +13 -6
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +7 -2
- package/contracts/types/Timestamp.sol +18 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +1 -0
- package/package.json +1 -1
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/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/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
@@ -6,13 +6,16 @@ import {IInstance} from "../../instance/IInstance.sol";
|
|
6
6
|
import {InstanceAccessManager} from "../InstanceAccessManager.sol";
|
7
7
|
import {InstanceReader} from "../../instance/InstanceReader.sol";
|
8
8
|
import {ISetup} from "../../instance/module/ISetup.sol";
|
9
|
+
import {IPolicy} from "../module/IPolicy.sol";
|
9
10
|
|
11
|
+
import {Amount, AmountLib} from "../../types/Amount.sol";
|
10
12
|
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
11
|
-
import {Fee} from "../../types/Fee.sol";
|
12
|
-
import {DISTRIBUTION_OWNER_ROLE} from "../../types/RoleId.sol";
|
13
|
+
import {Fee, FeeLib} from "../../types/Fee.sol";
|
14
|
+
import {PRODUCT_SERVICE_ROLE, DISTRIBUTION_OWNER_ROLE} from "../../types/RoleId.sol";
|
13
15
|
import {KEEP_STATE} from "../../types/StateId.sol";
|
14
|
-
import {ObjectType, DISTRIBUTION, INSTANCE, DISTRIBUTION, DISTRIBUTOR} from "../../types/ObjectType.sol";
|
16
|
+
import {ObjectType, DISTRIBUTION, INSTANCE, DISTRIBUTION, DISTRIBUTOR, PRICE} from "../../types/ObjectType.sol";
|
15
17
|
import {Version, VersionLib} from "../../types/Version.sol";
|
18
|
+
import {RoleId} from "../../types/RoleId.sol";
|
16
19
|
|
17
20
|
import {IVersionable} from "../../shared/IVersionable.sol";
|
18
21
|
import {Versionable} from "../../shared/Versionable.sol";
|
@@ -24,13 +27,15 @@ import {InstanceService} from "../InstanceService.sol";
|
|
24
27
|
import {IComponent} from "../../components/IComponent.sol";
|
25
28
|
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
26
29
|
import {IDistributionService} from "./IDistributionService.sol";
|
30
|
+
import {IPricingService} from "./IPricingService.sol";
|
27
31
|
|
28
|
-
import {UFixed} from "../../types/UFixed.sol";
|
32
|
+
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
29
33
|
import {DistributorType, DistributorTypeLib} from "../../types/DistributorType.sol";
|
30
34
|
import {ReferralId, ReferralStatus, ReferralLib} from "../../types/Referral.sol";
|
31
35
|
import {Timestamp, TimestampLib, zeroTimestamp} from "../../types/Timestamp.sol";
|
32
36
|
import {Key32} from "../../types/Key32.sol";
|
33
37
|
import {IDistribution} from "../module/IDistribution.sol";
|
38
|
+
import {InstanceStore} from "../InstanceStore.sol";
|
34
39
|
|
35
40
|
|
36
41
|
contract DistributionService is
|
@@ -38,6 +43,10 @@ contract DistributionService is
|
|
38
43
|
IDistributionService
|
39
44
|
{
|
40
45
|
using NftIdLib for NftId;
|
46
|
+
using TimestampLib for Timestamp;
|
47
|
+
using UFixedLib for UFixed;
|
48
|
+
using FeeLib for Fee;
|
49
|
+
using ReferralLib for ReferralId;
|
41
50
|
|
42
51
|
address internal _registryAddress;
|
43
52
|
|
@@ -54,11 +63,11 @@ contract DistributionService is
|
|
54
63
|
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
55
64
|
// TODO while DistributionService is not deployed in DistributionServiceManager constructor
|
56
65
|
// owner is DistributionServiceManager deployer
|
57
|
-
initializeService(registryAddress, owner);
|
66
|
+
initializeService(registryAddress, address(0), owner);
|
58
67
|
registerInterface(type(IDistributionService).interfaceId);
|
59
68
|
}
|
60
69
|
|
61
|
-
function getDomain() public pure override
|
70
|
+
function getDomain() public pure override returns(ObjectType) {
|
62
71
|
return DISTRIBUTION();
|
63
72
|
}
|
64
73
|
|
@@ -81,25 +90,46 @@ contract DistributionService is
|
|
81
90
|
distribution.linkToRegisteredNftId();
|
82
91
|
distributionNftId = distributionInfo.nftId;
|
83
92
|
|
84
|
-
instance.createDistributionSetup(distributionNftId, distribution.getSetupInfo());
|
85
|
-
|
86
|
-
|
93
|
+
instance.getInstanceStore().createDistributionSetup(distributionNftId, distribution.getSetupInfo());
|
94
|
+
// TODO move to distribution?
|
95
|
+
bytes4[][] memory selectors = new bytes4[][](2);
|
96
|
+
selectors[0] = new bytes4[](1);
|
97
|
+
selectors[1] = new bytes4[](2);
|
98
|
+
|
99
|
+
selectors[0][0] = IDistributionComponent.setFees.selector;
|
100
|
+
selectors[1][0] = IDistributionComponent.processRenewal.selector;
|
101
|
+
|
102
|
+
RoleId[] memory roles = new RoleId[](2);
|
103
|
+
roles[0] = DISTRIBUTION_OWNER_ROLE();
|
104
|
+
roles[1] = PRODUCT_SERVICE_ROLE();
|
105
|
+
|
106
|
+
getInstanceService().createGifTarget(
|
107
|
+
instanceNftId,
|
108
|
+
distributionAddress,
|
109
|
+
distribution.getName(),
|
110
|
+
selectors,
|
111
|
+
roles);
|
87
112
|
}
|
88
113
|
|
89
114
|
function setFees(
|
115
|
+
Fee memory minDistributionOwnerFee,
|
90
116
|
Fee memory distributionFee
|
91
117
|
)
|
92
118
|
external
|
93
119
|
override
|
94
120
|
{
|
95
|
-
(
|
121
|
+
if (minDistributionOwnerFee.fractionalFee > distributionFee.fractionalFee) {
|
122
|
+
revert ErrorIDistributionServiceMinFeeTooHigh(minDistributionOwnerFee.fractionalFee.toInt(), distributionFee.fractionalFee.toInt());
|
123
|
+
}
|
124
|
+
|
125
|
+
(NftId distributionNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(DISTRIBUTION());
|
96
126
|
InstanceReader instanceReader = instance.getInstanceReader();
|
97
|
-
NftId distributionNftId = info.nftId;
|
98
127
|
|
99
128
|
ISetup.DistributionSetupInfo memory distSetupInfo = instanceReader.getDistributionSetupInfo(distributionNftId);
|
129
|
+
distSetupInfo.minDistributionOwnerFee = minDistributionOwnerFee;
|
100
130
|
distSetupInfo.distributionFee = distributionFee;
|
101
131
|
|
102
|
-
instance.updateDistributionSetup(distributionNftId, distSetupInfo, KEEP_STATE());
|
132
|
+
instance.getInstanceStore().updateDistributionSetup(distributionNftId, distSetupInfo, KEEP_STATE());
|
103
133
|
}
|
104
134
|
|
105
135
|
function createDistributorType(
|
@@ -116,33 +146,43 @@ contract DistributionService is
|
|
116
146
|
external
|
117
147
|
returns (DistributorType distributorType)
|
118
148
|
{
|
119
|
-
(
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
commissionPercentage,
|
129
|
-
maxReferralCount,
|
130
|
-
maxReferralLifetime,
|
131
|
-
allowSelfReferrals,
|
132
|
-
allowRenewals,
|
133
|
-
data);
|
134
|
-
|
135
|
-
instance.createDistributorType(key32, info);
|
149
|
+
(NftId distributionNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(DISTRIBUTION());
|
150
|
+
|
151
|
+
{
|
152
|
+
ISetup.DistributionSetupInfo memory setupInfo = instance.getInstanceReader().getDistributionSetupInfo(distributionNftId);
|
153
|
+
UFixed variableFeesPartsTotal = setupInfo.minDistributionOwnerFee.fractionalFee.add(commissionPercentage);
|
154
|
+
UFixed maxDiscountPercentageLimit = setupInfo.distributionFee.fractionalFee.sub(variableFeesPartsTotal);
|
155
|
+
if (maxDiscountPercentage.gt(maxDiscountPercentageLimit)) {
|
156
|
+
revert ErrorIDistributionServiceMaxDiscountTooHigh(maxDiscountPercentage.toInt(), maxDiscountPercentageLimit.toInt());
|
157
|
+
}
|
136
158
|
}
|
159
|
+
|
160
|
+
distributorType = DistributorTypeLib.toDistributorType(distributionNftId, name);
|
161
|
+
IDistribution.DistributorTypeInfo memory info = IDistribution.DistributorTypeInfo(
|
162
|
+
name,
|
163
|
+
minDiscountPercentage,
|
164
|
+
maxDiscountPercentage,
|
165
|
+
commissionPercentage,
|
166
|
+
maxReferralCount,
|
167
|
+
maxReferralLifetime,
|
168
|
+
allowSelfReferrals,
|
169
|
+
allowRenewals,
|
170
|
+
data);
|
171
|
+
|
172
|
+
instance.getInstanceStore().createDistributorType(distributorType, info);
|
137
173
|
}
|
138
174
|
|
175
|
+
|
139
176
|
function createDistributor(
|
140
177
|
address distributor,
|
141
178
|
DistributorType distributorType,
|
142
179
|
bytes memory data
|
143
|
-
)
|
180
|
+
)
|
181
|
+
external
|
182
|
+
virtual
|
183
|
+
returns (NftId distributorNftId)
|
144
184
|
{
|
145
|
-
(
|
185
|
+
(NftId distributionNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(DISTRIBUTION());
|
146
186
|
|
147
187
|
distributorNftId = getRegistryService().registerDistributor(
|
148
188
|
IRegistry.ObjectInfo(
|
@@ -158,26 +198,28 @@ contract DistributionService is
|
|
158
198
|
IDistribution.DistributorInfo memory info = IDistribution.DistributorInfo(
|
159
199
|
distributorType,
|
160
200
|
true, // active
|
161
|
-
data
|
201
|
+
data,
|
202
|
+
AmountLib.zero(),
|
203
|
+
0);
|
162
204
|
|
163
|
-
instance.createDistributor(distributorNftId, info);
|
205
|
+
instance.getInstanceStore().createDistributor(distributorNftId, info);
|
164
206
|
}
|
165
207
|
|
166
|
-
function updateDistributorType(
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
)
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
}
|
208
|
+
// function updateDistributorType(
|
209
|
+
// NftId distributorNftId,
|
210
|
+
// DistributorType distributorType,
|
211
|
+
// bytes memory data
|
212
|
+
// )
|
213
|
+
// external
|
214
|
+
// virtual
|
215
|
+
// {
|
216
|
+
// (, IInstance instance) = _getAndVerifyCallingDistribution();
|
217
|
+
// InstanceReader instanceReader = instance.getInstanceReader();
|
218
|
+
// IDistribution.DistributorInfo memory distributorInfo = instanceReader.getDistributorInfo(distributorNftId);
|
219
|
+
// distributorInfo.distributorType = distributorType;
|
220
|
+
// distributorInfo.data = data;
|
221
|
+
// instance.updateDistributor(distributorNftId, distributorInfo, KEEP_STATE());
|
222
|
+
// }
|
181
223
|
|
182
224
|
|
183
225
|
function createReferral(
|
@@ -192,9 +234,31 @@ contract DistributionService is
|
|
192
234
|
virtual
|
193
235
|
returns (ReferralId referralId)
|
194
236
|
{
|
195
|
-
(
|
196
|
-
|
197
|
-
|
237
|
+
(NftId distributionNftId,, IInstance instance) = _getAndVerifyCallingComponentAndInstance(DISTRIBUTION());
|
238
|
+
|
239
|
+
if (bytes(code).length == 0) {
|
240
|
+
revert ErrorIDistributionServiceInvalidReferral(code);
|
241
|
+
}
|
242
|
+
if (expiryAt.eqz()) {
|
243
|
+
revert ErrorIDistributionServiceExpirationInvalid(expiryAt);
|
244
|
+
}
|
245
|
+
|
246
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
247
|
+
DistributorType distributorType = instanceReader.getDistributorInfo(distributorNftId).distributorType;
|
248
|
+
IDistribution.DistributorTypeInfo memory distributorTypeData = instanceReader.getDistributorTypeInfo(distributorType);
|
249
|
+
|
250
|
+
if (distributorTypeData.maxReferralCount < maxReferrals) {
|
251
|
+
revert ErrorIDistributionServiceMaxReferralsExceeded(distributorTypeData.maxReferralCount);
|
252
|
+
}
|
253
|
+
if (distributorTypeData.minDiscountPercentage > discountPercentage) {
|
254
|
+
revert ErrorIDistributionServiceDiscountTooLow(distributorTypeData.minDiscountPercentage.toInt(), discountPercentage.toInt());
|
255
|
+
}
|
256
|
+
if (distributorTypeData.maxDiscountPercentage < discountPercentage) {
|
257
|
+
revert ErrorIDistributionServiceDiscountTooHigh(distributorTypeData.maxDiscountPercentage.toInt(), discountPercentage.toInt());
|
258
|
+
}
|
259
|
+
if (expiryAt.toInt() - TimestampLib.blockTimestamp().toInt() > distributorTypeData.maxReferralLifetime) {
|
260
|
+
revert ErrorIDistributionServiceExpiryTooLong(distributorTypeData.maxReferralLifetime, expiryAt.toInt());
|
261
|
+
}
|
198
262
|
|
199
263
|
referralId = ReferralLib.toReferralId(distributionNftId, code);
|
200
264
|
IDistribution.ReferralInfo memory info = IDistribution.ReferralInfo(
|
@@ -207,71 +271,78 @@ contract DistributionService is
|
|
207
271
|
data
|
208
272
|
);
|
209
273
|
|
210
|
-
instance.createReferral(referralId
|
274
|
+
instance.getInstanceStore().createReferral(referralId, info);
|
211
275
|
return referralId;
|
212
276
|
}
|
213
277
|
|
214
278
|
function processSale(
|
279
|
+
NftId distributionNftId, // assume always of distribution type
|
215
280
|
ReferralId referralId,
|
216
|
-
|
281
|
+
IPolicy.Premium memory premium,
|
282
|
+
Amount transferredDistributionFeeAmount
|
217
283
|
)
|
218
284
|
external
|
219
285
|
virtual
|
220
286
|
{
|
221
|
-
|
222
|
-
|
287
|
+
bool isReferral = ! referralId.eqz();
|
288
|
+
bool referralValid = referralIsValid(distributionNftId, referralId);
|
223
289
|
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
290
|
+
if (isReferral && ! referralValid) {
|
291
|
+
revert ErrorIDistributionServiceReferralInvalid(distributionNftId, referralId);
|
292
|
+
}
|
293
|
+
|
294
|
+
IInstance instance = _getInstanceForDistribution(distributionNftId);
|
295
|
+
InstanceReader reader = instance.getInstanceReader();
|
296
|
+
InstanceStore store = instance.getInstanceStore();
|
297
|
+
IDistribution.ReferralInfo memory referralInfo = reader.getReferralInfo(referralId);
|
298
|
+
IDistribution.DistributorInfo memory distributorInfo = reader.getDistributorInfo(referralInfo.distributorNftId);
|
299
|
+
ISetup.DistributionSetupInfo memory setupInfo = reader.getDistributionSetupInfo(distributionNftId);
|
300
|
+
|
301
|
+
Amount distributionOwnerFee = AmountLib.toAmount(premium.distributionOwnerFeeFixAmount + premium.distributionOwnerFeeVarAmount);
|
302
|
+
Amount commissionAmount = AmountLib.toAmount(premium.commissionAmount);
|
303
|
+
|
304
|
+
if (!(transferredDistributionFeeAmount == distributionOwnerFee + commissionAmount)) {
|
305
|
+
revert ErrorDistributionServiceInvalidFeeTransferred(transferredDistributionFeeAmount, distributionOwnerFee + commissionAmount);
|
306
|
+
}
|
307
|
+
|
308
|
+
|
309
|
+
if (distributionOwnerFee.gtz()) {
|
310
|
+
setupInfo.sumDistributionOwnerFees += distributionOwnerFee.toInt();
|
311
|
+
store.updateDistributionSetup(distributionNftId, setupInfo, KEEP_STATE());
|
312
|
+
}
|
313
|
+
|
314
|
+
if (isReferral) {
|
315
|
+
referralInfo.usedReferrals += 1;
|
316
|
+
store.updateReferral(referralId, referralInfo, KEEP_STATE());
|
317
|
+
|
318
|
+
if (commissionAmount.gtz()) {
|
319
|
+
distributorInfo.commissionAmount = distributorInfo.commissionAmount + commissionAmount;
|
320
|
+
distributorInfo.numPoliciesSold += 1;
|
321
|
+
store.updateDistributor(referralInfo.distributorNftId, distributorInfo, KEEP_STATE());
|
322
|
+
}
|
323
|
+
}
|
234
324
|
}
|
235
325
|
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
address distributionAddress,
|
241
|
-
NftId distributionNftId,
|
242
|
-
IInstance instance
|
243
|
-
)
|
244
|
-
{
|
245
|
-
ObjectType objectType;
|
246
|
-
(
|
247
|
-
distributionAddress,
|
248
|
-
distributionNftId,
|
249
|
-
objectType,
|
250
|
-
instance
|
251
|
-
) = _getAndVerifyCaller();
|
326
|
+
// TODO: zero should return false
|
327
|
+
function referralIsValid(NftId distributionNftId, ReferralId referralId) public view returns (bool isValid) {
|
328
|
+
IInstance instance = _getInstanceForDistribution(distributionNftId);
|
329
|
+
IDistribution.ReferralInfo memory info = instance.getInstanceReader().getReferralInfo(referralId);
|
252
330
|
|
253
|
-
|
331
|
+
if (info.distributorNftId.eqz()) {
|
332
|
+
return false;
|
333
|
+
}
|
334
|
+
|
335
|
+
isValid = info.expiryAt.eqz() || (info.expiryAt.gtz() && TimestampLib.blockTimestamp() <= info.expiryAt);
|
336
|
+
isValid = isValid && info.usedReferrals < info.maxReferrals;
|
254
337
|
}
|
255
338
|
|
256
|
-
function
|
339
|
+
function _getInstanceForDistribution(NftId distributionNftId)
|
257
340
|
internal
|
258
341
|
view
|
259
|
-
returns(
|
260
|
-
address objectAddress,
|
261
|
-
NftId objectNftId,
|
262
|
-
ObjectType objectType,
|
263
|
-
IInstance instance
|
264
|
-
)
|
342
|
+
returns(IInstance instance)
|
265
343
|
{
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
IRegistry.ObjectInfo memory info = getRegistry().getObjectInfo(objectNftId);
|
270
|
-
objectType = info.objectType;
|
271
|
-
|
272
|
-
IRegistry.ObjectInfo memory parentInfo = getRegistry().getObjectInfo(info.parentNftId);
|
273
|
-
require(parentInfo.objectType == INSTANCE(), "ERROR:SRV-031:PARENT_NOT_INSTANCE");
|
274
|
-
instance = IInstance(parentInfo.objectAddress);
|
344
|
+
NftId instanceNftId = getRegistry().getObjectInfo(distributionNftId).parentNftId;
|
345
|
+
address instanceAddress = getRegistry().getObjectInfo(instanceNftId).objectAddress;
|
346
|
+
return IInstance(instanceAddress);
|
275
347
|
}
|
276
|
-
|
277
|
-
}
|
348
|
+
}
|
@@ -1,30 +1,30 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
-
import {
|
4
|
+
import {IPolicy} from "../module/IPolicy.sol";
|
5
5
|
import {IService} from "../../shared/IService.sol";
|
6
6
|
|
7
|
+
import {Amount} from "../../types/Amount.sol";
|
7
8
|
import {NftId} from "../../types/NftId.sol";
|
9
|
+
import {ObjectType} from "../../types/ObjectType.sol";
|
8
10
|
import {ReferralId} from "../../types/Referral.sol";
|
9
11
|
import {RiskId} from "../../types/RiskId.sol";
|
10
|
-
import {
|
11
|
-
import {Timestamp} from "../../types/Timestamp.sol";
|
12
|
-
import {UFixed} from "../../types/UFixed.sol";
|
13
|
-
import {Fee} from "../../types/Fee.sol";
|
12
|
+
import {Seconds} from "../../types/Seconds.sol";
|
14
13
|
|
15
14
|
/// @dev gif service responsible for creating applications
|
16
15
|
/// only product components may call transaction functions
|
17
16
|
interface IApplicationService is IService {
|
18
17
|
|
19
|
-
error
|
18
|
+
error ErrorApplicationServiceNotProduct(NftId callerNftId, ObjectType callerType);
|
19
|
+
error ErrorApplicationServiceBundlePoolMismatch(NftId bundleNftId, NftId bundlePoolNftId, NftId poolNftId);
|
20
20
|
|
21
21
|
/// @dev creates a new application based on the specified attributes
|
22
22
|
/// may only be called by a product component
|
23
23
|
function create(
|
24
24
|
address applicationOwner,
|
25
25
|
RiskId riskId,
|
26
|
-
|
27
|
-
|
26
|
+
Amount sumInsuredAmount,
|
27
|
+
Seconds lifetime,
|
28
28
|
NftId bundleNftId,
|
29
29
|
ReferralId referralId,
|
30
30
|
bytes memory applicationData
|
@@ -38,8 +38,8 @@ interface IApplicationService is IService {
|
|
38
38
|
RiskId riskId,
|
39
39
|
NftId bundleNftId,
|
40
40
|
ReferralId referralId,
|
41
|
-
|
42
|
-
|
41
|
+
Amount sumInsuredAmount,
|
42
|
+
Seconds lifetime,
|
43
43
|
bytes memory applicationData
|
44
44
|
) external;
|
45
45
|
|
@@ -59,24 +59,4 @@ interface IApplicationService is IService {
|
|
59
59
|
/// an application can only be revoked in applied state
|
60
60
|
/// only the application holder may revoke an application
|
61
61
|
function revoke(NftId policyNftId) external;
|
62
|
-
|
63
|
-
/// @dev calculates the premium amount for the specified attributes
|
64
|
-
/// also returns the various fee components involved with creating a policy
|
65
|
-
function calculatePremium(
|
66
|
-
RiskId riskId,
|
67
|
-
uint256 sumInsuredAmount,
|
68
|
-
uint256 lifetime,
|
69
|
-
bytes memory applicationData,
|
70
|
-
NftId bundleNftId,
|
71
|
-
ReferralId referralId
|
72
|
-
)
|
73
|
-
external
|
74
|
-
view
|
75
|
-
returns (
|
76
|
-
uint256 premiumAmount,
|
77
|
-
uint256 distributionFeeAmount,
|
78
|
-
uint256 productFeeAmount,
|
79
|
-
uint256 poolFeeAmount,
|
80
|
-
uint256 bundleFeeAmount
|
81
|
-
);
|
82
|
-
}
|
62
|
+
}
|
@@ -1,54 +1,118 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.19;
|
3
3
|
|
4
|
+
import {Amount} from "../../types/Amount.sol";
|
4
5
|
import {NftId} from "../../types/NftId.sol";
|
5
6
|
import {Fee} from "../../types/Fee.sol";
|
6
|
-
import {StateId} from "../../types/StateId.sol";
|
7
7
|
import {IService} from "../../shared/IService.sol";
|
8
8
|
import {IBundle} from "../module/IBundle.sol";
|
9
9
|
import {IInstance} from "../../instance/IInstance.sol";
|
10
|
+
import {Seconds} from "../../types/Seconds.sol";
|
11
|
+
import {StateId} from "../../types/StateId.sol";
|
12
|
+
import {Timestamp} from "../../types/Timestamp.sol";
|
10
13
|
|
11
14
|
interface IBundleService is IService {
|
12
|
-
error ErrorIBundleServiceInsufficientAllowance(address bundleOwner, address tokenHandlerAddress, uint256 amount);
|
13
15
|
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
16
|
+
event LogBundleServiceBundleActivated(NftId bundleNftId);
|
17
|
+
event LogBundleServiceBundleLocked(NftId bundleNftId);
|
18
|
+
|
19
|
+
error ErrorBundleServiceInsufficientAllowance(address bundleOwner, address tokenHandlerAddress, Amount amount);
|
20
|
+
error ErrorBundleServiceBundleNotOpen(NftId bundleNftId, StateId state, Timestamp expiredAt);
|
21
|
+
error ErrorBundleServiceCapacityInsufficient(NftId bundleNftId, Amount capacityAmount, Amount collateralAmount);
|
22
|
+
error ErrorBundleServiceBundleWithOpenPolicies(NftId bundleNftId, uint256 openPoliciesCount);
|
23
|
+
|
24
|
+
error ErrorBundleServiceBundleUnknown(NftId bundleNftId);
|
25
|
+
error ErrorBundleServiceBundlePoolMismatch(NftId bundleNftId, NftId expectedPool, NftId actualPool);
|
26
|
+
|
27
|
+
error ErrorBundleServicePolicyNotCloseable(NftId policyNftId);
|
28
|
+
|
29
|
+
/// @dev create a new bundle for the specified attributes
|
30
|
+
/// may only be called by pool service
|
31
|
+
function create(
|
32
|
+
IInstance instance, // instance relevant for bundle
|
33
|
+
NftId poolNftId, // the pool the bundle will be linked to
|
34
|
+
address owner, // initial bundle owner
|
35
|
+
Fee memory fee, // fees deducted from premium that go to bundle owner
|
36
|
+
Amount stakingAmount, // staking amount - staking fees result in initial bundle capital
|
37
|
+
Seconds lifetime, // initial duration for which new policies are covered
|
38
|
+
bytes calldata filter // optional use case specific criteria that define if a policy may be covered by this bundle
|
39
|
+
)
|
40
|
+
external
|
41
|
+
returns(NftId bundleNftId); // the nft id of the newly created bundle
|
21
42
|
|
22
|
-
|
43
|
+
|
44
|
+
/// @dev increase bundle stakes by the specified amount
|
45
|
+
/// may only be called by the bundle owner
|
46
|
+
// function stake(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
47
|
+
|
48
|
+
// function unstake(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
49
|
+
|
50
|
+
/// @dev locks the specified bundle, locked bundles are not available to collateralize new policies
|
51
|
+
/// only active bundles may be locked
|
52
|
+
/// may only be called by registered and unlocked pool components
|
53
|
+
function lock(NftId bundleNftId) external;
|
54
|
+
|
55
|
+
/// @dev activates the specified bundle
|
56
|
+
/// only locked bundles may be unlocked
|
57
|
+
/// may only be called by registered and unlocked pool components
|
58
|
+
function unlock(NftId bundleNftId) external;
|
59
|
+
|
60
|
+
/// @dev closes the specified bundle
|
61
|
+
/// only open bundles (active or locked) may be closed
|
62
|
+
/// to close a bundle it may not have any non-closed polices attached to it
|
63
|
+
/// may only be called by registered and unlocked pool components
|
64
|
+
function close(
|
65
|
+
IInstance instance,
|
66
|
+
NftId bundleNftId
|
67
|
+
) external;
|
68
|
+
|
69
|
+
/// @dev set bundle fee to provided value
|
70
|
+
/// may only be called by registered and unlocked pool components
|
71
|
+
function setFee(
|
23
72
|
NftId bundleNftId,
|
24
73
|
Fee memory fee
|
25
74
|
) external;
|
26
75
|
|
27
|
-
function updateBundle(NftId instanceNftId, NftId bundleNftId, IBundle.BundleInfo memory bundleInfo, StateId state) external;
|
28
76
|
|
77
|
+
/// @dev locks the specified collateral in the bundle
|
78
|
+
/// the locked collateral is added to the bundle locked capital
|
79
|
+
/// the bundles' fees are updated with the fees for this premium
|
80
|
+
/// the premium (minus bundle fee) is added to the bundle capital
|
81
|
+
/// may only be called by pool service
|
29
82
|
function lockCollateral(
|
30
83
|
IInstance instanceNftId,
|
31
84
|
NftId policyNftId,
|
32
85
|
NftId bundleNftId,
|
33
|
-
|
34
|
-
|
35
|
-
)
|
36
|
-
external
|
37
|
-
returns (
|
38
|
-
IBundle.BundleInfo memory bundleInfo
|
39
|
-
);
|
40
|
-
|
41
|
-
function increaseBalance(IInstance instance, NftId bundleNftId, uint256 amount) external;
|
42
|
-
|
43
|
-
function closePolicy(IInstance instance, NftId policyNftId, NftId bundleNftId, uint256 collateralAmount) external;
|
44
|
-
|
45
|
-
// function fundBundle(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
|
86
|
+
Amount collateralAmount,
|
87
|
+
Amount premiumAmount // premium after pool fee
|
88
|
+
) external;
|
46
89
|
|
47
|
-
|
90
|
+
/// @dev releases the specified collateral in the bundle
|
91
|
+
/// may only be called by pool service
|
92
|
+
function releaseCollateral(
|
93
|
+
IInstance instance,
|
94
|
+
NftId policyNftId,
|
95
|
+
NftId bundleNftId,
|
96
|
+
Amount collateralAmount
|
97
|
+
) external;
|
48
98
|
|
49
|
-
|
99
|
+
/// @dev unlink policy from bundle
|
100
|
+
/// policy may only be unlinked if policy is closeable
|
101
|
+
/// may only be called by pool service
|
102
|
+
function unlinkPolicy(
|
103
|
+
IInstance instance,
|
104
|
+
NftId policyNftId
|
105
|
+
) external;
|
50
106
|
|
51
|
-
|
107
|
+
/// @dev updates the bundle's fees of with the provided fee amount
|
108
|
+
function updateBundleFees(
|
109
|
+
IInstance instance,
|
110
|
+
NftId bundleNftId,
|
111
|
+
Amount feeAmount
|
112
|
+
) external;
|
52
113
|
|
53
|
-
|
114
|
+
function increaseBalance(
|
115
|
+
IInstance instance,
|
116
|
+
NftId bundleNftId,
|
117
|
+
Amount amount) external;
|
54
118
|
}
|