@etherisc/gif-next 0.0.2-ffa91a6-022 → 3.0.0-06d5e8b-738
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 +124 -332
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +106 -38
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +111 -45
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +58 -6
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +370 -141
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1582 -202
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +2 -2
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +266 -64
- package/artifacts/contracts/authorization/IAccess.sol/IAccess.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAccessAdmin.sol/IAccessAdmin.json +263 -87
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +102 -19
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +256 -16
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +426 -27
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +63 -38
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +269 -69
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +21 -12
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +376 -147
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +160 -78
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +20 -11
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +232 -19
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +108 -79
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +268 -68
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +136 -95
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +268 -68
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +728 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +229 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1234 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +896 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +1466 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +2497 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +891 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +586 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +901 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +86 -45
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +268 -68
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +35 -26
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +130 -105
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +268 -68
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +333 -147
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +268 -68
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
- package/artifacts/contracts/{shared/IKeyValueStore.sol/IKeyValueStore.json → instance/BaseStore.sol/BaseStore.json} +51 -229
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +2 -2
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +304 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +374 -35
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +305 -5
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +425 -97
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +753 -401
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +236 -80
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +747 -553
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +331 -31
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +100 -42
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +1323 -2012
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +3427 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +101 -88
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +8 -8
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +20 -20
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +25 -16
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +282 -65
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +19 -10
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +29 -0
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +19 -10
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +83 -38
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +116 -50
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +59 -58
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +268 -68
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +300 -123
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +144 -58
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +186 -33
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +29 -20
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +238 -19
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +29 -20
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +100 -34
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +338 -79
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +141 -63
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +216 -59
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +113 -43
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +46 -37
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +268 -68
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +142 -102
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +128 -70
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +166 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +50 -10
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +55 -0
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +29 -0
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +40 -31
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +203 -18
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +157 -86
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +511 -21
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +138 -72
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +93 -112
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +115 -65
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +40 -31
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +231 -46
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +101 -43
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +33 -22
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +29 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +71 -60
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +539 -314
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +335 -76
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +41 -12
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +96 -38
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +551 -246
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +169 -111
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +459 -26
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +119 -59
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +19 -10
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +196 -201
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +130 -64
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +76 -41
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +2 -2
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/{ComponentVerifyingService.sol/ComponentVerifyingService.json → IAuthorizedComponent.sol/IAuthorizedComponent.json} +238 -90
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +19 -10
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +111 -132
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +19 -10
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +19 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +19 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +29 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +19 -10
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +21 -2
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +2 -2
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +19 -0
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -2
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +29 -0
- 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/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +2 -2
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +2 -2
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1390 -134
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +97 -117
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1479 -192
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +77 -76
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +139 -64
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +296 -152
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +131 -167
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +96 -46
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1615 -815
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +153 -91
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +10 -10
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +64 -19
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +93 -37
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +22 -25
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +23 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +33 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +39 -218
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +64 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +69 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +37 -5
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +60 -36
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +10 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +81 -27
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +10 -0
- package/contracts/accounting/AccountingService.sol +15 -3
- package/contracts/accounting/IAccountingService.sol +4 -2
- package/contracts/authorization/AccessAdmin.sol +303 -326
- package/contracts/authorization/AccessAdminLib.sol +535 -23
- package/contracts/authorization/AccessManagerCloneable.sol +0 -18
- package/contracts/authorization/Authorization.sol +64 -239
- package/contracts/authorization/IAccess.sol +29 -12
- package/contracts/authorization/IAccessAdmin.sol +25 -53
- package/contracts/authorization/IAuthorization.sol +3 -57
- package/contracts/authorization/IServiceAuthorization.sol +55 -17
- package/contracts/authorization/ServiceAuthorization.sol +228 -34
- package/contracts/distribution/BasicDistribution.sol +3 -4
- package/contracts/distribution/BasicDistributionAuthorization.sol +11 -4
- package/contracts/distribution/Distribution.sol +9 -8
- package/contracts/distribution/DistributionService.sol +125 -62
- package/contracts/distribution/IDistributionComponent.sol +3 -1
- package/contracts/distribution/IDistributionService.sol +20 -8
- package/contracts/examples/fire/FireProduct.sol +6 -6
- package/contracts/examples/flight/FlightLib.sol +300 -0
- package/contracts/examples/flight/FlightMessageVerifier.sol +128 -0
- package/contracts/examples/flight/FlightOracle.sol +171 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +53 -0
- package/contracts/examples/flight/FlightPool.sol +89 -0
- package/contracts/examples/flight/FlightPoolAuthorization.sol +37 -0
- package/contracts/examples/flight/FlightProduct.sol +685 -0
- package/contracts/examples/flight/FlightProductAuthorization.sol +69 -0
- package/contracts/examples/flight/FlightUSD.sol +28 -0
- package/contracts/examples/flight/originalV1.sol +396 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +83 -19
- package/contracts/instance/BaseStore.sol +93 -0
- package/contracts/instance/IBaseStore.sol +37 -0
- package/contracts/instance/IInstance.sol +57 -6
- package/contracts/instance/IInstanceService.sol +42 -7
- package/contracts/instance/Instance.sol +111 -56
- package/contracts/instance/InstanceAdmin.sol +150 -294
- package/contracts/instance/InstanceAuthorizationV3.sol +106 -66
- package/contracts/instance/InstanceReader.sol +376 -392
- package/contracts/instance/InstanceService.sol +186 -134
- package/contracts/instance/InstanceStore.sol +153 -128
- package/contracts/instance/ProductStore.sol +290 -0
- package/contracts/instance/RiskSet.sol +10 -2
- package/contracts/instance/TargetNames.sol +10 -0
- package/contracts/instance/base/BalanceStore.sol +4 -6
- package/contracts/instance/base/ObjectLifecycle.sol +2 -6
- package/contracts/instance/module/IBundle.sol +6 -5
- package/contracts/instance/module/IComponents.sol +15 -5
- package/contracts/instance/module/IDistribution.sol +17 -7
- package/contracts/instance/module/IPolicy.sol +28 -8
- package/contracts/instance/module/IRisk.sol +2 -0
- package/contracts/oracle/BasicOracle.sol +2 -3
- package/contracts/oracle/BasicOracleAuthorization.sol +18 -2
- package/contracts/oracle/IOracle.sol +9 -4
- package/contracts/oracle/IOracleService.sol +12 -12
- package/contracts/oracle/Oracle.sol +4 -6
- package/contracts/oracle/OracleService.sol +8 -8
- package/contracts/pool/BasicPool.sol +4 -16
- package/contracts/pool/BasicPoolAuthorization.sol +10 -5
- package/contracts/pool/BundleService.sol +34 -43
- package/contracts/pool/IBundleService.sol +14 -13
- package/contracts/pool/IPoolService.sol +7 -2
- package/contracts/pool/Pool.sol +6 -18
- package/contracts/pool/PoolLib.sol +127 -2
- package/contracts/pool/PoolService.sol +40 -181
- package/contracts/product/ApplicationService.sol +64 -11
- package/contracts/product/BasicProduct.sol +2 -3
- package/contracts/product/BasicProductAuthorization.sol +13 -5
- package/contracts/product/ClaimService.sol +99 -105
- package/contracts/product/IApplicationService.sol +21 -2
- package/contracts/product/IClaimService.sol +5 -4
- package/contracts/product/IPolicyService.sol +9 -2
- package/contracts/product/IRiskService.sol +18 -3
- package/contracts/product/PolicyService.sol +40 -59
- package/contracts/product/PolicyServiceLib.sol +79 -5
- package/contracts/product/PricingService.sol +28 -31
- package/contracts/product/Product.sol +40 -16
- package/contracts/product/RiskService.sol +50 -15
- package/contracts/registry/IRegistry.sol +15 -9
- package/contracts/registry/IRelease.sol +6 -3
- package/contracts/registry/Registry.sol +15 -9
- package/contracts/registry/RegistryAdmin.sol +39 -118
- package/contracts/registry/RegistryAuthorization.sol +139 -69
- package/contracts/registry/RegistryService.sol +1 -1
- package/contracts/registry/ReleaseAdmin.sol +59 -106
- package/contracts/registry/ReleaseRegistry.sol +20 -12
- package/contracts/registry/ServiceAuthorizationV3.sol +43 -32
- package/contracts/registry/TokenRegistry.sol +56 -52
- package/contracts/shared/Component.sol +8 -8
- package/contracts/shared/ComponentService.sol +245 -262
- package/contracts/shared/ContractLib.sol +106 -75
- package/contracts/shared/EcdsaChecker.sol +5 -0
- package/contracts/shared/IAuthorizedComponent.sol +15 -0
- package/contracts/shared/IComponent.sol +1 -1
- package/contracts/shared/IComponentService.sol +14 -15
- package/contracts/shared/IInstanceLinkedComponent.sol +2 -5
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +0 -1
- package/contracts/shared/InstanceLinkedComponent.sol +64 -26
- package/contracts/shared/NftOwnable.sol +3 -1
- package/contracts/shared/PolicyHolder.sol +3 -2
- package/contracts/shared/Service.sol +6 -4
- package/contracts/staking/IStaking.sol +261 -70
- package/contracts/staking/IStakingService.sol +39 -84
- package/contracts/staking/ITargetLimitHandler.sol +17 -0
- package/contracts/staking/Staking.sol +468 -217
- package/contracts/staking/StakingLib.sol +38 -124
- package/contracts/staking/StakingManager.sol +4 -3
- package/contracts/staking/StakingReader.sol +62 -71
- package/contracts/staking/StakingService.sol +42 -185
- package/contracts/staking/StakingServiceManager.sol +1 -0
- package/contracts/staking/StakingStore.sol +1093 -331
- package/contracts/staking/TargetHandler.sol +132 -0
- package/contracts/staking/TargetManagerLib.sol +69 -46
- package/contracts/type/Amount.sol +4 -0
- package/contracts/type/Blocknumber.sol +17 -22
- package/contracts/type/ChainId.sol +101 -0
- package/contracts/type/Fee.sol +8 -8
- package/contracts/type/NftId.sol +3 -3
- package/contracts/type/ObjectType.sol +17 -33
- package/contracts/type/Referral.sol +6 -0
- package/contracts/type/RequestIdSet.sol +62 -0
- package/contracts/type/RoleId.sol +57 -59
- package/contracts/type/Seconds.sol +23 -0
- package/contracts/type/String.sol +42 -0
- package/contracts/type/Timestamp.sol +14 -3
- package/contracts/type/UFixed.sol +28 -10
- package/contracts/upgradeability/IVersionable.sol +3 -0
- package/contracts/upgradeability/ProxyManager.sol +26 -12
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +12 -2
- package/contracts/upgradeability/Versionable.sol +6 -3
- package/package.json +2 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.dbg.json +0 -4
- package/artifacts/contracts/authorization/AccessAdmin.sol/IAccessManagedChecker.json +0 -24
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +0 -4
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +0 -538
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +0 -4
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +0 -205
- package/contracts/shared/ComponentVerifyingService.sol +0 -128
- package/contracts/shared/IKeyValueStore.sol +0 -54
- package/contracts/shared/KeyValueStore.sol +0 -131
- package/contracts/staking/StakingLifecycle.sol +0 -23
@@ -15,6 +15,8 @@ import {InstanceReader} from "../instance/InstanceReader.sol";
|
|
15
15
|
import {InstanceStore} from "../instance/InstanceStore.sol";
|
16
16
|
import {NftId} from "../type/NftId.sol";
|
17
17
|
import {ObjectType, BUNDLE, POOL} from "../type/ObjectType.sol";
|
18
|
+
import {PayoutId} from "../type/PayoutId.sol";
|
19
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
18
20
|
import {UFixed} from "../type/UFixed.sol";
|
19
21
|
|
20
22
|
library PoolLib {
|
@@ -105,7 +107,7 @@ library PoolLib {
|
|
105
107
|
Amount payoutAmount,
|
106
108
|
address payoutBeneficiary
|
107
109
|
)
|
108
|
-
|
110
|
+
public
|
109
111
|
view
|
110
112
|
returns (
|
111
113
|
Amount netPayoutAmount,
|
@@ -127,7 +129,7 @@ library PoolLib {
|
|
127
129
|
// calculate processing fees if applicable
|
128
130
|
IComponents.FeeInfo memory feeInfo = instanceReader.getFeeInfo(productNftId);
|
129
131
|
if(FeeLib.gtz(feeInfo.processingFee)) {
|
130
|
-
|
132
|
+
(processingFeeAmount, netPayoutAmount) = FeeLib.calculateFee(feeInfo.processingFee, payoutAmount);
|
131
133
|
}
|
132
134
|
}
|
133
135
|
}
|
@@ -204,6 +206,32 @@ library PoolLib {
|
|
204
206
|
instance = IInstance(instanceAddress);
|
205
207
|
}
|
206
208
|
|
209
|
+
|
210
|
+
function getAndVerifyActiveComponent(
|
211
|
+
IRegistry registry,
|
212
|
+
address sender,
|
213
|
+
ObjectType expectedComponentType
|
214
|
+
)
|
215
|
+
public
|
216
|
+
view
|
217
|
+
returns (
|
218
|
+
NftId componentNftId,
|
219
|
+
IInstance instance
|
220
|
+
)
|
221
|
+
{
|
222
|
+
(
|
223
|
+
IRegistry.ObjectInfo memory info,
|
224
|
+
address instanceAddress
|
225
|
+
) = ContractLib.getAndVerifyComponent(
|
226
|
+
registry,
|
227
|
+
sender,
|
228
|
+
expectedComponentType,
|
229
|
+
true); // only active components
|
230
|
+
|
231
|
+
componentNftId = info.nftId;
|
232
|
+
instance = IInstance(instanceAddress);
|
233
|
+
}
|
234
|
+
|
207
235
|
function checkNftType(
|
208
236
|
IRegistry registry,
|
209
237
|
NftId nftId,
|
@@ -213,4 +241,101 @@ library PoolLib {
|
|
213
241
|
revert INftOwnable.ErrorNftOwnableInvalidType(nftId, expectedObjectType);
|
214
242
|
}
|
215
243
|
}
|
244
|
+
|
245
|
+
function transferTokenAndNotifyPolicyHolder(
|
246
|
+
IRegistry registry,
|
247
|
+
InstanceReader instanceReader,
|
248
|
+
TokenHandler poolTokenHandler,
|
249
|
+
NftId productNftId,
|
250
|
+
NftId policyNftId,
|
251
|
+
PayoutId payoutId,
|
252
|
+
Amount payoutAmount,
|
253
|
+
address payoutBeneficiary
|
254
|
+
)
|
255
|
+
external
|
256
|
+
returns (
|
257
|
+
Amount netPayoutAmount,
|
258
|
+
Amount processingFeeAmount
|
259
|
+
)
|
260
|
+
{
|
261
|
+
address beneficiary;
|
262
|
+
|
263
|
+
(
|
264
|
+
netPayoutAmount,
|
265
|
+
processingFeeAmount,
|
266
|
+
beneficiary
|
267
|
+
) = calculatePayoutAmounts(
|
268
|
+
registry,
|
269
|
+
instanceReader,
|
270
|
+
productNftId,
|
271
|
+
policyNftId,
|
272
|
+
payoutAmount,
|
273
|
+
payoutBeneficiary);
|
274
|
+
|
275
|
+
// 1st token tx to payout to beneficiary
|
276
|
+
poolTokenHandler.pushToken(
|
277
|
+
beneficiary,
|
278
|
+
netPayoutAmount);
|
279
|
+
|
280
|
+
// 2nd token tx to transfer processing fees to product wallet
|
281
|
+
// if processingFeeAmount > 0
|
282
|
+
if (processingFeeAmount.gtz()) {
|
283
|
+
poolTokenHandler.pushToken(
|
284
|
+
instanceReader.getWallet(productNftId),
|
285
|
+
processingFeeAmount);
|
286
|
+
}
|
287
|
+
|
288
|
+
// callback to policy holder if applicable
|
289
|
+
policyHolderPayoutExecuted(
|
290
|
+
registry,
|
291
|
+
policyNftId,
|
292
|
+
payoutId,
|
293
|
+
beneficiary,
|
294
|
+
netPayoutAmount);
|
295
|
+
}
|
296
|
+
|
297
|
+
function policyHolderPayoutExecuted(
|
298
|
+
IRegistry registry,
|
299
|
+
NftId policyNftId,
|
300
|
+
PayoutId payoutId,
|
301
|
+
address beneficiary,
|
302
|
+
Amount payoutAmount
|
303
|
+
)
|
304
|
+
private
|
305
|
+
{
|
306
|
+
IPolicyHolder policyHolder = getPolicyHolder(registry, policyNftId);
|
307
|
+
if(address(policyHolder) != address(0)) {
|
308
|
+
policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
|
309
|
+
}
|
310
|
+
}
|
311
|
+
|
312
|
+
/// @dev Transfers the specified amount from the "from account" to the pool's wallet
|
313
|
+
function pullStakingAmount(
|
314
|
+
InstanceReader reader,
|
315
|
+
NftId poolNftId,
|
316
|
+
address from,
|
317
|
+
Amount amount
|
318
|
+
)
|
319
|
+
external
|
320
|
+
{
|
321
|
+
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
322
|
+
info.tokenHandler.pullToken(
|
323
|
+
from,
|
324
|
+
amount);
|
325
|
+
}
|
326
|
+
|
327
|
+
/// @dev Transfers the specified amount from the pool's wallet to the "to account"
|
328
|
+
function pushUnstakingAmount(
|
329
|
+
InstanceReader reader,
|
330
|
+
NftId poolNftId,
|
331
|
+
address to,
|
332
|
+
Amount amount
|
333
|
+
)
|
334
|
+
external
|
335
|
+
{
|
336
|
+
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
337
|
+
info.tokenHandler.pushToken(
|
338
|
+
to,
|
339
|
+
amount);
|
340
|
+
}
|
216
341
|
}
|
@@ -2,13 +2,11 @@
|
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
4
|
import {IAccountingService} from "../accounting/IAccountingService.sol";
|
5
|
-
import {IBundle} from "../instance/module/IBundle.sol";
|
6
5
|
import {IBundleService} from "./IBundleService.sol";
|
7
6
|
import {IComponents} from "../instance/module/IComponents.sol";
|
8
7
|
import {IComponentService} from "../shared/IComponentService.sol";
|
9
8
|
import {IInstance} from "../instance/IInstance.sol";
|
10
9
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
11
|
-
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
12
10
|
import {IPoolComponent} from "../pool/IPoolComponent.sol";
|
13
11
|
import {IPoolService} from "./IPoolService.sol";
|
14
12
|
import {IProductComponent} from "../product/IProductComponent.sol";
|
@@ -27,9 +25,6 @@ import {PayoutId} from "../type/PayoutId.sol";
|
|
27
25
|
import {PoolLib} from "./PoolLib.sol";
|
28
26
|
import {Service} from "../shared/Service.sol";
|
29
27
|
import {TokenHandler} from "../shared/TokenHandler.sol";
|
30
|
-
import {UFixed} from "../type/UFixed.sol";
|
31
|
-
|
32
|
-
string constant POOL_SERVICE_NAME = "PoolService";
|
33
28
|
|
34
29
|
|
35
30
|
contract PoolService is
|
@@ -69,6 +64,7 @@ contract PoolService is
|
|
69
64
|
function setMaxBalanceAmount(Amount maxBalanceAmount)
|
70
65
|
external
|
71
66
|
virtual
|
67
|
+
restricted()
|
72
68
|
{
|
73
69
|
(NftId poolNftId, IInstance instance) = _getAndVerifyActivePool();
|
74
70
|
InstanceReader instanceReader = instance.getInstanceReader();
|
@@ -84,6 +80,7 @@ contract PoolService is
|
|
84
80
|
|
85
81
|
function closeBundle(NftId bundleNftId)
|
86
82
|
external
|
83
|
+
restricted()
|
87
84
|
virtual
|
88
85
|
{
|
89
86
|
_checkNftType(bundleNftId, BUNDLE());
|
@@ -119,6 +116,7 @@ contract PoolService is
|
|
119
116
|
Amount availableAmount
|
120
117
|
)
|
121
118
|
external
|
119
|
+
restricted()
|
122
120
|
virtual
|
123
121
|
{
|
124
122
|
_checkNftType(policyNftId, POLICY());
|
@@ -175,7 +173,7 @@ contract PoolService is
|
|
175
173
|
function stake(NftId bundleNftId, Amount amount)
|
176
174
|
external
|
177
175
|
virtual
|
178
|
-
|
176
|
+
restricted()
|
179
177
|
returns(
|
180
178
|
Amount netAmount
|
181
179
|
)
|
@@ -222,7 +220,7 @@ contract PoolService is
|
|
222
220
|
|
223
221
|
// collect tokens from bundle owner
|
224
222
|
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
225
|
-
|
223
|
+
PoolLib.pullStakingAmount(
|
226
224
|
instanceReader,
|
227
225
|
poolNftId,
|
228
226
|
bundleOwner,
|
@@ -235,7 +233,7 @@ contract PoolService is
|
|
235
233
|
function unstake(NftId bundleNftId, Amount amount)
|
236
234
|
external
|
237
235
|
virtual
|
238
|
-
|
236
|
+
restricted()
|
239
237
|
returns(Amount netAmount)
|
240
238
|
{
|
241
239
|
(
|
@@ -269,7 +267,7 @@ contract PoolService is
|
|
269
267
|
|
270
268
|
// transfer amount to bundle owner
|
271
269
|
address bundleOwner = getRegistry().ownerOf(bundleNftId);
|
272
|
-
|
270
|
+
PoolLib.pushUnstakingAmount(
|
273
271
|
instanceReader,
|
274
272
|
poolNftId,
|
275
273
|
bundleOwner,
|
@@ -281,7 +279,7 @@ contract PoolService is
|
|
281
279
|
function fundPoolWallet(Amount amount)
|
282
280
|
external
|
283
281
|
virtual
|
284
|
-
|
282
|
+
restricted()
|
285
283
|
{
|
286
284
|
(
|
287
285
|
NftId poolNftId,
|
@@ -297,7 +295,7 @@ contract PoolService is
|
|
297
295
|
address poolOwner = getRegistry().ownerOf(poolNftId);
|
298
296
|
emit LogPoolServiceWalletFunded(poolNftId, poolOwner, amount);
|
299
297
|
|
300
|
-
|
298
|
+
PoolLib.pullStakingAmount(
|
301
299
|
reader,
|
302
300
|
poolNftId,
|
303
301
|
poolOwner,
|
@@ -308,7 +306,7 @@ contract PoolService is
|
|
308
306
|
function defundPoolWallet(Amount amount)
|
309
307
|
external
|
310
308
|
virtual
|
311
|
-
|
309
|
+
restricted()
|
312
310
|
{
|
313
311
|
(
|
314
312
|
NftId poolNftId,
|
@@ -324,7 +322,7 @@ contract PoolService is
|
|
324
322
|
address poolOwner = getRegistry().ownerOf(poolNftId);
|
325
323
|
emit LogPoolServiceWalletDefunded(poolNftId, poolOwner, amount);
|
326
324
|
|
327
|
-
|
325
|
+
PoolLib.pushUnstakingAmount(
|
328
326
|
reader,
|
329
327
|
poolNftId,
|
330
328
|
poolOwner,
|
@@ -363,6 +361,8 @@ contract PoolService is
|
|
363
361
|
bundleNftId,
|
364
362
|
bundleNetAmount,
|
365
363
|
bundleFeeAmount);
|
364
|
+
|
365
|
+
emit LogPoolServiceSaleProcessed(poolNftId, bundleNftId, bundleNetAmount, bundleFeeAmount, poolFeeAmount);
|
366
366
|
}
|
367
367
|
|
368
368
|
|
@@ -421,10 +421,15 @@ contract PoolService is
|
|
421
421
|
bundleNftId,
|
422
422
|
totalCollateralAmount);
|
423
423
|
|
424
|
-
|
424
|
+
emit LogPoolServiceApplicationVerified(poolNftId, bundleNftId, applicationNftId, totalCollateralAmount);
|
425
425
|
}
|
426
426
|
|
427
|
-
|
427
|
+
emit LogPoolServiceCollateralLocked(
|
428
|
+
poolNftId,
|
429
|
+
bundleNftId,
|
430
|
+
applicationNftId,
|
431
|
+
totalCollateralAmount,
|
432
|
+
localCollateralAmount);
|
428
433
|
}
|
429
434
|
|
430
435
|
function processPayout(
|
@@ -440,6 +445,10 @@ contract PoolService is
|
|
440
445
|
external
|
441
446
|
virtual
|
442
447
|
restricted()
|
448
|
+
returns (
|
449
|
+
Amount netPayoutAmount,
|
450
|
+
Amount processingFeeAmount
|
451
|
+
)
|
443
452
|
{
|
444
453
|
// checks
|
445
454
|
_checkNftType(policyNftId, POLICY());
|
@@ -474,7 +483,8 @@ contract PoolService is
|
|
474
483
|
payoutAmount);
|
475
484
|
|
476
485
|
// interactions
|
477
|
-
|
486
|
+
(netPayoutAmount, processingFeeAmount) = PoolLib.transferTokenAndNotifyPolicyHolder(
|
487
|
+
getRegistry(),
|
478
488
|
instanceReader,
|
479
489
|
poolTokenHandler,
|
480
490
|
productNftId,
|
@@ -482,50 +492,22 @@ contract PoolService is
|
|
482
492
|
payoutId,
|
483
493
|
payoutAmount,
|
484
494
|
payoutBeneficiary);
|
485
|
-
|
486
|
-
|
487
|
-
function _transferTokenAndNotifyPolicyHolder(
|
488
|
-
InstanceReader instanceReader,
|
489
|
-
TokenHandler poolTokenHandler,
|
490
|
-
NftId productNftId,
|
491
|
-
NftId policyNftId,
|
492
|
-
PayoutId payoutId,
|
493
|
-
Amount payoutAmount,
|
494
|
-
address payoutBeneficiary
|
495
|
-
)
|
496
|
-
internal
|
497
|
-
{
|
498
|
-
(
|
499
|
-
Amount netPayoutAmount,
|
500
|
-
Amount processingFeeAmount,
|
501
|
-
address beneficiary
|
502
|
-
) = PoolLib.calculatePayoutAmounts(
|
503
|
-
getRegistry(),
|
504
|
-
instanceReader,
|
505
|
-
productNftId,
|
506
|
-
policyNftId,
|
507
|
-
payoutAmount,
|
508
|
-
payoutBeneficiary);
|
509
|
-
|
510
|
-
// 1st token tx to payout to beneficiary
|
511
|
-
poolTokenHandler.pushToken(
|
512
|
-
beneficiary,
|
513
|
-
netPayoutAmount);
|
514
|
-
|
515
|
-
// 2nd token tx to transfer processing fees to product wallet
|
516
|
-
// if processingFeeAmount > 0
|
495
|
+
|
517
496
|
if (processingFeeAmount.gtz()) {
|
518
|
-
|
519
|
-
|
497
|
+
_accountingService.increaseProductFeesForPool(
|
498
|
+
instanceStore,
|
499
|
+
productNftId,
|
520
500
|
processingFeeAmount);
|
521
501
|
}
|
522
502
|
|
523
|
-
|
524
|
-
|
503
|
+
emit LogPoolServicePayoutProcessed(
|
504
|
+
poolNftId,
|
505
|
+
bundleNftId,
|
525
506
|
policyNftId,
|
526
507
|
payoutId,
|
527
|
-
|
528
|
-
|
508
|
+
netPayoutAmount,
|
509
|
+
processingFeeAmount,
|
510
|
+
payoutBeneficiary);
|
529
511
|
}
|
530
512
|
|
531
513
|
|
@@ -605,112 +587,11 @@ contract PoolService is
|
|
605
587
|
instanceReader.getInstanceNftId(),
|
606
588
|
address(instanceReader.getToken(policyInfo.productNftId)),
|
607
589
|
remainingCollateralAmount);
|
608
|
-
}
|
609
|
-
|
610
|
-
|
611
|
-
// function calculateRequiredCollateral(
|
612
|
-
// InstanceReader instanceReader,
|
613
|
-
// NftId productNftId,
|
614
|
-
// Amount sumInsuredAmount
|
615
|
-
// )
|
616
|
-
// public
|
617
|
-
// view
|
618
|
-
// returns(
|
619
|
-
// NftId poolNftId,
|
620
|
-
// Amount totalCollateralAmount,
|
621
|
-
// Amount localCollateralAmount,
|
622
|
-
// bool poolIsVerifyingApplications
|
623
|
-
// )
|
624
|
-
// {
|
625
|
-
// return CollateralLib.calculateRequiredCollateral(
|
626
|
-
// instanceReader,
|
627
|
-
// productNftId,
|
628
|
-
// sumInsuredAmount);
|
629
|
-
// }
|
630
590
|
|
631
|
-
|
632
|
-
|
633
|
-
|
634
|
-
|
635
|
-
// poolIsVerifyingApplications = poolInfo.isVerifyingApplications;
|
636
|
-
|
637
|
-
// (
|
638
|
-
// totalCollateralAmount,
|
639
|
-
// localCollateralAmount
|
640
|
-
// ) = calculateRequiredCollateral(
|
641
|
-
// poolInfo.collateralizationLevel,
|
642
|
-
// poolInfo.retentionLevel,
|
643
|
-
// sumInsuredAmount);
|
644
|
-
// }
|
645
|
-
|
646
|
-
|
647
|
-
// function calculateRequiredCollateral(
|
648
|
-
// UFixed collateralizationLevel,
|
649
|
-
// UFixed retentionLevel,
|
650
|
-
// Amount sumInsuredAmount
|
651
|
-
// )
|
652
|
-
// public
|
653
|
-
// pure
|
654
|
-
// returns(
|
655
|
-
// Amount totalCollateralAmount,
|
656
|
-
// Amount localCollateralAmount
|
657
|
-
// )
|
658
|
-
// {
|
659
|
-
// // collateralization is applied to sum insured
|
660
|
-
// UFixed totalUFixed = collateralizationLevel * sumInsuredAmount.toUFixed();
|
661
|
-
// totalCollateralAmount = AmountLib.toAmount(totalUFixed.toInt());
|
662
|
-
|
663
|
-
// // retention level defines how much capital is required locally
|
664
|
-
// localCollateralAmount = AmountLib.toAmount(
|
665
|
-
// (retentionLevel * totalUFixed).toInt());
|
666
|
-
// }
|
667
|
-
|
668
|
-
|
669
|
-
|
670
|
-
|
671
|
-
function _policyHolderPayoutExecuted(
|
672
|
-
NftId policyNftId,
|
673
|
-
PayoutId payoutId,
|
674
|
-
address beneficiary,
|
675
|
-
Amount payoutAmount
|
676
|
-
)
|
677
|
-
internal
|
678
|
-
{
|
679
|
-
IPolicyHolder policyHolder = PoolLib.getPolicyHolder(getRegistry(), policyNftId);
|
680
|
-
if(address(policyHolder) != address(0)) {
|
681
|
-
policyHolder.payoutExecuted(policyNftId, payoutId, payoutAmount, beneficiary);
|
682
|
-
}
|
683
|
-
}
|
684
|
-
|
685
|
-
|
686
|
-
/// @dev Transfers the specified amount from the "from account" to the pool's wallet
|
687
|
-
function _pullStakingAmount(
|
688
|
-
InstanceReader reader,
|
689
|
-
NftId poolNftId,
|
690
|
-
address from,
|
691
|
-
Amount amount
|
692
|
-
)
|
693
|
-
internal
|
694
|
-
{
|
695
|
-
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
696
|
-
info.tokenHandler.pullToken(
|
697
|
-
from,
|
698
|
-
amount);
|
699
|
-
}
|
700
|
-
|
701
|
-
/// @dev Transfers the specified amount from the pool's wallet to the "to account"
|
702
|
-
function _pushUnstakingAmount(
|
703
|
-
InstanceReader reader,
|
704
|
-
NftId poolNftId,
|
705
|
-
address to,
|
706
|
-
Amount amount
|
707
|
-
)
|
708
|
-
internal
|
709
|
-
{
|
710
|
-
IComponents.ComponentInfo memory info = reader.getComponentInfo(poolNftId);
|
711
|
-
info.tokenHandler.pushToken(
|
712
|
-
to,
|
713
|
-
amount);
|
591
|
+
emit LogPoolServiceCollateralReleased(
|
592
|
+
policyInfo.bundleNftId,
|
593
|
+
policyNftId,
|
594
|
+
remainingCollateralAmount);
|
714
595
|
}
|
715
596
|
|
716
597
|
|
@@ -726,28 +607,6 @@ contract PoolService is
|
|
726
607
|
return PoolLib.getAndVerifyActivePool(getRegistry(), msg.sender);
|
727
608
|
}
|
728
609
|
|
729
|
-
// function _getAndVerifyActivePool()
|
730
|
-
// internal
|
731
|
-
// virtual
|
732
|
-
// view
|
733
|
-
// returns (
|
734
|
-
// NftId poolNftId,
|
735
|
-
// IInstance instance
|
736
|
-
// )
|
737
|
-
// {
|
738
|
-
// (
|
739
|
-
// IRegistry.ObjectInfo memory info,
|
740
|
-
// address instanceAddress
|
741
|
-
// ) = ContractLib.getAndVerifyComponent(
|
742
|
-
// getRegistry(),
|
743
|
-
// msg.sender,
|
744
|
-
// POOL(),
|
745
|
-
// true); // only active pools
|
746
|
-
|
747
|
-
// poolNftId = info.nftId;
|
748
|
-
// instance = IInstance(instanceAddress);
|
749
|
-
// }
|
750
|
-
|
751
610
|
|
752
611
|
function _getDomain() internal pure override returns(ObjectType) {
|
753
612
|
return POOL();
|
@@ -11,6 +11,7 @@ import {IPricingService} from "./IPricingService.sol";
|
|
11
11
|
import {IRegistryService} from "../registry/IRegistryService.sol";
|
12
12
|
|
13
13
|
import {AmountLib} from "../type/Amount.sol";
|
14
|
+
import {ContractLib} from "../shared/ContractLib.sol";
|
14
15
|
import {Seconds} from "../type/Seconds.sol";
|
15
16
|
import {zeroTimestamp} from "../type/Timestamp.sol";
|
16
17
|
import {ObjectType, BUNDLE, DISTRIBUTION, PRODUCT, REGISTRY, APPLICATION, POLICY, PRICE} from "../type/ObjectType.sol";
|
@@ -19,13 +20,12 @@ import {NftId, NftIdLib} from "../type/NftId.sol";
|
|
19
20
|
import {ReferralId} from "../type/Referral.sol";
|
20
21
|
import {RiskId} from "../type/RiskId.sol";
|
21
22
|
import {Amount, AmountLib} from "../type/Amount.sol";
|
22
|
-
import {
|
23
|
+
import {Service} from "../shared/Service.sol";
|
23
24
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
24
25
|
|
25
26
|
|
26
|
-
|
27
27
|
contract ApplicationService is
|
28
|
-
|
28
|
+
Service,
|
29
29
|
IApplicationService
|
30
30
|
{
|
31
31
|
IDistributionService private _distributionService;
|
@@ -69,7 +69,7 @@ contract ApplicationService is
|
|
69
69
|
// check risk with product
|
70
70
|
(bool exists, bool active) = instanceReader.getRiskSet().checkRisk(productNftId, riskId);
|
71
71
|
if (!exists) { revert ErrorApplicationServiceRiskUnknown(riskId, productNftId); }
|
72
|
-
if (!active) { revert
|
72
|
+
if (!active) { revert ErrorApplicationServiceRiskLocked(riskId, productNftId); }
|
73
73
|
|
74
74
|
NftId riskProductNftId = instanceReader.getRiskInfo(riskId).productNftId;
|
75
75
|
if (productNftId != riskProductNftId) {
|
@@ -149,12 +149,13 @@ contract ApplicationService is
|
|
149
149
|
)
|
150
150
|
external
|
151
151
|
virtual
|
152
|
+
restricted()
|
152
153
|
nonReentrant()
|
153
154
|
returns (NftId applicationNftId)
|
154
155
|
{
|
155
156
|
_checkNftType(bundleNftId, BUNDLE());
|
156
157
|
|
157
|
-
(NftId productNftId
|
158
|
+
(NftId productNftId, IInstance instance) = _getAndVerifyActiveProduct();
|
158
159
|
|
159
160
|
// check if provided references are valid and linked to calling product contract
|
160
161
|
InstanceReader instanceReader = instance.getInstanceReader();
|
@@ -180,11 +181,32 @@ contract ApplicationService is
|
|
180
181
|
applicationData);
|
181
182
|
|
182
183
|
// register application with instance
|
183
|
-
instance.
|
184
|
+
instance.getProductStore().createApplication(
|
184
185
|
applicationNftId,
|
185
186
|
applicationInfo);
|
186
187
|
|
187
|
-
|
188
|
+
_emitApplicationCreatedEvent(applicationNftId, applicationOwner, applicationInfo);
|
189
|
+
}
|
190
|
+
|
191
|
+
function _emitApplicationCreatedEvent(
|
192
|
+
NftId applicationNftId,
|
193
|
+
address applicationOwner,
|
194
|
+
IPolicy.PolicyInfo memory applicationInfo
|
195
|
+
)
|
196
|
+
internal
|
197
|
+
virtual
|
198
|
+
{
|
199
|
+
emit LogApplicationServiceApplicationCreated(
|
200
|
+
applicationNftId,
|
201
|
+
applicationInfo.productNftId,
|
202
|
+
applicationInfo.bundleNftId,
|
203
|
+
applicationInfo.riskId,
|
204
|
+
applicationInfo.referralId,
|
205
|
+
applicationOwner,
|
206
|
+
applicationInfo.sumInsuredAmount,
|
207
|
+
applicationInfo.premiumAmount,
|
208
|
+
applicationInfo.lifetime
|
209
|
+
);
|
188
210
|
}
|
189
211
|
|
190
212
|
function _createApplicationInfo(
|
@@ -227,12 +249,16 @@ contract ApplicationService is
|
|
227
249
|
)
|
228
250
|
external
|
229
251
|
virtual
|
252
|
+
restricted()
|
230
253
|
nonReentrant()
|
231
254
|
returns (NftId applicationNftId)
|
232
255
|
{
|
233
256
|
_checkNftType(policyNftId, POLICY());
|
234
257
|
_checkNftType(bundleNftId, BUNDLE());
|
235
|
-
|
258
|
+
|
259
|
+
// TODO: implement
|
260
|
+
|
261
|
+
emit LogApplicationServiceApplicationRenewed(policyNftId, bundleNftId);
|
236
262
|
}
|
237
263
|
|
238
264
|
|
@@ -247,26 +273,53 @@ contract ApplicationService is
|
|
247
273
|
)
|
248
274
|
external
|
249
275
|
virtual
|
276
|
+
restricted()
|
250
277
|
nonReentrant()
|
251
278
|
{
|
252
279
|
_checkNftType(applicationNftId, POLICY());
|
253
280
|
_checkNftType(bundleNftId, BUNDLE());
|
254
|
-
|
281
|
+
|
282
|
+
// TODO: implement
|
283
|
+
|
284
|
+
emit LogApplicationServiceApplicationAdjusted(applicationNftId, bundleNftId, riskId, referralId, sumInsuredAmount, lifetime);
|
255
285
|
}
|
256
286
|
|
257
287
|
function revoke(NftId applicationNftId)
|
258
288
|
external
|
259
289
|
virtual
|
290
|
+
restricted()
|
260
291
|
nonReentrant()
|
261
292
|
{
|
262
293
|
_checkNftType(applicationNftId, POLICY());
|
263
294
|
|
264
|
-
(
|
265
|
-
instance.
|
295
|
+
(, IInstance instance) = _getAndVerifyActiveProduct();
|
296
|
+
instance.getProductStore().updateApplicationState(applicationNftId, REVOKED());
|
297
|
+
emit LogApplicationServiceApplicationRevoked(applicationNftId);
|
266
298
|
}
|
267
299
|
|
268
300
|
// internal functions
|
269
301
|
|
302
|
+
function _getAndVerifyActiveProduct()
|
303
|
+
internal
|
304
|
+
view
|
305
|
+
returns (
|
306
|
+
NftId productNftId,
|
307
|
+
IInstance instance
|
308
|
+
)
|
309
|
+
{
|
310
|
+
(
|
311
|
+
IRegistry.ObjectInfo memory info,
|
312
|
+
address instanceAddress
|
313
|
+
) = ContractLib.getAndVerifyComponent(
|
314
|
+
getRegistry(),
|
315
|
+
msg.sender,
|
316
|
+
PRODUCT(),
|
317
|
+
true); // only active pools
|
318
|
+
|
319
|
+
productNftId = info.nftId;
|
320
|
+
instance = IInstance(instanceAddress);
|
321
|
+
}
|
322
|
+
|
270
323
|
|
271
324
|
function _getDomain() internal pure override returns(ObjectType) {
|
272
325
|
return APPLICATION();
|
@@ -36,14 +36,13 @@ abstract contract BasicProduct is
|
|
36
36
|
virtual
|
37
37
|
onlyInitializing()
|
38
38
|
{
|
39
|
-
|
39
|
+
__Product_init(
|
40
40
|
registry,
|
41
41
|
instanceNftId,
|
42
42
|
name,
|
43
43
|
productInfo,
|
44
44
|
feeInfo,
|
45
45
|
authorization,
|
46
|
-
initialOwner
|
47
|
-
""); // component data
|
46
|
+
initialOwner);
|
48
47
|
}
|
49
48
|
}
|