@etherisc/gif-next 0.0.2-b1fff40-773 → 0.0.2-b2070b1-995
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 +109 -9
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1075 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +790 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +843 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +673 -262
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1289 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +202 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +456 -24
- 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 +549 -209
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +215 -18
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +265 -16
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +473 -17
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +183 -487
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +431 -36
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +102 -387
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +644 -392
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +209 -133
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +96 -191
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +476 -137
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1484 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +805 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2053 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +805 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1208 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +805 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +1476 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +805 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +2609 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +805 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +376 -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 +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1439 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +805 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1171 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1647 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +805 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2585 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +805 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.json +332 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- 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 +578 -65
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +395 -60
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +616 -183
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1021 -363
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +328 -92
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1799 -789
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +409 -231
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +143 -105
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +960 -1163
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +1539 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +866 -0
- 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 +46 -5
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- 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/mock/Dip.sol/Dip.json +2 -2
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +127 -355
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +424 -37
- 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 +103 -133
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +98 -11
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +103 -323
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +198 -190
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +177 -97
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +160 -438
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +430 -35
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +502 -364
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +194 -114
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +340 -112
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +139 -236
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +711 -340
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +129 -416
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +925 -545
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +230 -106
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +353 -180
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +159 -99
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +272 -431
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +430 -35
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +466 -245
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +187 -123
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +301 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +350 -18
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +417 -101
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +183 -80
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +257 -226
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/{shared/ComponentVerifyingService.sol/ComponentVerifyingService.json → product/IRiskService.sol/IRiskService.json} +283 -157
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +532 -311
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +196 -108
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +247 -332
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +165 -137
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +264 -423
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +873 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +774 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +359 -48
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +169 -37
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +565 -109
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +791 -377
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1074 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +136 -290
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +141 -89
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2152 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +483 -253
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +489 -20
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +120 -60
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +86 -277
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +493 -638
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +183 -133
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +632 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +92 -93
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +432 -290
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +103 -133
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +79 -6
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +35 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +167 -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 +84 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +4 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +53 -0
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +102 -322
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +85 -7
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -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 +41 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +141 -97
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +86 -111
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +585 -12
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1510 -191
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +235 -123
- 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 +1635 -455
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +470 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +191 -105
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +295 -183
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +282 -281
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +144 -96
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1645 -790
- 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 +180 -77
- 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 +35 -11
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +45 -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 +28 -4
- 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 +94 -38
- 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 +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +49 -50
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- 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/RequestIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/RequestIdSet.sol/RequestIdSet.json +33 -0
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +42 -157
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +112 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- 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 +56 -5
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +73 -36
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +101 -2
- 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 +118 -79
- 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 +274 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +47 -0
- package/contracts/authorization/AccessAdmin.sol +458 -269
- package/contracts/authorization/AccessAdminLib.sol +396 -0
- package/contracts/authorization/AccessManagerCloneable.sol +146 -4
- package/contracts/authorization/Authorization.sol +159 -208
- package/contracts/authorization/IAccess.sol +25 -6
- package/contracts/authorization/IAccessAdmin.sol +87 -79
- package/contracts/authorization/IAuthorization.sol +9 -37
- package/contracts/authorization/IServiceAuthorization.sol +57 -17
- package/contracts/authorization/ServiceAuthorization.sol +255 -25
- package/contracts/distribution/BasicDistribution.sol +22 -30
- package/contracts/distribution/BasicDistributionAuthorization.sol +30 -10
- package/contracts/distribution/Distribution.sol +44 -98
- package/contracts/distribution/DistributionService.sol +243 -132
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +4 -11
- package/contracts/distribution/IDistributionService.sol +47 -29
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +433 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/flight/FlightOracle.sol +167 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +34 -0
- package/contracts/examples/flight/FlightPool.sol +89 -0
- package/contracts/examples/flight/FlightPoolAuthorization.sol +37 -0
- package/contracts/examples/flight/FlightProduct.sol +728 -0
- package/contracts/examples/flight/FlightProductAuthorization.sol +44 -0
- package/contracts/examples/flight/FlightUSD.sol +26 -0
- package/contracts/examples/flight/originalV1.sol +396 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +437 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BaseStore.sol +93 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IBaseStore.sol +37 -0
- package/contracts/instance/IInstance.sol +113 -43
- package/contracts/instance/IInstanceService.sol +61 -34
- package/contracts/instance/Instance.sol +201 -104
- package/contracts/instance/InstanceAdmin.sol +275 -162
- package/contracts/instance/InstanceAuthorizationV3.sol +142 -71
- package/contracts/instance/InstanceReader.sol +502 -251
- package/contracts/instance/InstanceService.sol +333 -262
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +27 -36
- package/contracts/instance/ProductStore.sol +119 -0
- package/contracts/instance/RiskSet.sol +126 -0
- package/contracts/instance/TargetNames.sol +10 -0
- package/contracts/instance/base/BalanceStore.sol +4 -6
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +13 -10
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +6 -5
- package/contracts/instance/module/IComponents.sol +30 -19
- package/contracts/instance/module/IDistribution.sol +21 -8
- package/contracts/instance/module/IPolicy.sol +50 -29
- package/contracts/instance/module/IRisk.sol +5 -0
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/BasicOracle.sol +2 -5
- package/contracts/oracle/BasicOracleAuthorization.sol +14 -8
- package/contracts/oracle/IOracle.sol +9 -4
- package/contracts/oracle/IOracleService.sol +14 -13
- package/contracts/oracle/Oracle.sol +11 -27
- package/contracts/oracle/OracleService.sol +119 -87
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +39 -41
- package/contracts/pool/BasicPoolAuthorization.sol +39 -13
- package/contracts/pool/BundleService.sol +200 -155
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +42 -46
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +97 -77
- package/contracts/pool/Pool.sol +143 -138
- package/contracts/pool/PoolLib.sol +341 -0
- package/contracts/pool/PoolService.sol +413 -233
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +144 -47
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +13 -46
- package/contracts/product/BasicProductAuthorization.sol +33 -12
- package/contracts/product/ClaimService.sol +394 -185
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +29 -3
- package/contracts/product/IClaimService.sol +48 -11
- package/contracts/product/IPolicyService.sol +61 -37
- package/contracts/product/IPricingService.sol +11 -10
- package/contracts/product/IProductComponent.sol +27 -5
- package/contracts/product/IRiskService.sol +48 -0
- package/contracts/product/PolicyService.sol +445 -276
- package/contracts/product/PolicyServiceLib.sol +139 -0
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +90 -84
- package/contracts/product/PricingServiceManager.sol +4 -4
- package/contracts/product/Product.sol +201 -100
- package/contracts/product/RiskService.sol +190 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -40
- package/contracts/registry/IRegistry.sol +70 -32
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/IRelease.sol +29 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +367 -207
- package/contracts/registry/RegistryAdmin.sol +114 -288
- package/contracts/registry/RegistryAuthorization.sol +336 -0
- package/contracts/registry/RegistryService.sol +38 -49
- package/contracts/registry/RegistryServiceManager.sol +3 -3
- package/contracts/registry/ReleaseAdmin.sol +195 -0
- package/contracts/registry/ReleaseLifecycle.sol +8 -3
- package/contracts/registry/ReleaseRegistry.sol +279 -241
- package/contracts/registry/ServiceAuthorizationV3.sol +205 -63
- package/contracts/registry/TokenRegistry.sol +61 -59
- package/contracts/shared/Component.sol +70 -136
- package/contracts/shared/ComponentService.sol +423 -387
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ContractLib.sol +312 -0
- package/contracts/shared/IComponent.sol +6 -18
- package/contracts/shared/IComponentService.sol +43 -40
- package/contracts/shared/IInstanceLinkedComponent.sol +6 -32
- package/contracts/shared/IKeyValueStore.sol +9 -1
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +4 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IRegisterable.sol +22 -1
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +11 -3
- package/contracts/shared/InstanceLinkedComponent.sol +116 -54
- package/contracts/shared/KeyValueStore.sol +4 -4
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +33 -11
- package/contracts/shared/PolicyHolder.sol +20 -59
- package/contracts/shared/Registerable.sol +52 -21
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +20 -35
- package/contracts/shared/TokenHandler.sol +310 -26
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +271 -71
- package/contracts/staking/IStakingService.sol +45 -78
- package/contracts/staking/ITargetLimitHandler.sol +17 -0
- package/contracts/staking/Staking.sol +525 -243
- package/contracts/staking/StakingLib.sol +195 -0
- package/contracts/staking/StakingManager.sol +12 -9
- package/contracts/staking/StakingReader.sol +70 -82
- package/contracts/staking/StakingService.sol +62 -152
- package/contracts/staking/StakingServiceManager.sol +7 -5
- package/contracts/staking/StakingStore.sol +1093 -330
- package/contracts/staking/TargetHandler.sol +132 -0
- package/contracts/staking/TargetManagerLib.sol +73 -46
- package/contracts/type/Amount.sol +19 -0
- package/contracts/type/Blocknumber.sol +22 -16
- package/contracts/type/ChainId.sol +101 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Fee.sol +8 -8
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +7 -0
- package/contracts/type/ObjectType.sol +74 -67
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/Referral.sol +6 -0
- package/contracts/type/RequestIdSet.sol +62 -0
- package/contracts/type/RiskId.sol +38 -6
- package/contracts/type/RoleId.sol +61 -55
- package/contracts/type/Seconds.sol +44 -1
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/String.sol +42 -0
- package/contracts/type/Timestamp.sol +24 -8
- package/contracts/type/UFixed.sol +38 -126
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/IVersionable.sol +3 -0
- package/contracts/upgradeability/ProxyManager.sol +93 -45
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +12 -2
- package/contracts/upgradeability/Versionable.sol +8 -5
- package/package.json +5 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +0 -400
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -708
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
- package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +0 -4
- package/artifacts/contracts/shared/ERC165.sol/ERC165.json +0 -73
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -470
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +0 -4
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +0 -164
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/product/IProductService.sol +0 -33
- package/contracts/product/ProductService.sol +0 -99
- package/contracts/product/ProductServiceManager.sol +0 -39
- package/contracts/shared/ComponentVerifyingService.sol +0 -117
- package/contracts/shared/InitializableCustom.sol +0 -177
- package/contracts/staking/StakeManagerLib.sol +0 -231
- package/contracts/staking/StakingLifecycle.sol +0 -23
@@ -3,36 +3,43 @@ pragma solidity ^0.8.20;
|
|
3
3
|
|
4
4
|
import {IERC20Metadata} from "@openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol";
|
5
5
|
|
6
|
-
import {
|
7
|
-
import {ClaimId} from "../type/ClaimId.sol";
|
8
|
-
import {DistributorType} from "../type/DistributorType.sol";
|
9
|
-
import {Fee, FeeLib} from "../type/Fee.sol";
|
10
|
-
import {Key32} from "../type/Key32.sol";
|
11
|
-
import {NftId} from "../type/NftId.sol";
|
12
|
-
import {ObjectType, COMPONENT, DISTRIBUTOR, DISTRIBUTION, INSTANCE, PRODUCT, POLICY, POOL, BUNDLE} from "../type/ObjectType.sol";
|
13
|
-
import {PayoutId} from "../type/PayoutId.sol";
|
14
|
-
import {ReferralId, ReferralStatus, ReferralLib, REFERRAL_OK, REFERRAL_ERROR_UNKNOWN, REFERRAL_ERROR_EXPIRED, REFERRAL_ERROR_EXHAUSTED} from "../type/Referral.sol";
|
15
|
-
import {RequestId} from "../type/RequestId.sol";
|
16
|
-
import {RiskId} from "../type/RiskId.sol";
|
17
|
-
import {RoleId} from "../type/RoleId.sol";
|
18
|
-
import {StateId} from "../type/StateId.sol";
|
19
|
-
import {UFixed, MathLib, UFixedLib} from "../type/UFixed.sol";
|
20
|
-
import {Version} from "../type/Version.sol";
|
21
|
-
|
22
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
6
|
+
import {IAccess} from "../authorization/IAccess.sol";
|
23
7
|
import {IBundle} from "../instance/module/IBundle.sol";
|
24
8
|
import {IComponents} from "../instance/module/IComponents.sol";
|
25
9
|
import {IDistribution} from "../instance/module/IDistribution.sol";
|
10
|
+
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
26
11
|
import {IInstance} from "./IInstance.sol";
|
27
12
|
import {IKeyValueStore} from "../shared/IKeyValueStore.sol";
|
28
13
|
import {IOracle} from "../oracle/IOracle.sol";
|
29
14
|
import {IPolicy} from "../instance/module/IPolicy.sol";
|
15
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
30
16
|
import {IRisk} from "../instance/module/IRisk.sol";
|
31
|
-
import {TimestampLib} from "../type/Timestamp.sol";
|
32
17
|
|
18
|
+
import {AccessAdminLib} from "../authorization/AccessAdminLib.sol";
|
19
|
+
import {Amount} from "../type/Amount.sol";
|
20
|
+
import {BundleSet} from "./BundleSet.sol";
|
21
|
+
import {BUNDLE, COMPONENT, DISTRIBUTOR, DISTRIBUTION, FEE, PREMIUM, POLICY, POOL, PRODUCT} from "../type/ObjectType.sol";
|
22
|
+
import {ClaimId, ClaimIdLib} from "../type/ClaimId.sol";
|
23
|
+
import {DistributorType} from "../type/DistributorType.sol";
|
24
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
33
25
|
import {InstanceStore} from "./InstanceStore.sol";
|
26
|
+
import {Key32} from "../type/Key32.sol";
|
27
|
+
import {NftId} from "../type/NftId.sol";
|
28
|
+
import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
|
29
|
+
import {PolicyServiceLib} from "../product/PolicyServiceLib.sol";
|
30
|
+
import {ProductStore} from "./ProductStore.sol";
|
31
|
+
import {ReferralId, ReferralStatus, ReferralLib} from "../type/Referral.sol";
|
32
|
+
import {RequestId} from "../type/RequestId.sol";
|
33
|
+
import {RiskId} from "../type/RiskId.sol";
|
34
|
+
import {RiskSet} from "./RiskSet.sol";
|
35
|
+
import {RoleId, INSTANCE_OWNER_ROLE} from "../type/RoleId.sol";
|
36
|
+
import {StateId} from "../type/StateId.sol";
|
37
|
+
import {TokenHandler} from "../shared/TokenHandler.sol";
|
38
|
+
import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
34
39
|
|
35
40
|
|
41
|
+
/// @dev Central reader contract for a specific instance.
|
42
|
+
/// Provides reading functions for all instance data and related component data.
|
36
43
|
contract InstanceReader {
|
37
44
|
|
38
45
|
error ErrorInstanceReaderAlreadyInitialized();
|
@@ -40,8 +47,15 @@ contract InstanceReader {
|
|
40
47
|
|
41
48
|
bool private _initialized = false;
|
42
49
|
|
50
|
+
IRegistry internal _registry;
|
43
51
|
IInstance internal _instance;
|
52
|
+
InstanceAdmin internal _instanceAdmin;
|
53
|
+
|
44
54
|
InstanceStore internal _store;
|
55
|
+
ProductStore internal _productStore;
|
56
|
+
BundleSet internal _bundleSet;
|
57
|
+
RiskSet internal _riskSet;
|
58
|
+
IDistributionService internal _distributionService;
|
45
59
|
|
46
60
|
/// @dev This initializer needs to be called from the instance itself.
|
47
61
|
function initialize() public {
|
@@ -52,258 +66,390 @@ contract InstanceReader {
|
|
52
66
|
initializeWithInstance(msg.sender);
|
53
67
|
}
|
54
68
|
|
55
|
-
|
56
|
-
|
69
|
+
|
70
|
+
/// @dev Initializer to upgrade instance reader via instance service
|
71
|
+
function initializeWithInstance(address instanceAddress)
|
72
|
+
public
|
73
|
+
{
|
57
74
|
if(_initialized) {
|
58
75
|
revert ErrorInstanceReaderAlreadyInitialized();
|
59
76
|
}
|
60
77
|
|
61
78
|
_initialized = true;
|
62
79
|
_instance = IInstance(instanceAddress);
|
80
|
+
_instanceAdmin = _instance.getInstanceAdmin();
|
81
|
+
_registry = _instance.getRegistry();
|
82
|
+
|
63
83
|
_store = _instance.getInstanceStore();
|
84
|
+
_productStore = _instance.getProductStore();
|
85
|
+
_bundleSet = _instance.getBundleSet();
|
86
|
+
_riskSet = _instance.getRiskSet();
|
87
|
+
_distributionService = IDistributionService(_registry.getServiceAddress(DISTRIBUTION(), _instance.getRelease()));
|
64
88
|
}
|
65
89
|
|
66
90
|
|
67
|
-
|
91
|
+
//--- instance functions ---------------------------------------------------------//
|
68
92
|
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
returns (IPolicy.PolicyInfo memory info)
|
73
|
-
{
|
74
|
-
bytes memory data = _store.getData(toPolicyKey(policyNftId));
|
75
|
-
if (data.length > 0) {
|
76
|
-
return abi.decode(data, (IPolicy.PolicyInfo));
|
77
|
-
}
|
93
|
+
/// @dev Returns the registry this instance is registered in.
|
94
|
+
function getRegistry() public view returns (IRegistry registry) {
|
95
|
+
return _registry;
|
78
96
|
}
|
79
97
|
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
{
|
85
|
-
return _store.getState(toPolicyKey(policyNftId));
|
98
|
+
|
99
|
+
/// @dev Returns the instance NFT ID.
|
100
|
+
function getInstanceNftId() public view returns (NftId instanceNftid) {
|
101
|
+
return _registry.getNftIdForAddress(address(_instance));
|
86
102
|
}
|
87
103
|
|
88
|
-
/// @dev returns true iff policy may be closed
|
89
|
-
/// a policy can be closed all conditions below are met
|
90
|
-
/// - policy exists
|
91
|
-
/// - has been activated
|
92
|
-
/// - is not yet closed
|
93
|
-
/// - has no open claims
|
94
|
-
/// - claim amount matches sum insured amount or is expired
|
95
|
-
function policyIsCloseable(NftId policyNftId)
|
96
|
-
public
|
97
|
-
view
|
98
|
-
returns (bool isCloseable)
|
99
|
-
{
|
100
|
-
IPolicy.PolicyInfo memory info = getPolicyInfo(policyNftId);
|
101
104
|
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
105
|
+
/// @dev Returns the instance contract.
|
106
|
+
function getInstance() public view returns (IInstance instance) {
|
107
|
+
return _instance;
|
108
|
+
}
|
106
109
|
|
107
|
-
// closeable: if sum of claims matches sum insured a policy may be closed prior to the expiry date
|
108
|
-
if (info.claimAmount == info.sumInsuredAmount) { return true; }
|
109
110
|
|
110
|
-
|
111
|
-
if (TimestampLib.blockTimestamp() < info.expiredAt) { return false; }
|
111
|
+
//--- component functions ------------------------------------------------------//
|
112
112
|
|
113
|
-
|
114
|
-
|
113
|
+
/// @dev Returns the number of registered components.
|
114
|
+
/// Components may be products, distributions, oracles or pools.
|
115
|
+
function components() public view returns (uint256 componentCount) {
|
116
|
+
return _instanceAdmin.components();
|
115
117
|
}
|
116
118
|
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
119
|
+
|
120
|
+
/// @dev Returns the component info for the given component NFT ID.
|
121
|
+
function getComponentInfo(NftId componentNftId) public view returns (IComponents.ComponentInfo memory info) {
|
122
|
+
(bytes memory data, bool success) = _getData(_toComponentKey(componentNftId));
|
123
|
+
if (success) { return abi.decode(data, (IComponents.ComponentInfo)); }
|
124
|
+
}
|
125
|
+
|
126
|
+
|
127
|
+
/// @dev Returns the registered token for the given component NFT ID.
|
128
|
+
function getToken(NftId componentNftId) public view returns (IERC20Metadata token) {
|
129
|
+
TokenHandler tokenHandler = getTokenHandler(componentNftId);
|
130
|
+
if (address(tokenHandler) != address(0)) { return tokenHandler.TOKEN(); }
|
131
|
+
}
|
132
|
+
|
133
|
+
|
134
|
+
/// @dev Returns the current wallet address for the given component NFT ID.
|
135
|
+
/// The wallet address is either the component's own address or any other wallet address specified by the component owner.
|
136
|
+
/// The wallet holds the component's funds. Tokens collected by the component are transferred to the wallet and
|
137
|
+
/// Tokens distributed from the component are transferred from this wallet.
|
138
|
+
function getWallet(NftId componentNftId) public view returns (address wallet) {
|
139
|
+
TokenHandler tokenHandler = getTokenHandler(componentNftId);
|
140
|
+
if (address(tokenHandler) != address(0)) { return tokenHandler.getWallet(); }
|
141
|
+
}
|
142
|
+
|
143
|
+
|
144
|
+
/// @dev Returns the token handler for the given component NFT ID.
|
145
|
+
/// The token handler manages all transfers from/to the component's wallet.
|
146
|
+
/// To allow a component to collect funds from an account, it has to create a corresponding allowance from the
|
147
|
+
/// account to the address of the component's token handler.
|
148
|
+
function getTokenHandler(NftId componentNftId) public view returns (TokenHandler tokenHandler) {
|
149
|
+
(bytes memory data, bool success) = _getData(_toComponentKey(componentNftId));
|
150
|
+
if (success) { return abi.decode(data, (IComponents.ComponentInfo)).tokenHandler; }
|
151
|
+
}
|
152
|
+
|
153
|
+
|
154
|
+
/// @dev Returns the current token balance amount for the given component NFT ID.
|
155
|
+
/// The balance amount includes the fee amount.
|
156
|
+
function getBalanceAmount(NftId targetNftId) external view returns (Amount) {
|
157
|
+
return _store.getBalanceAmount(targetNftId);
|
158
|
+
}
|
159
|
+
|
160
|
+
|
161
|
+
/// @dev Returns the current fee amount for the given NFT ID.
|
162
|
+
/// The target NFT ID may reference a component, a distributor or a bundle.
|
163
|
+
function getFeeAmount(NftId targetNftId) external view returns (Amount) {
|
164
|
+
return _store.getFeeAmount(targetNftId);
|
165
|
+
}
|
166
|
+
|
167
|
+
|
168
|
+
/// @dev Returns the currently locked amount for the given NFT ID.
|
169
|
+
/// The target NFT ID may reference a pool or a bundle.
|
170
|
+
function getLockedAmount(NftId targetNftId) external view returns (Amount) {
|
171
|
+
return _store.getLockedAmount(targetNftId);
|
172
|
+
}
|
173
|
+
|
174
|
+
//--- product functions ------------------------------------------------------//
|
175
|
+
|
176
|
+
/// @dev Returns the number of registered products.
|
177
|
+
function products() public view returns (uint256 productCount) {
|
178
|
+
return _instance.products();
|
179
|
+
}
|
180
|
+
|
181
|
+
|
182
|
+
/// @dev Returns th product NFT ID for the given index.
|
183
|
+
function getProduct(uint256 idx) public view returns (NftId productNftId) {
|
184
|
+
return _instance.getProduct(idx);
|
185
|
+
}
|
186
|
+
|
187
|
+
|
188
|
+
/// @dev Returns the product info for the given product NFT ID.
|
189
|
+
function getProductInfo(NftId productNftId) public view returns (IComponents.ProductInfo memory info) {
|
190
|
+
(bytes memory data, bool success) = _getData(productNftId.toKey32(PRODUCT()));
|
191
|
+
if (success) { return abi.decode(data, (IComponents.ProductInfo)); }
|
192
|
+
}
|
193
|
+
|
194
|
+
|
195
|
+
/// @dev Returns the current fee settings for the given product NFT ID.
|
196
|
+
function getFeeInfo(NftId productNftId) public view returns (IComponents.FeeInfo memory feeInfo) {
|
197
|
+
(bytes memory data, bool success) = _getData(productNftId.toKey32(FEE()));
|
198
|
+
if (success) { return abi.decode(data, (IComponents.FeeInfo)); }
|
199
|
+
}
|
200
|
+
|
201
|
+
//--- risk functions ---------------------------------------------------------//
|
202
|
+
|
203
|
+
/// @dev Returns the total number of registered risks for the specified product.
|
204
|
+
function risks(NftId productNftId) public view returns (uint256 riskCount) {
|
205
|
+
return _riskSet.risks(productNftId);
|
206
|
+
}
|
207
|
+
|
208
|
+
|
209
|
+
/// @dev Returns the number of active risks for the specified product.
|
210
|
+
function activeRisks(NftId productNftId) public view returns (uint256 activeRiskCount) {
|
211
|
+
return _riskSet.activeRisks(productNftId);
|
212
|
+
}
|
213
|
+
|
214
|
+
|
215
|
+
/// @dev Returns the risk ID for the given product NFT ID and (registered) risk index.
|
216
|
+
function getRiskId(NftId productNftId, uint256 idx) public view returns (RiskId riskId) {
|
217
|
+
return _riskSet.getRiskId(productNftId, idx);
|
218
|
+
}
|
219
|
+
|
220
|
+
|
221
|
+
/// @dev Returns the active risk ID for the given product NFT ID and (active) risk index.
|
222
|
+
function getActiveRiskId(NftId productNftId, uint256 idx) public view returns (RiskId riskId) {
|
223
|
+
return _riskSet.getActiveRiskId(productNftId, idx);
|
224
|
+
}
|
225
|
+
|
226
|
+
|
227
|
+
/// @dev Returns true if the specified risk exists for the given product NFT ID.
|
228
|
+
function isProductRisk(NftId productNftId, RiskId riskId) public view returns (bool exists) {
|
229
|
+
return _riskSet.hasRisk(productNftId, riskId);
|
230
|
+
}
|
231
|
+
|
232
|
+
|
233
|
+
/// @dev Returns the risk info for the given risk ID.
|
234
|
+
function getRiskInfo(RiskId riskId) public view returns (IRisk.RiskInfo memory info) {
|
235
|
+
(bytes memory data, bool success) = _getData(riskId.toKey32());
|
236
|
+
if (success) { return abi.decode(data, (IRisk.RiskInfo)); }
|
237
|
+
}
|
238
|
+
|
239
|
+
|
240
|
+
/// @dev Returns the risk state for the given risk ID.
|
241
|
+
function getRiskState(RiskId riskId) public view returns (StateId stateId) {
|
242
|
+
return getState(riskId.toKey32());
|
243
|
+
}
|
244
|
+
|
245
|
+
|
246
|
+
//--- policy functions -------------------------------------------------------//
|
247
|
+
|
248
|
+
/// @dev Returns the number of linked policies for the given risk ID.
|
249
|
+
function policiesForRisk(RiskId riskId) public view returns (uint256 linkedPolicies) {
|
250
|
+
return _riskSet.linkedPolicies(riskId);
|
251
|
+
}
|
252
|
+
|
253
|
+
|
254
|
+
/// @dev Returns the linked policy NFT ID for the given risk ID and index.
|
255
|
+
function getPolicyForRisk(RiskId riskId, uint256 idx) public view returns (NftId linkedPolicyNftId) {
|
256
|
+
return _riskSet.getLinkedPolicyNftId(riskId, idx);
|
257
|
+
}
|
258
|
+
|
259
|
+
/// @dev Returns the number of linked policies for the given bundle NFT ID.
|
260
|
+
function policiesForBundle(NftId bundleNftId) public view returns (uint256 linkedPolicies) {
|
261
|
+
return _bundleSet.activePolicies(bundleNftId);
|
262
|
+
}
|
263
|
+
|
264
|
+
|
265
|
+
/// @dev Returns the linked policy NFT ID for the given risk ID and index.
|
266
|
+
function getPolicyForBundle(NftId bundleNftId, uint256 idx) public view returns (NftId linkedPolicyNftId) {
|
267
|
+
return _bundleSet.getActivePolicy(bundleNftId, idx);
|
268
|
+
}
|
269
|
+
|
270
|
+
|
271
|
+
/// @dev Returns the info for the given policy NFT ID.
|
272
|
+
function getPolicyInfo(NftId policyNftId) public view returns (IPolicy.PolicyInfo memory info) {
|
273
|
+
return _productStore.getPolicy(policyNftId);
|
274
|
+
}
|
275
|
+
|
276
|
+
|
277
|
+
/// @dev Returns the state for the given policy NFT ID.
|
278
|
+
function getPolicyState(NftId policyNftId) public view returns (StateId state) {
|
279
|
+
return _productStore.getState(_toPolicyKey(policyNftId));
|
280
|
+
}
|
281
|
+
|
282
|
+
|
283
|
+
/// @dev Returns true iff policy is active.
|
284
|
+
function policyIsActive(NftId policyNftId) public view returns (bool isCloseable) {
|
285
|
+
return PolicyServiceLib.policyIsActive(this, policyNftId);
|
286
|
+
}
|
287
|
+
|
288
|
+
//--- claim functions -------------------------------------------------------//
|
289
|
+
|
290
|
+
/// @dev Returns the number of claims for the given policy NFT ID.
|
291
|
+
function claims(NftId policyNftId) public view returns (uint16 claimCount) {
|
292
|
+
return getPolicyInfo(policyNftId).claimsCount;
|
293
|
+
}
|
294
|
+
|
295
|
+
|
296
|
+
/// @dev Returns the claim ID for the given policy NFT ID and index.
|
297
|
+
function getClaimId(uint256 idx) public pure returns (ClaimId claimId) {
|
298
|
+
return ClaimIdLib.toClaimId(idx + 1);
|
299
|
+
}
|
300
|
+
|
301
|
+
|
302
|
+
/// @dev Returns the claim info for the given policy NFT ID and claim ID.
|
303
|
+
function getClaimInfo(NftId policyNftId, ClaimId claimId) public view returns (IPolicy.ClaimInfo memory info) {
|
304
|
+
(bytes memory data, bool success) = _getData(claimId.toKey32(policyNftId));
|
305
|
+
if (success) {
|
124
306
|
return abi.decode(data, (IPolicy.ClaimInfo));
|
125
307
|
}
|
126
308
|
}
|
127
309
|
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
{
|
133
|
-
return _store.getState(claimId.toKey32(policyNftId));
|
310
|
+
|
311
|
+
/// @dev Returns the current claim state for the given policy NFT ID and claim ID.
|
312
|
+
function getClaimState(NftId policyNftId, ClaimId claimId) public view returns (StateId state) {
|
313
|
+
return getState(claimId.toKey32(policyNftId));
|
134
314
|
}
|
135
315
|
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
return abi.decode(data, (IPolicy.PayoutInfo));
|
144
|
-
}
|
316
|
+
|
317
|
+
/// @dev Returns the remaining claimable amount for the given policy NFT ID.
|
318
|
+
/// The remaining claimable amount is the difference between the sum insured amount and total approved claim amounts so far.
|
319
|
+
function getRemainingClaimableAmount(NftId policyNftId)
|
320
|
+
public view returns (Amount remainingClaimableAmount) {
|
321
|
+
IPolicy.PolicyInfo memory info = getPolicyInfo(policyNftId);
|
322
|
+
return info.sumInsuredAmount - info.claimAmount;
|
145
323
|
}
|
146
324
|
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
return _store.getState(payoutId.toKey32(policyNftId));
|
325
|
+
//--- payout functions -------------------------------------------------------//
|
326
|
+
|
327
|
+
/// @dev Returns the number of payouts for the given policy NFT ID and claim ID.
|
328
|
+
function payouts(NftId policyNftId, ClaimId claimId) public view returns (uint24 payoutCount) {
|
329
|
+
return getClaimInfo(policyNftId, claimId).payoutsCount;
|
153
330
|
}
|
154
331
|
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
|
159
|
-
{
|
160
|
-
bytes memory data = _store.getData(riskId.toKey32());
|
161
|
-
if (data.length > 0) {
|
162
|
-
return abi.decode(data, (IRisk.RiskInfo));
|
163
|
-
}
|
332
|
+
|
333
|
+
/// @dev Returns the payout ID for the given claim ID and index.
|
334
|
+
function getPayoutId(ClaimId claimId, uint24 idx) public pure returns (PayoutId payoutId) {
|
335
|
+
return PayoutIdLib.toPayoutId(claimId, idx + 1);
|
164
336
|
}
|
165
337
|
|
166
|
-
function getTokenHandler(NftId componentNftId)
|
167
|
-
public
|
168
|
-
view
|
169
|
-
returns (address tokenHandler)
|
170
|
-
{
|
171
|
-
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
172
338
|
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
}
|
339
|
+
/// @dev Returns the payout info for the given policy NFT ID and payout ID.
|
340
|
+
function getPayoutInfo(NftId policyNftId, PayoutId payoutId) public view returns (IPolicy.PayoutInfo memory info) {
|
341
|
+
(bytes memory data, bool success) = _getData(payoutId.toKey32(policyNftId));
|
342
|
+
if (success) { return abi.decode(data, (IPolicy.PayoutInfo)); }
|
177
343
|
}
|
178
344
|
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
{
|
184
|
-
bytes memory data = _store.getData(toBundleKey(bundleNftId));
|
185
|
-
if (data.length > 0) {
|
186
|
-
return abi.decode(data, (IBundle.BundleInfo));
|
187
|
-
}
|
345
|
+
|
346
|
+
/// @dev Returns the payout state for the given policy NFT ID and payout ID.
|
347
|
+
function getPayoutState(NftId policyNftId, PayoutId payoutId) public view returns (StateId state) {
|
348
|
+
return getState(payoutId.toKey32(policyNftId));
|
188
349
|
}
|
189
350
|
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
if (data.length > 0) {
|
197
|
-
return abi.decode(data, (IDistribution.DistributorTypeInfo));
|
198
|
-
}
|
351
|
+
//--- premium functions -------------------------------------------------------//
|
352
|
+
|
353
|
+
/// @dev Returns the premium info for the given policy NFT ID.
|
354
|
+
function getPremiumInfo(NftId policyNftId) public view returns (IPolicy.PremiumInfo memory info) {
|
355
|
+
(bytes memory data, bool success) = _getData(_toPremiumKey(policyNftId));
|
356
|
+
if (success) { return abi.decode(data, (IPolicy.PremiumInfo)); }
|
199
357
|
}
|
200
358
|
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
{
|
206
|
-
bytes memory data = _store.getData(toDistributorKey(distributorNftId));
|
207
|
-
if (data.length > 0) {
|
208
|
-
return abi.decode(data, (IDistribution.DistributorInfo));
|
209
|
-
}
|
359
|
+
|
360
|
+
/// @dev Returns the premium state for the given policy NFT ID.
|
361
|
+
function getPremiumState(NftId policyNftId) public view returns (StateId state) {
|
362
|
+
return getState(_toPremiumKey(policyNftId));
|
210
363
|
}
|
211
364
|
|
212
|
-
|
213
|
-
|
365
|
+
//--- oracle functions ---------------------------------------------------------//
|
366
|
+
|
367
|
+
/// @dev Returns the request info for the given oracle request ID.
|
368
|
+
function getRequestInfo(RequestId requestId) public view returns (IOracle.RequestInfo memory requestInfo) {
|
369
|
+
(bytes memory data, bool success) = _getData(requestId.toKey32());
|
370
|
+
if (success) { return abi.decode(data, (IOracle.RequestInfo)); }
|
214
371
|
}
|
215
372
|
|
216
|
-
|
217
|
-
|
373
|
+
/// @dev Returns the request info for the given oracle request ID.
|
374
|
+
function getRequestState(RequestId requestId) public view returns (StateId state) {
|
375
|
+
return getState(requestId.toKey32());
|
218
376
|
}
|
219
377
|
|
220
|
-
|
221
|
-
|
378
|
+
//--- pool functions -----------------------------------------------------------//
|
379
|
+
|
380
|
+
/// @dev Returns the pool info for the given pool NFT ID.
|
381
|
+
function getPoolInfo(NftId poolNftId) public view returns (IComponents.PoolInfo memory info) {
|
382
|
+
(bytes memory data, bool success) = _getData(poolNftId.toKey32(POOL()));
|
383
|
+
if (success) { return abi.decode(data, (IComponents.PoolInfo)); }
|
222
384
|
}
|
223
385
|
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
bytes memory data = _store.getData(toComponentKey(componentNftId));
|
230
|
-
if (data.length > 0) {
|
231
|
-
return abi.decode(data, (IComponents.ComponentInfo));
|
232
|
-
}
|
386
|
+
//--- bundle functions -------------------------------------------------------//
|
387
|
+
|
388
|
+
/// @dev Returns the total number of registered bundles for the given pool.
|
389
|
+
function bundles(NftId poolNftId) public view returns (uint256 bundleCount) {
|
390
|
+
return _bundleSet.bundles(poolNftId);
|
233
391
|
}
|
234
392
|
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
{
|
240
|
-
bytes memory data = _store.getData(toProductKey(productNftId));
|
241
|
-
if (data.length > 0) {
|
242
|
-
return abi.decode(data, (IComponents.ProductInfo));
|
243
|
-
}
|
393
|
+
|
394
|
+
/// @dev Returns the number of active bundles for the given pool.
|
395
|
+
function activeBundles(NftId poolNftId) public view returns (uint256 bundleCount) {
|
396
|
+
return _bundleSet.activeBundles(poolNftId);
|
244
397
|
}
|
245
398
|
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
{
|
251
|
-
bytes memory data = _store.getData(toPoolKey(poolNftId));
|
252
|
-
if (data.length > 0) {
|
253
|
-
return abi.decode(data, (IComponents.PoolInfo));
|
254
|
-
}
|
399
|
+
|
400
|
+
/// @dev Returns the bunde NFT ID for the given pool and index.
|
401
|
+
function getBundleNftId(NftId poolNftId, uint256 idx) public view returns (NftId bundleNftId) {
|
402
|
+
return _bundleSet.getBundleNftId(poolNftId, idx);
|
255
403
|
}
|
256
404
|
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
{
|
262
|
-
bytes memory data = _store.getData(referralId.toKey32());
|
263
|
-
if (data.length > 0) {
|
264
|
-
return abi.decode(data, (IDistribution.ReferralInfo));
|
265
|
-
}
|
405
|
+
|
406
|
+
/// @dev Returns the active bunde NFT ID for the given pool and index.
|
407
|
+
function getActiveBundleNftId(NftId poolNftId, uint256 idx) public view returns (NftId bundleNftId) {
|
408
|
+
return _bundleSet.getActiveBundleNftId(poolNftId, idx);
|
266
409
|
}
|
267
410
|
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
bytes memory data = _store.getData(requestId.toKey32());
|
274
|
-
if (data.length > 0) {
|
275
|
-
return abi.decode(data, (IOracle.RequestInfo));
|
276
|
-
}
|
411
|
+
|
412
|
+
/// @dev Returns the bundle info for the given bundle NFT ID.
|
413
|
+
function getBundleInfo(NftId bundleNftId) public view returns (IBundle.BundleInfo memory info) {
|
414
|
+
(bytes memory data, bool success) = _getData(_toBundleKey(bundleNftId));
|
415
|
+
if (success) { return abi.decode(data, (IBundle.BundleInfo)); }
|
277
416
|
}
|
278
417
|
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
{
|
284
|
-
return _store.getMetadata(key);
|
418
|
+
|
419
|
+
/// @dev Returns the bundle state for the given bundle NFT ID.
|
420
|
+
function getBundleState(NftId bundleNftId) public view returns (StateId state) {
|
421
|
+
return getState(_toBundleKey(bundleNftId));
|
285
422
|
}
|
286
423
|
|
287
|
-
|
288
|
-
|
289
|
-
|
290
|
-
|
291
|
-
|
292
|
-
return _store.getMetadata(key).state;
|
424
|
+
//--- distribution functions -------------------------------------------------------//
|
425
|
+
|
426
|
+
function getDistributorTypeInfo(DistributorType distributorType) public view returns (IDistribution.DistributorTypeInfo memory info) {
|
427
|
+
(bytes memory data, bool success) = _getData(distributorType.toKey32());
|
428
|
+
if (success) { return abi.decode(data, (IDistribution.DistributorTypeInfo)); }
|
293
429
|
}
|
294
430
|
|
295
431
|
|
296
|
-
function
|
297
|
-
|
298
|
-
|
299
|
-
|
300
|
-
|
301
|
-
|
302
|
-
|
303
|
-
|
304
|
-
|
305
|
-
|
306
|
-
|
432
|
+
function getDistributorInfo(NftId distributorNftId) public view returns (IDistribution.DistributorInfo memory info) {
|
433
|
+
(bytes memory data, bool success) = _getData(distributorNftId.toKey32(DISTRIBUTOR()));
|
434
|
+
if (success) { return abi.decode(data, (IDistribution.DistributorInfo)); }
|
435
|
+
}
|
436
|
+
|
437
|
+
|
438
|
+
//--- referral functions -------------------------------------------------------//
|
439
|
+
|
440
|
+
function toReferralId(NftId distributionNftId, string memory referralCode) public pure returns (ReferralId referralId) {
|
441
|
+
return ReferralLib.toReferralId(distributionNftId, referralCode);
|
442
|
+
}
|
443
|
+
|
444
|
+
|
445
|
+
function isReferralValid(NftId distributionNftId, ReferralId referralId) external view returns (bool isValid) {
|
446
|
+
return _distributionService.referralIsValid(distributionNftId, referralId);
|
447
|
+
}
|
448
|
+
|
449
|
+
|
450
|
+
function getReferralInfo(ReferralId referralId) public view returns (IDistribution.ReferralInfo memory info) {
|
451
|
+
(bytes memory data, bool success) = _getData(referralId.toKey32());
|
452
|
+
if (success) { return abi.decode(data, (IDistribution.ReferralInfo)); }
|
307
453
|
}
|
308
454
|
|
309
455
|
|
@@ -315,91 +461,196 @@ contract InstanceReader {
|
|
315
461
|
ReferralStatus status
|
316
462
|
)
|
317
463
|
{
|
318
|
-
|
319
|
-
|
464
|
+
return IDistributionService(
|
465
|
+
_registry.getServiceAddress(
|
466
|
+
DISTRIBUTION(),
|
467
|
+
_instance.getRelease())).getDiscountPercentage(
|
468
|
+
this, // instance reader
|
469
|
+
referralId);
|
470
|
+
}
|
320
471
|
|
321
|
-
|
322
|
-
return (
|
323
|
-
UFixedLib.zero(),
|
324
|
-
REFERRAL_ERROR_UNKNOWN());
|
325
|
-
}
|
472
|
+
//--- authorization functions -------------------------------------------------------//
|
326
473
|
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
}
|
474
|
+
/// @dev Returns the number of defined roles.
|
475
|
+
function roles() public view returns (uint256) {
|
476
|
+
return _instanceAdmin.roles();
|
477
|
+
}
|
332
478
|
|
333
|
-
if (info.usedReferrals >= info.maxReferrals) {
|
334
|
-
return (
|
335
|
-
UFixedLib.zero(),
|
336
|
-
REFERRAL_ERROR_EXHAUSTED());
|
337
|
-
}
|
338
479
|
|
339
|
-
|
340
|
-
|
341
|
-
|
342
|
-
);
|
480
|
+
/// @dev Returns the role ID for the given index.
|
481
|
+
function getRoleId(uint256 idx) public view returns (RoleId roleId) {
|
482
|
+
return _instanceAdmin.getRoleId(uint64(idx));
|
343
483
|
}
|
344
484
|
|
345
485
|
|
346
|
-
|
347
|
-
|
486
|
+
/// @dev Returns the role ID for the instance owner role.
|
487
|
+
/// This role may be used as a "root" admin role for other custom roles defined for this instance.
|
488
|
+
function getInstanceOwnerRole() public pure returns (RoleId roleId) {
|
489
|
+
return INSTANCE_OWNER_ROLE();
|
348
490
|
}
|
349
491
|
|
350
492
|
|
351
|
-
|
352
|
-
|
493
|
+
/// @dev Returns the role info for the given role ID.
|
494
|
+
function getRoleInfo(RoleId roleId) public view returns (IAccess.RoleInfo memory roleInfo) {
|
495
|
+
return _instanceAdmin.getRoleInfo(roleId);
|
353
496
|
}
|
354
497
|
|
355
498
|
|
356
|
-
|
357
|
-
|
499
|
+
/// @dev Returns true iff the provided role ID is defined for this instance.
|
500
|
+
function roleExists(RoleId roleId) public view returns (bool exists) {
|
501
|
+
return _instanceAdmin.roleExists(roleId);
|
358
502
|
}
|
359
503
|
|
360
|
-
|
361
|
-
|
504
|
+
|
505
|
+
/// @dev Returns true iff the provided role ID represents a custom role ID.
|
506
|
+
function isRoleCustom(RoleId roleId) public view returns (bool isCustom) {
|
507
|
+
return _instanceAdmin.isRoleCustom(roleId);
|
362
508
|
}
|
363
509
|
|
364
510
|
|
365
|
-
|
366
|
-
|
511
|
+
/// @dev Returns true iff the provided role ID is active.
|
512
|
+
function isRoleActive(RoleId roleId) public view returns (bool isActive) {
|
513
|
+
return _instanceAdmin.isRoleActive(roleId);
|
367
514
|
}
|
368
515
|
|
369
|
-
|
370
|
-
|
516
|
+
|
517
|
+
/// @dev Returns the number of members (accounts) for the given role ID.
|
518
|
+
function roleMembers(RoleId roleId) public view returns (uint256 numberOfMembers) {
|
519
|
+
return _instanceAdmin.roleMembers(roleId);
|
371
520
|
}
|
372
521
|
|
373
|
-
|
374
|
-
|
522
|
+
|
523
|
+
/// @dev Returns the member (account address) for the given role ID and index.
|
524
|
+
function getRoleMember(RoleId roleId, uint256 idx) public view returns (address account) {
|
525
|
+
return _instanceAdmin.getRoleMember(roleId, idx);
|
375
526
|
}
|
376
527
|
|
377
|
-
|
378
|
-
|
528
|
+
|
529
|
+
/// @dev Returns true iff the given account is a member of the specified role ID.
|
530
|
+
function isRoleMember(RoleId roleId, address account) public view returns (bool isMember) {
|
531
|
+
return _instanceAdmin.isRoleMember(roleId, account);
|
379
532
|
}
|
380
533
|
|
381
|
-
|
382
|
-
|
534
|
+
|
535
|
+
/// @dev Returns true iff the given account is an admin of the specified role ID.
|
536
|
+
/// Role admins may grant and revoke the role to other accounts.
|
537
|
+
function isRoleAdmin(RoleId roleId, address account) public view returns (bool isMember) {
|
538
|
+
return _instanceAdmin.isRoleAdmin(roleId, account);
|
383
539
|
}
|
384
540
|
|
385
|
-
|
386
|
-
|
541
|
+
|
542
|
+
/// @dev Returns the number of targets (contracts) defined for this instance.
|
543
|
+
function targets() public view returns (uint256 targetCount) {
|
544
|
+
return _instanceAdmin.targets();
|
387
545
|
}
|
388
546
|
|
389
|
-
|
390
|
-
|
391
|
-
|
547
|
+
|
548
|
+
/// @dev Returns the target address for the given index.
|
549
|
+
function getTargetAddress(uint256 idx) public view returns (address target) {
|
550
|
+
return _instanceAdmin.getTargetAddress(idx);
|
551
|
+
}
|
552
|
+
|
553
|
+
|
554
|
+
/// @dev Returns the target info for the given target address.
|
555
|
+
function getTargetInfo(address target) public view returns (IAccess.TargetInfo memory targetInfo) {
|
556
|
+
return _instanceAdmin.getTargetInfo(target);
|
557
|
+
}
|
558
|
+
|
559
|
+
|
560
|
+
/// @dev Returns true iff the given target is defined for this instance.
|
561
|
+
function targetExists(address target) public view returns (bool exists) {
|
562
|
+
return _instanceAdmin.targetExists(target);
|
563
|
+
}
|
564
|
+
|
565
|
+
|
566
|
+
/// @dev Returns true iff the given target is locked.
|
567
|
+
function isLocked(address target) public view returns (bool) {
|
568
|
+
return _instanceAdmin.isTargetLocked(target);
|
569
|
+
}
|
570
|
+
|
571
|
+
|
572
|
+
/// @dev Returns the number of authorized functions for the given target.
|
573
|
+
function authorizedFunctions(address target) external view returns (uint256 numberOfFunctions) {
|
574
|
+
return _instanceAdmin.authorizedFunctions(target);
|
575
|
+
}
|
576
|
+
|
577
|
+
|
578
|
+
/// @dev Returns the authorized function info for the given target and index.
|
579
|
+
function getAuthorizedFunction(address target, uint256 idx) external view returns (IAccess.FunctionInfo memory func, RoleId roleId) {
|
580
|
+
return _instanceAdmin.getAuthorizedFunction(target, idx);
|
581
|
+
}
|
582
|
+
|
583
|
+
|
584
|
+
/// @dev Returns a function info for the given function signature and function name.
|
585
|
+
/// The function signature must not be zero and the function name must not be empty.
|
586
|
+
function toFunction(bytes4 signature, string memory name) public view returns (IAccess.FunctionInfo memory) {
|
587
|
+
return AccessAdminLib.toFunction(signature, name);
|
588
|
+
}
|
589
|
+
|
590
|
+
//--- low level function ----------------------------------------------------//
|
591
|
+
|
592
|
+
function getInstanceAdmin() external view returns (InstanceAdmin instanceAdmin) {
|
593
|
+
return _instanceAdmin;
|
392
594
|
}
|
393
595
|
|
394
596
|
function getInstanceStore() external view returns (IKeyValueStore store) {
|
395
597
|
return _store;
|
396
598
|
}
|
397
599
|
|
600
|
+
|
601
|
+
function getBundleSet() external view returns (BundleSet bundleSet) {
|
602
|
+
return _bundleSet;
|
603
|
+
}
|
604
|
+
|
605
|
+
|
606
|
+
function getRiskSet() external view returns (RiskSet riskSet) {
|
607
|
+
return _riskSet;
|
608
|
+
}
|
609
|
+
|
610
|
+
|
611
|
+
function getMetadata(Key32 key) public view returns (IKeyValueStore.Metadata memory metadata) {
|
612
|
+
return _store.getMetadata(key);
|
613
|
+
}
|
614
|
+
|
615
|
+
|
616
|
+
function getState(Key32 key) public view returns (StateId state) {
|
617
|
+
return _store.getState(key);
|
618
|
+
}
|
619
|
+
|
620
|
+
|
398
621
|
function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
|
399
622
|
return UFixedLib.toUFixed(value, exp);
|
400
623
|
}
|
401
624
|
|
625
|
+
|
402
626
|
function toInt(UFixed value) public pure returns (uint256) {
|
403
627
|
return UFixedLib.toInt(value);
|
404
628
|
}
|
629
|
+
|
630
|
+
//--- internal functions ----------------------------------------------------//
|
631
|
+
|
632
|
+
function _getData(Key32 key) internal view returns (bytes memory data, bool success) {
|
633
|
+
data = _store.getData(key);
|
634
|
+
return (data, data.length > 0);
|
635
|
+
}
|
636
|
+
|
637
|
+
|
638
|
+
function _toPolicyKey(NftId policyNftId) internal pure returns (Key32) {
|
639
|
+
return policyNftId.toKey32(POLICY());
|
640
|
+
}
|
641
|
+
|
642
|
+
|
643
|
+
function _toPremiumKey(NftId policyNftId) internal pure returns (Key32) {
|
644
|
+
return policyNftId.toKey32(PREMIUM());
|
645
|
+
}
|
646
|
+
|
647
|
+
|
648
|
+
function _toBundleKey(NftId poolNftId) internal pure returns (Key32) {
|
649
|
+
return poolNftId.toKey32(BUNDLE());
|
650
|
+
}
|
651
|
+
|
652
|
+
|
653
|
+
function _toComponentKey(NftId componentNftId) internal pure returns (Key32) {
|
654
|
+
return componentNftId.toKey32(COMPONENT());
|
655
|
+
}
|
405
656
|
}
|