@etherisc/gif-next 0.0.2-e9148e0-933 → 0.0.2-e9a637d-547
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 +65 -2
- package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
- package/artifacts/contracts/components/Component.sol/Component.json +842 -0
- package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/components/Distribution.sol/Distribution.json +941 -230
- package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
- package/artifacts/contracts/{shared/RegisterableUpgradable.sol/RegisterableUpgradable.json → components/IComponent.sol/IComponent.json} +295 -132
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +848 -31
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +864 -49
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +682 -9
- package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/components/Pool.sol/Pool.json +825 -231
- package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/components/Product.sol/Product.json +638 -190
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.dbg.json +4 -0
- package/artifacts/contracts/instance/AccessManagerUpgradeableInitializeable.sol/AccessManagerUpgradeableInitializeable.json +1206 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +778 -0
- package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
- package/artifacts/contracts/instance/{AccessManagedSimple.sol/AccessManagedSimple.json → Cloneable.sol/Cloneable.json} +91 -2
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +346 -704
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +342 -168
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +405 -3100
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +609 -178
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +148 -247
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +536 -259
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +335 -98
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +4 -0
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2677 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
- package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +256 -0
- package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
- package/artifacts/contracts/instance/base/{ComponentServiceBase.sol/ComponentServiceBase.json → ComponentService.sol/ComponentService.json} +247 -180
- package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +40 -10
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +36 -11
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +71 -45
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +4 -0
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.json +10 -0
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
- package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +1039 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +673 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1231 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +721 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +817 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +641 -0
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1341 -259
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +440 -79
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +622 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +659 -0
- package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IClaimService.sol/IClaimService.json} +217 -208
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +804 -160
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +606 -0
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +437 -154
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +90 -391
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1092 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
- package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +697 -0
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +649 -251
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +305 -92
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +284 -502
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +304 -99
- 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 +261 -131
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +149 -230
- 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 +275 -226
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +200 -335
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +298 -141
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +559 -0
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +141 -53
- package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +40 -29
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +21 -34
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +86 -172
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +120 -27
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +294 -61
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -51
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +191 -163
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +2 -2
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
- package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
- package/artifacts/contracts/test/TestFee.sol/TestFee.json +2 -2
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
- package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +129 -51
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
- package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +6 -6
- package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
- package/artifacts/contracts/test/TestService.sol/TestService.json +210 -214
- package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersion.sol/TestVersion.json +2 -2
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
- package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
- package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
- package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/types/Amount.sol/AmountLib.dbg.json +4 -0
- package/artifacts/contracts/types/Amount.sol/AmountLib.json +161 -0
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.json +2 -2
- package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/types/Fee.sol/FeeLib.json +40 -9
- package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/NftId.sol/NftIdLib.json +17 -4
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
- package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
- package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
- package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
- package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
- package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/types/StateId.sol/StateIdLib.json +2 -2
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +25 -7
- package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/types/UFixed.sol/UFixedLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/types/Version.sol/VersionPartLib.json +2 -2
- package/contracts/components/Component.sol +253 -0
- package/contracts/components/Distribution.sol +200 -79
- package/contracts/components/IComponent.sol +76 -0
- package/contracts/components/IDistributionComponent.sol +44 -17
- package/contracts/components/IPoolComponent.sol +88 -37
- package/contracts/components/IProductComponent.sol +10 -5
- package/contracts/components/Pool.sol +221 -160
- package/contracts/components/Product.sol +128 -119
- package/contracts/instance/AccessManagerUpgradeableInitializeable.sol +13 -0
- package/contracts/instance/BundleManager.sol +127 -0
- package/contracts/instance/Cloneable.sol +51 -0
- package/contracts/instance/IInstance.sol +43 -24
- package/contracts/instance/IInstanceService.sol +59 -5
- package/contracts/instance/Instance.sol +125 -369
- package/contracts/instance/InstanceAccessManager.sol +428 -176
- package/contracts/instance/InstanceReader.sol +21 -34
- package/contracts/instance/InstanceService.sol +466 -128
- package/contracts/instance/InstanceServiceManager.sol +6 -9
- package/contracts/instance/InstanceStore.sol +219 -0
- package/contracts/instance/ObjectManager.sol +82 -0
- package/contracts/instance/base/ComponentService.sol +121 -0
- package/contracts/instance/base/KeyValueStore.sol +13 -5
- package/contracts/instance/base/Lifecycle.sol +11 -2
- package/contracts/instance/module/IAccess.sol +36 -20
- package/contracts/instance/module/IBundle.sol +8 -5
- package/contracts/instance/module/IComponents.sol +41 -0
- package/contracts/instance/module/IDistribution.sol +2 -0
- package/contracts/instance/module/IPolicy.sol +30 -3
- package/contracts/instance/module/ISetup.sol +9 -20
- package/contracts/instance/service/ApplicationService.sol +351 -0
- package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
- package/contracts/instance/service/BundleService.sol +431 -0
- package/contracts/instance/service/BundleServiceManager.sol +51 -0
- package/contracts/instance/service/ClaimService.sol +151 -0
- package/contracts/instance/service/ClaimServiceManager.sol +35 -0
- package/contracts/instance/service/DistributionService.sol +382 -33
- package/contracts/instance/service/DistributionServiceManager.sol +7 -10
- package/contracts/instance/service/IApplicationService.sol +82 -0
- package/contracts/instance/service/IBundleService.sol +93 -0
- package/contracts/instance/service/IClaimService.sol +61 -0
- package/contracts/instance/service/IDistributionService.sol +87 -0
- package/contracts/instance/service/IPolicyService.sol +72 -0
- package/contracts/instance/service/IPoolService.sol +79 -17
- package/contracts/instance/service/IProductService.sol +6 -73
- package/contracts/instance/service/PolicyService.sol +362 -0
- package/contracts/instance/service/PolicyServiceManager.sol +54 -0
- package/contracts/instance/service/PoolService.sol +217 -108
- package/contracts/instance/service/PoolServiceManager.sol +6 -9
- package/contracts/instance/service/ProductService.sol +114 -453
- package/contracts/instance/service/ProductServiceManager.sol +2 -2
- package/contracts/registry/ChainNft.sol +9 -1
- package/contracts/registry/IRegistry.sol +41 -19
- package/contracts/registry/IRegistryService.sol +31 -13
- package/contracts/registry/ITransferInterceptor.sol +1 -0
- package/contracts/registry/Registry.sol +245 -222
- package/contracts/registry/RegistryAccessManager.sol +216 -0
- package/contracts/registry/RegistryService.sol +97 -173
- package/contracts/registry/RegistryServiceManager.sol +21 -39
- package/contracts/registry/ReleaseManager.sol +324 -0
- package/contracts/registry/TokenRegistry.sol +22 -17
- package/contracts/shared/ERC165.sol +14 -12
- package/contracts/shared/INftOwnable.sol +11 -10
- package/contracts/shared/IPolicyHolder.sol +26 -0
- package/contracts/shared/IRegisterable.sol +4 -6
- package/contracts/shared/IRegistryLinked.sol +12 -0
- package/contracts/shared/IService.sol +5 -4
- package/contracts/shared/IVersionable.sol +4 -47
- package/contracts/shared/NftOwnable.sol +66 -80
- package/contracts/shared/PolicyHolder.sol +81 -0
- package/contracts/shared/ProxyManager.sol +100 -25
- package/contracts/shared/Registerable.sol +16 -32
- package/contracts/shared/RegistryLinked.sol +48 -0
- package/contracts/shared/Service.sol +41 -24
- package/contracts/shared/TokenHandler.sol +11 -5
- package/contracts/shared/Versionable.sol +4 -92
- package/contracts/test/TestRegisterable.sol +1 -1
- package/contracts/test/TestService.sol +4 -3
- package/contracts/types/Amount.sol +60 -0
- package/contracts/types/Blocknumber.sol +1 -0
- package/contracts/types/ClaimId.sol +52 -0
- package/contracts/types/DistributorType.sol +2 -2
- package/contracts/types/Fee.sol +13 -5
- package/contracts/types/NftId.sol +8 -0
- package/contracts/types/NftIdSet.sol +26 -24
- package/contracts/types/ObjectType.sol +10 -5
- package/contracts/types/PayoutId.sol +54 -0
- package/contracts/types/Referral.sol +4 -0
- package/contracts/types/RoleId.sol +26 -19
- package/contracts/types/Seconds.sol +54 -0
- package/contracts/types/StateId.sol +1 -0
- package/contracts/types/Timestamp.sol +13 -13
- package/contracts/types/UFixed.sol +1 -0
- package/contracts/types/Version.sol +1 -0
- package/package.json +3 -3
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -327
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
- package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -280
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
- package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
- package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
- package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
- package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
- package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
- package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
- package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
- package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
- package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
- package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
- package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1132
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
- package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
- package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
- package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
- package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
- package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
- package/contracts/components/BaseComponent.sol +0 -91
- package/contracts/components/IBaseComponent.sol +0 -25
- package/contracts/experiment/cloning/Cloner.sol +0 -47
- package/contracts/experiment/errors/Require.sol +0 -38
- package/contracts/experiment/errors/Revert.sol +0 -44
- package/contracts/experiment/inheritance/A.sol +0 -53
- package/contracts/experiment/inheritance/B.sol +0 -28
- package/contracts/experiment/inheritance/C.sol +0 -34
- package/contracts/experiment/inheritance/IA.sol +0 -13
- package/contracts/experiment/inheritance/IB.sol +0 -10
- package/contracts/experiment/inheritance/IC.sol +0 -12
- package/contracts/experiment/statemachine/Dummy.sol +0 -27
- package/contracts/experiment/statemachine/ISM.sol +0 -25
- package/contracts/experiment/statemachine/SM.sol +0 -57
- package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
- package/contracts/experiment/types/TypeA.sol +0 -47
- package/contracts/experiment/types/TypeB.sol +0 -29
- package/contracts/instance/AccessManagedSimple.sol +0 -115
- package/contracts/instance/AccessManagerSimple.sol +0 -692
- package/contracts/instance/IAccessManagerSimple.sol +0 -391
- package/contracts/instance/base/ComponentServiceBase.sol +0 -124
- package/contracts/instance/base/IInstanceBase.sol +0 -23
- package/contracts/instance/service/ComponentOwnerService.sol +0 -317
- package/contracts/instance/service/IComponentOwnerService.sol +0 -20
- package/contracts/shared/RegisterableUpgradable.sol +0 -16
@@ -4,6 +4,7 @@ pragma solidity ^0.8.19;
|
|
4
4
|
import {IRegistry} from "../../registry/IRegistry.sol";
|
5
5
|
import {IProductComponent} from "../../components/IProductComponent.sol";
|
6
6
|
import {Product} from "../../components/Product.sol";
|
7
|
+
import {IComponent} from "../../components/IComponent.sol";
|
7
8
|
import {IPoolComponent} from "../../components/IPoolComponent.sol";
|
8
9
|
import {IDistributionComponent} from "../../components/IDistributionComponent.sol";
|
9
10
|
import {IInstance} from "../IInstance.sol";
|
@@ -22,7 +23,7 @@ import {Versionable} from "../../shared/Versionable.sol";
|
|
22
23
|
import {Timestamp, zeroTimestamp} from "../../types/Timestamp.sol";
|
23
24
|
import {UFixed, UFixedLib} from "../../types/UFixed.sol";
|
24
25
|
import {Blocknumber, blockNumber} from "../../types/Blocknumber.sol";
|
25
|
-
import {ObjectType,
|
26
|
+
import {ObjectType, PRODUCT, POOL, POLICY} from "../../types/ObjectType.sol";
|
26
27
|
import {APPLIED, UNDERWRITTEN, ACTIVE, KEEP_STATE} from "../../types/StateId.sol";
|
27
28
|
import {NftId, NftIdLib, zeroNftId} from "../../types/NftId.sol";
|
28
29
|
import {Fee, FeeLib} from "../../types/Fee.sol";
|
@@ -30,22 +31,20 @@ import {ReferralId} from "../../types/Referral.sol";
|
|
30
31
|
import {RiskId} from "../../types/RiskId.sol";
|
31
32
|
import {StateId} from "../../types/StateId.sol";
|
32
33
|
import {Version, VersionLib} from "../../types/Version.sol";
|
34
|
+
import {RoleId, PRODUCT_OWNER_ROLE} from "../../types/RoleId.sol";
|
33
35
|
|
34
36
|
import {IService} from "../../shared/IService.sol";
|
35
37
|
import {Service} from "../../shared/Service.sol";
|
36
|
-
import {
|
38
|
+
import {ComponentService} from "../base/ComponentService.sol";
|
37
39
|
import {IProductService} from "./IProductService.sol";
|
38
40
|
import {InstanceReader} from "../InstanceReader.sol";
|
39
|
-
|
40
|
-
string constant PRODUCT_SERVICE_NAME = "ProductService";
|
41
|
+
import {IPoolService} from "./PoolService.sol";
|
41
42
|
|
42
43
|
// TODO or name this ProtectionService to have Product be something more generic (loan, savings account, ...)
|
43
|
-
contract ProductService is
|
44
|
+
contract ProductService is ComponentService, IProductService {
|
44
45
|
using NftIdLib for NftId;
|
45
46
|
|
46
|
-
|
47
|
-
|
48
|
-
address internal _registryAddress;
|
47
|
+
IPoolService internal _poolService;
|
49
48
|
|
50
49
|
event LogProductServiceSender(address sender);
|
51
50
|
|
@@ -57,26 +56,97 @@ contract ProductService is ComponentServiceBase, IProductService {
|
|
57
56
|
initializer
|
58
57
|
virtual override
|
59
58
|
{
|
60
|
-
address
|
61
|
-
|
59
|
+
address registryAddress;
|
60
|
+
address initialOwner;
|
61
|
+
(registryAddress, initialOwner) = abi.decode(data, (address, address));
|
62
62
|
|
63
|
-
|
63
|
+
initializeService(registryAddress, address(0), owner);
|
64
64
|
|
65
|
-
|
66
|
-
|
65
|
+
_poolService = IPoolService(getRegistry().getServiceAddress(POOL(), getVersion().toMajorPart()));
|
66
|
+
|
67
|
+
registerInterface(type(IProductService).interfaceId);
|
67
68
|
}
|
68
69
|
|
69
70
|
|
70
|
-
function
|
71
|
-
|
71
|
+
function register(address productAddress)
|
72
|
+
external
|
73
|
+
returns(NftId productNftId)
|
74
|
+
{
|
75
|
+
(
|
76
|
+
IComponent component,
|
77
|
+
address owner,
|
78
|
+
IInstance instance,
|
79
|
+
NftId instanceNftId
|
80
|
+
) = _checkComponentForRegistration(
|
81
|
+
productAddress,
|
82
|
+
PRODUCT(),
|
83
|
+
PRODUCT_OWNER_ROLE());
|
84
|
+
|
85
|
+
IProductComponent product = IProductComponent(productAddress);
|
86
|
+
IRegistry.ObjectInfo memory productInfo = getRegistryService().registerProduct(product, owner);
|
87
|
+
productNftId = productInfo.nftId;
|
88
|
+
_createProductSetup(
|
89
|
+
instance,
|
90
|
+
product,
|
91
|
+
productNftId);
|
92
|
+
}
|
93
|
+
|
94
|
+
|
95
|
+
function _createProductSetup(
|
96
|
+
IInstance instance,
|
97
|
+
IProductComponent product,
|
98
|
+
NftId productNftId
|
99
|
+
)
|
100
|
+
internal
|
101
|
+
returns (string memory name)
|
102
|
+
{
|
103
|
+
// wire distribution and pool components to product component
|
104
|
+
ISetup.ProductSetupInfo memory setup = product.getSetupInfo();
|
105
|
+
IComponent distribution = IComponent(getRegistry().getObjectInfo(setup.distributionNftId).objectAddress);
|
106
|
+
IComponent pool = IComponent(getRegistry().getObjectInfo(setup.poolNftId).objectAddress);
|
107
|
+
|
108
|
+
distribution.setProductNftId(productNftId);
|
109
|
+
pool.setProductNftId(productNftId);
|
110
|
+
product.setProductNftId(productNftId);
|
111
|
+
product.linkToRegisteredNftId();
|
112
|
+
|
113
|
+
// create product setup in instance
|
114
|
+
instance.getInstanceStore().createProductSetup(productNftId, product.getSetupInfo());
|
115
|
+
|
116
|
+
bytes4[][] memory selectors = new bytes4[][](1);
|
117
|
+
selectors[0] = new bytes4[](1);
|
118
|
+
selectors[0][0] = IProductComponent.setFees.selector;
|
119
|
+
|
120
|
+
RoleId[] memory roles = new RoleId[](1);
|
121
|
+
roles[0] = PRODUCT_OWNER_ROLE();
|
122
|
+
|
123
|
+
// create target for instane access manager
|
124
|
+
getInstanceService().createGifTarget(
|
125
|
+
getRegistry().getNftId(address(instance)),
|
126
|
+
address(product),
|
127
|
+
product.getName(),
|
128
|
+
selectors,
|
129
|
+
roles);
|
130
|
+
}
|
131
|
+
|
132
|
+
function getDomain() public pure override returns(ObjectType) {
|
133
|
+
return PRODUCT();
|
72
134
|
}
|
73
135
|
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
136
|
+
|
137
|
+
function _decodeAndVerifyProductData(bytes memory data)
|
138
|
+
internal
|
139
|
+
returns(string memory name, ISetup.ProductSetupInfo memory setup)
|
140
|
+
{
|
141
|
+
(name, setup) = abi.decode(
|
142
|
+
data,
|
143
|
+
(string, ISetup.ProductSetupInfo)
|
78
144
|
);
|
79
|
-
|
145
|
+
|
146
|
+
// TODO add checks
|
147
|
+
// if(wallet == address(0)) {
|
148
|
+
// revert WalletIsZero();
|
149
|
+
// }
|
80
150
|
}
|
81
151
|
|
82
152
|
function setFees(
|
@@ -84,465 +154,56 @@ contract ProductService is ComponentServiceBase, IProductService {
|
|
84
154
|
Fee memory processingFee
|
85
155
|
)
|
86
156
|
external
|
87
|
-
override
|
88
157
|
{
|
89
|
-
|
158
|
+
// TODO check args
|
159
|
+
|
160
|
+
(NftId productNftId, IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
90
161
|
InstanceReader instanceReader = instance.getInstanceReader();
|
91
|
-
NftId productNftId = productInfo.nftId;
|
92
162
|
|
93
163
|
ISetup.ProductSetupInfo memory productSetupInfo = instanceReader.getProductSetupInfo(productNftId);
|
164
|
+
|
94
165
|
productSetupInfo.productFee = productFee;
|
95
166
|
productSetupInfo.processingFee = processingFee;
|
96
167
|
|
97
|
-
instance.updateProductSetup(productNftId, productSetupInfo, KEEP_STATE());
|
168
|
+
instance.getInstanceStore().updateProductSetup(productNftId, productSetupInfo, KEEP_STATE());
|
98
169
|
}
|
99
170
|
|
100
|
-
// FIXME: this
|
101
171
|
function createRisk(
|
102
172
|
RiskId riskId,
|
103
173
|
bytes memory data
|
104
|
-
) external override {
|
105
|
-
// (IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
106
|
-
// NftId productNftId = productInfo.nftId;
|
107
|
-
// instance.createRisk(
|
108
|
-
// riskId,
|
109
|
-
// productNftId,
|
110
|
-
// data
|
111
|
-
// );
|
112
|
-
}
|
113
|
-
|
114
|
-
// FIXME: this
|
115
|
-
function setRiskInfo(
|
116
|
-
RiskId riskId,
|
117
|
-
IRisk.RiskInfo memory info
|
118
|
-
) external {
|
119
|
-
// (, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
120
|
-
// instance.setRiskInfo(
|
121
|
-
// riskId,
|
122
|
-
// info
|
123
|
-
// );
|
124
|
-
}
|
125
|
-
|
126
|
-
// FIXME: this
|
127
|
-
function updateRiskState(
|
128
|
-
RiskId riskId,
|
129
|
-
StateId state
|
130
|
-
) external {
|
131
|
-
// (, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
132
|
-
// instance.updateRiskState(
|
133
|
-
// riskId,
|
134
|
-
// state
|
135
|
-
// );
|
136
|
-
}
|
137
|
-
|
138
|
-
function _getAndVerifyInstanceAndProduct() internal view returns (Product product) {
|
139
|
-
IRegistry.ObjectInfo memory productInfo;
|
140
|
-
(productInfo,) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
141
|
-
product = Product(productInfo.objectAddress);
|
142
|
-
}
|
143
|
-
|
144
|
-
function calculatePremium(
|
145
|
-
RiskId riskId,
|
146
|
-
uint256 sumInsuredAmount,
|
147
|
-
uint256 lifetime,
|
148
|
-
bytes memory applicationData,
|
149
|
-
NftId bundleNftId,
|
150
|
-
ReferralId referralId
|
151
174
|
)
|
152
|
-
|
153
|
-
view
|
175
|
+
external
|
154
176
|
override
|
155
|
-
returns (
|
156
|
-
uint256 premiumAmount,
|
157
|
-
uint256 productFeeAmount,
|
158
|
-
uint256 poolFeeAmount,
|
159
|
-
uint256 bundleFeeAmount,
|
160
|
-
uint256 distributionFeeAmount
|
161
|
-
)
|
162
177
|
{
|
163
|
-
|
164
|
-
|
165
|
-
|
178
|
+
(NftId productNftId, IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
179
|
+
IRisk.RiskInfo memory riskInfo = IRisk.RiskInfo(productNftId, data);
|
180
|
+
instance.getInstanceStore().createRisk(
|
166
181
|
riskId,
|
167
|
-
|
168
|
-
applicationData
|
182
|
+
riskInfo
|
169
183
|
);
|
170
|
-
|
171
|
-
(
|
172
|
-
productFeeAmount,
|
173
|
-
poolFeeAmount,
|
174
|
-
bundleFeeAmount,
|
175
|
-
distributionFeeAmount
|
176
|
-
) = _calculateFeeAmounts(
|
177
|
-
netPremiumAmount,
|
178
|
-
product,
|
179
|
-
bundleNftId,
|
180
|
-
referralId
|
181
|
-
);
|
182
|
-
|
183
|
-
premiumAmount = netPremiumAmount + productFeeAmount;
|
184
|
-
premiumAmount += poolFeeAmount + bundleFeeAmount;
|
185
|
-
premiumAmount += distributionFeeAmount;
|
186
|
-
}
|
187
|
-
|
188
|
-
function _calculateFeeAmounts(
|
189
|
-
uint256 netPremiumAmount,
|
190
|
-
Product product,
|
191
|
-
NftId bundleNftId,
|
192
|
-
ReferralId referralId
|
193
|
-
)
|
194
|
-
internal
|
195
|
-
view
|
196
|
-
returns (
|
197
|
-
uint256 productFeeAmount,
|
198
|
-
uint256 poolFeeAmount,
|
199
|
-
uint256 bundleFeeAmount,
|
200
|
-
uint256 distributionFeeAmount
|
201
|
-
)
|
202
|
-
{
|
203
|
-
IInstance instance = product.getInstance();
|
204
|
-
// FIXME: this
|
205
|
-
// ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(product.getNftId());
|
206
|
-
// IBundle.BundleInfo memory bundleInfo = instance.getBundleInfo(bundleNftId);
|
207
|
-
// require(bundleInfo.poolNftId == treasuryInfo.poolNftId,"ERROR:PRS-035:BUNDLE_POOL_MISMATCH");
|
208
|
-
|
209
|
-
// (productFeeAmount,) = FeeLib.calculateFee(treasuryInfo.productFee, netPremiumAmount);
|
210
|
-
// (poolFeeAmount,) = FeeLib.calculateFee(treasuryInfo.poolFee, netPremiumAmount);
|
211
|
-
// (bundleFeeAmount,) = FeeLib.calculateFee(bundleInfo.fee, netPremiumAmount);
|
212
|
-
|
213
|
-
// IRegistry.ObjectInfo memory distributionInfo = getRegistry().getObjectInfo(treasuryInfo.distributionNftId);
|
214
|
-
// IDistributionComponent distribution = IDistributionComponent(distributionInfo.objectAddress);
|
215
|
-
// distributionFeeAmount = distribution.calculateFeeAmount(referralId, netPremiumAmount);
|
216
184
|
}
|
217
185
|
|
218
|
-
|
219
|
-
function createApplication(
|
220
|
-
address applicationOwner,
|
186
|
+
function updateRisk(
|
221
187
|
RiskId riskId,
|
222
|
-
|
223
|
-
uint256 lifetime,
|
224
|
-
bytes memory applicationData,
|
225
|
-
NftId bundleNftId,
|
226
|
-
ReferralId referralId
|
227
|
-
) external override returns (NftId policyNftId) {
|
228
|
-
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
229
|
-
// TODO add validations (see create bundle in pool service)
|
230
|
-
|
231
|
-
policyNftId = getRegistryService().registerPolicy(
|
232
|
-
IRegistry.ObjectInfo(
|
233
|
-
zeroNftId(),
|
234
|
-
productInfo.nftId,
|
235
|
-
POLICY(),
|
236
|
-
false, // intercepting property for policies is defined on product
|
237
|
-
address(0),
|
238
|
-
applicationOwner,
|
239
|
-
""
|
240
|
-
)
|
241
|
-
);
|
242
|
-
|
243
|
-
(uint256 premiumAmount,,,,) = calculatePremium(
|
244
|
-
riskId,
|
245
|
-
sumInsuredAmount,
|
246
|
-
lifetime,
|
247
|
-
applicationData,
|
248
|
-
bundleNftId,
|
249
|
-
referralId
|
250
|
-
);
|
251
|
-
|
252
|
-
// FIXME: this
|
253
|
-
// instance.createPolicyInfo(
|
254
|
-
// policyNftId,
|
255
|
-
// productInfo.nftId,
|
256
|
-
// referralId,
|
257
|
-
// riskId,
|
258
|
-
// sumInsuredAmount,
|
259
|
-
// premiumAmount,
|
260
|
-
// lifetime,
|
261
|
-
// bundleNftId
|
262
|
-
// );
|
263
|
-
|
264
|
-
// TODO add logging
|
265
|
-
}
|
266
|
-
|
267
|
-
function _getAndVerifyUnderwritingSetup(
|
268
|
-
IInstance instance,
|
269
|
-
IPolicy.PolicyInfo memory policyInfo
|
270
|
-
)
|
271
|
-
internal
|
272
|
-
view
|
273
|
-
returns (
|
274
|
-
ITreasury.TreasuryInfo memory treasuryInfo,
|
275
|
-
NftId bundleNftId,
|
276
|
-
IBundle.BundleInfo memory bundleInfo,
|
277
|
-
uint256 collateralAmount
|
278
|
-
)
|
279
|
-
{
|
280
|
-
// FIXME: this
|
281
|
-
// check match between policy and bundle (via pool)
|
282
|
-
// treasuryInfo = instance.getTreasuryInfo(policyInfo.productNftId);
|
283
|
-
// bundleNftId = policyInfo.bundleNftId;
|
284
|
-
// bundleInfo = instance.getBundleInfo(bundleNftId);
|
285
|
-
// require(bundleInfo.poolNftId == treasuryInfo.poolNftId, "POLICY_BUNDLE_MISMATCH");
|
286
|
-
|
287
|
-
// // calculate required collateral
|
288
|
-
// NftId poolNftId = treasuryInfo.poolNftId;
|
289
|
-
// ISetup.PoolSetupInfo memory poolInfo = instance.getPoolInfo(poolNftId);
|
290
|
-
|
291
|
-
// // obtain remaining return values
|
292
|
-
// collateralAmount = calculateRequiredCollateral(poolInfo.collateralizationLevel, policyInfo.sumInsuredAmount);
|
293
|
-
}
|
294
|
-
|
295
|
-
function _lockCollateralInBundle(
|
296
|
-
IInstance instance,
|
297
|
-
NftId bundleNftId,
|
298
|
-
IBundle.BundleInfo memory bundleInfo,
|
299
|
-
NftId policyNftId,
|
300
|
-
uint256 collateralAmount
|
301
|
-
)
|
302
|
-
internal
|
303
|
-
returns (IBundle.BundleInfo memory)
|
304
|
-
{
|
305
|
-
bundleInfo.lockedAmount += collateralAmount;
|
306
|
-
// FIXME: this
|
307
|
-
// instance.collateralizePolicy(bundleNftId, policyNftId, collateralAmount);
|
308
|
-
return bundleInfo;
|
309
|
-
}
|
310
|
-
|
311
|
-
function _underwriteByPool(
|
312
|
-
ITreasury.TreasuryInfo memory treasuryInfo,
|
313
|
-
NftId policyNftId,
|
314
|
-
IPolicy.PolicyInfo memory policyInfo,
|
315
|
-
bytes memory bundleFilter,
|
316
|
-
uint256 collateralAmount
|
317
|
-
)
|
318
|
-
internal
|
319
|
-
{
|
320
|
-
address poolAddress = getRegistry().getObjectInfo(treasuryInfo.poolNftId).objectAddress;
|
321
|
-
IPoolComponent pool = IPoolComponent(poolAddress);
|
322
|
-
pool.underwrite(
|
323
|
-
policyNftId,
|
324
|
-
policyInfo.applicationData,
|
325
|
-
bundleFilter,
|
326
|
-
collateralAmount);
|
327
|
-
}
|
328
|
-
|
329
|
-
|
330
|
-
function revoke(
|
331
|
-
NftId policyNftId
|
188
|
+
bytes memory data
|
332
189
|
)
|
333
190
|
external
|
334
|
-
override
|
335
|
-
{
|
336
|
-
require(false, "ERROR:PRS-234:NOT_YET_IMPLEMENTED");
|
337
|
-
}
|
338
|
-
|
339
|
-
|
340
|
-
function underwrite(
|
341
|
-
NftId policyNftId,
|
342
|
-
bool requirePremiumPayment,
|
343
|
-
Timestamp activateAt
|
344
|
-
)
|
345
|
-
external
|
346
|
-
override
|
347
|
-
{
|
348
|
-
// check caller is registered product
|
349
|
-
(
|
350
|
-
IRegistry.ObjectInfo memory productInfo,
|
351
|
-
IInstance instance
|
352
|
-
) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
353
|
-
|
354
|
-
// check match between policy and calling product
|
355
|
-
NftId productNftId = productInfo.nftId;
|
356
|
-
// FIXME: this
|
357
|
-
// IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
358
|
-
// require(policyInfo.productNftId == productNftId, "POLICY_PRODUCT_MISMATCH");
|
359
|
-
// require(instance.getState(policyNftId.toKey32(POLICY())) == APPLIED(), "ERROR:PRS-021:STATE_NOT_APPLIED");
|
360
|
-
|
361
|
-
// ITreasury.TreasuryInfo memory treasuryInfo;
|
362
|
-
// NftId bundleNftId;
|
363
|
-
// IBundle.BundleInfo memory bundleInfo;
|
364
|
-
// uint256 collateralAmount;
|
365
|
-
|
366
|
-
// (
|
367
|
-
// treasuryInfo,
|
368
|
-
// bundleNftId,
|
369
|
-
// bundleInfo,
|
370
|
-
// collateralAmount
|
371
|
-
// ) = _getAndVerifyUnderwritingSetup(
|
372
|
-
// instance,
|
373
|
-
// policyInfo
|
374
|
-
// );
|
375
|
-
|
376
|
-
// // lock bundle collateral
|
377
|
-
// bundleInfo = _lockCollateralInBundle(
|
378
|
-
// instance,
|
379
|
-
// bundleNftId,
|
380
|
-
// bundleInfo,
|
381
|
-
// policyNftId,
|
382
|
-
// collateralAmount);
|
383
|
-
|
384
|
-
// // set policy state to underwritten
|
385
|
-
// instance.updatePolicyState(policyNftId, UNDERWRITTEN());
|
386
|
-
|
387
|
-
// // optional activation of policy
|
388
|
-
// if(activateAt > zeroTimestamp()) {
|
389
|
-
// policyInfo.activatedAt = activateAt;
|
390
|
-
// policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
391
|
-
|
392
|
-
// instance.updatePolicyState(policyNftId, ACTIVE());
|
393
|
-
// }
|
394
|
-
|
395
|
-
// // optional collection of premium
|
396
|
-
// if(requirePremiumPayment) {
|
397
|
-
// uint256 netPremiumAmount = _processPremiumByTreasury(
|
398
|
-
// instance,
|
399
|
-
// productInfo.nftId,
|
400
|
-
// treasuryInfo,
|
401
|
-
// policyNftId,
|
402
|
-
// policyInfo.premiumAmount);
|
403
|
-
|
404
|
-
// policyInfo.premiumPaidAmount += policyInfo.premiumAmount;
|
405
|
-
// bundleInfo.balanceAmount += netPremiumAmount;
|
406
|
-
// }
|
407
|
-
|
408
|
-
// instance.setPolicyInfo(policyNftId, policyInfo);
|
409
|
-
// instance.setBundleInfo(bundleNftId, bundleInfo);
|
410
|
-
|
411
|
-
// // involve pool if necessary
|
412
|
-
// {
|
413
|
-
// NftId poolNftId = treasuryInfo.poolNftId;
|
414
|
-
// ISetup.PoolSetupInfo memory poolInfo = instance.getPoolInfo(poolNftId);
|
415
|
-
|
416
|
-
// if(poolInfo.isVerifying) {
|
417
|
-
// _underwriteByPool(
|
418
|
-
// treasuryInfo,
|
419
|
-
// policyNftId,
|
420
|
-
// policyInfo,
|
421
|
-
// bundleInfo.filter,
|
422
|
-
// collateralAmount
|
423
|
-
// );
|
424
|
-
// }
|
425
|
-
// }
|
426
|
-
|
427
|
-
// TODO add logging
|
428
|
-
}
|
429
|
-
|
430
|
-
function calculateRequiredCollateral(UFixed collateralizationLevel, uint256 sumInsuredAmount) public pure override returns(uint256 collateralAmount) {
|
431
|
-
UFixed sumInsuredUFixed = UFixedLib.toUFixed(sumInsuredAmount);
|
432
|
-
UFixed collateralUFixed = collateralizationLevel * sumInsuredUFixed;
|
433
|
-
return collateralUFixed.toInt();
|
434
|
-
}
|
435
|
-
|
436
|
-
function collectPremium(NftId policyNftId, Timestamp activateAt) external override {
|
437
|
-
// check caller is registered product
|
438
|
-
(IRegistry.ObjectInfo memory productInfo, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
439
|
-
|
440
|
-
// perform actual token transfers
|
441
|
-
// FIXME: this
|
442
|
-
// IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
443
|
-
// ITreasury.TreasuryInfo memory treasuryInfo = instance.getTreasuryInfo(productInfo.nftId);
|
444
|
-
|
445
|
-
// uint256 premiumAmount = policyInfo.premiumAmount;
|
446
|
-
// _processPremiumByTreasury(instance, productInfo.nftId, treasuryInfo, policyNftId, premiumAmount);
|
447
|
-
|
448
|
-
// // policy level book keeping for premium paid
|
449
|
-
// policyInfo.premiumPaidAmount += premiumAmount;
|
450
|
-
|
451
|
-
// // optional activation of policy
|
452
|
-
// if(activateAt > zeroTimestamp()) {
|
453
|
-
// require(
|
454
|
-
// policyInfo.activatedAt.eqz(),
|
455
|
-
// "ERROR:PRS-030:ALREADY_ACTIVATED");
|
456
|
-
|
457
|
-
// policyInfo.activatedAt = activateAt;
|
458
|
-
// policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
459
|
-
|
460
|
-
// instance.updatePolicyState(policyNftId, ACTIVE());
|
461
|
-
// }
|
462
|
-
|
463
|
-
// instance.setPolicyInfo(policyNftId, policyInfo);
|
464
|
-
|
465
|
-
// TODO add logging
|
466
|
-
}
|
467
|
-
|
468
|
-
// FIXME: this
|
469
|
-
function activate(NftId policyNftId, Timestamp activateAt) external override {
|
470
|
-
// check caller is registered product
|
471
|
-
(, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
472
|
-
|
473
|
-
// IPolicy.PolicyInfo memory policyInfo = instance.getPolicyInfo(policyNftId);
|
474
|
-
|
475
|
-
// require(
|
476
|
-
// policyInfo.activatedAt.eqz(),
|
477
|
-
// "ERROR:PRS-020:ALREADY_ACTIVATED");
|
478
|
-
|
479
|
-
// policyInfo.activatedAt = activateAt;
|
480
|
-
// policyInfo.expiredAt = activateAt.addSeconds(policyInfo.lifetime);
|
481
|
-
|
482
|
-
// instance.setPolicyInfo(policyNftId, policyInfo);
|
483
|
-
// instance.updatePolicyState(policyNftId, ACTIVE());
|
484
|
-
|
485
|
-
// TODO add logging
|
486
|
-
}
|
487
|
-
|
488
|
-
function close(
|
489
|
-
NftId policyNftId
|
490
|
-
) external override // solhint-disable-next-line no-empty-blocks
|
491
191
|
{
|
192
|
+
(,, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
193
|
+
InstanceReader instanceReader = instance.getInstanceReader();
|
492
194
|
|
195
|
+
IRisk.RiskInfo memory riskInfo = instanceReader.getRiskInfo(riskId);
|
196
|
+
riskInfo.data = data;
|
197
|
+
instance.getInstanceStore().updateRisk(riskId, riskInfo, KEEP_STATE());
|
493
198
|
}
|
494
199
|
|
495
|
-
function
|
496
|
-
|
497
|
-
|
498
|
-
)
|
499
|
-
|
500
|
-
view
|
501
|
-
returns (NftId poolNftid)
|
502
|
-
{
|
503
|
-
// FIXME: this
|
504
|
-
// return instance.getTreasuryInfo(productNftId).poolNftId;
|
505
|
-
}
|
506
|
-
|
507
|
-
|
508
|
-
function _processPremiumByTreasury(
|
509
|
-
IInstance instance,
|
510
|
-
NftId productNftId,
|
511
|
-
ITreasury.TreasuryInfo memory treasuryInfo,
|
512
|
-
NftId policyNftId,
|
513
|
-
uint256 premiumAmount
|
514
|
-
)
|
515
|
-
internal
|
516
|
-
returns (uint256 netPremiumAmount)
|
200
|
+
function updateRiskState(
|
201
|
+
RiskId riskId,
|
202
|
+
StateId state
|
203
|
+
)
|
204
|
+
external
|
517
205
|
{
|
518
|
-
|
519
|
-
|
520
|
-
// FIXME: this
|
521
|
-
// TokenHandler tokenHandler = instance.getTokenHandler(productNftId);
|
522
|
-
// address policyOwner = getRegistry().ownerOf(policyNftId);
|
523
|
-
// address poolWallet = instance.getComponentWallet(treasuryInfo.poolNftId);
|
524
|
-
// netPremiumAmount = premiumAmount;
|
525
|
-
// Fee memory productFee = treasuryInfo.productFee;
|
526
|
-
|
527
|
-
// if (FeeLib.feeIsZero(productFee)) {
|
528
|
-
// tokenHandler.transfer(
|
529
|
-
// policyOwner,
|
530
|
-
// poolWallet,
|
531
|
-
// premiumAmount
|
532
|
-
// );
|
533
|
-
// } else {
|
534
|
-
// (uint256 feeAmount, uint256 netAmount) = instance.calculateFeeAmount(
|
535
|
-
// premiumAmount,
|
536
|
-
// productFee
|
537
|
-
// );
|
538
|
-
|
539
|
-
// address productWallet = instance.getComponentWallet(productNftId);
|
540
|
-
// tokenHandler.transfer(policyOwner, productWallet, feeAmount);
|
541
|
-
// tokenHandler.transfer(policyOwner, poolWallet, netAmount);
|
542
|
-
// netPremiumAmount = netAmount;
|
543
|
-
// }
|
544
|
-
}
|
545
|
-
|
546
|
-
// TODO add logging
|
206
|
+
(,, IInstance instance) = _getAndVerifyComponentInfoAndInstance(PRODUCT());
|
207
|
+
instance.getInstanceStore().updateRiskState(riskId, state);
|
547
208
|
}
|
548
209
|
}
|
@@ -16,7 +16,7 @@ contract ProductServiceManager is ProxyManager {
|
|
16
16
|
constructor(
|
17
17
|
address registryAddress
|
18
18
|
)
|
19
|
-
ProxyManager()
|
19
|
+
ProxyManager(registryAddress)
|
20
20
|
{
|
21
21
|
ProductService svc = new ProductService();
|
22
22
|
bytes memory data = abi.encode(registryAddress, address(this));
|
@@ -39,7 +39,7 @@ contract ProductServiceManager is ProxyManager {
|
|
39
39
|
// address(_productService));
|
40
40
|
|
41
41
|
// implies that after this constructor call only upgrade functionality is available
|
42
|
-
_isDeployed = true;
|
42
|
+
// _isDeployed = true;
|
43
43
|
}
|
44
44
|
|
45
45
|
//--- view functions ----------------------------------------------------//
|
@@ -59,7 +59,7 @@ contract ChainNft is ERC721Enumerable {
|
|
59
59
|
}
|
60
60
|
|
61
61
|
_chainIdMultiplier = 10 ** _chainIdDigits;
|
62
|
-
_idNext =
|
62
|
+
_idNext = 3;
|
63
63
|
}
|
64
64
|
|
65
65
|
/**
|
@@ -95,6 +95,10 @@ contract ChainNft is ERC721Enumerable {
|
|
95
95
|
|
96
96
|
_totalMinted++;
|
97
97
|
_safeMint(to, tokenId);
|
98
|
+
|
99
|
+
if(interceptor != address(0)) {
|
100
|
+
ITransferInterceptor(interceptor).nftMint(to, tokenId);
|
101
|
+
}
|
98
102
|
}
|
99
103
|
|
100
104
|
|
@@ -195,6 +199,10 @@ contract ChainNft is ERC721Enumerable {
|
|
195
199
|
_chainIdDigits;
|
196
200
|
}
|
197
201
|
|
202
|
+
function getNextTokenId() external view returns (uint256) {
|
203
|
+
return calculateTokenId(_idNext);
|
204
|
+
}
|
205
|
+
|
198
206
|
function _getNextTokenId() private returns (uint256 id) {
|
199
207
|
id = calculateTokenId(_idNext);
|
200
208
|
_idNext++;
|