@etherisc/gif-next 0.0.2-f1e0c66-773 → 0.0.2-f1f3b2c-994
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 +7 -2
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +81 -63
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +2 -2
- 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 +48 -30
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +21 -2
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +2 -2
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +72 -9
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +63 -248
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +16 -16
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +21 -222
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +134 -286
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +84 -120
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +21 -37
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +49 -62
- 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 +1512 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +410 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +1999 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +414 -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/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1432 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1192 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1566 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2001 -0
- 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/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +10 -99
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +145 -111
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +14 -14
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +437 -124
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +39 -146
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +61 -81
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +285 -218
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +2 -2
- 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 +45 -4
- 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/module/IAccess.sol/IAccess.dbg.json +1 -1
- 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 +47 -232
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +18 -18
- 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 +15 -31
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +15 -216
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +37 -144
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +60 -80
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +51 -274
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +16 -16
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +319 -188
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +130 -94
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +149 -23
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +44 -88
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +360 -171
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +41 -270
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +492 -333
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +98 -82
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +36 -162
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +57 -89
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +43 -242
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +16 -16
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +263 -181
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +104 -100
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +5 -0
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +147 -6
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +282 -119
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +43 -43
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +43 -57
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/product/{IProductService.sol/IProductService.json → IRiskService.sol/IRiskService.json} +2 -2
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +399 -327
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +104 -100
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +115 -267
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +80 -120
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +43 -242
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +588 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +682 -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 +238 -34
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.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 +436 -95
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +261 -143
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +23 -313
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +52 -72
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +46 -5
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +117 -215
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +70 -12
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +2 -2
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +15 -205
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +89 -212
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +96 -114
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.json +5 -112
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +92 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +15 -20
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +15 -31
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +36 -0
- 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/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/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -22
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +15 -216
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +41 -0
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +41 -0
- 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 +6 -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 +8 -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 +5 -112
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +330 -11
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +108 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +42 -21
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +63 -93
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +100 -256
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +45 -4
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +77 -88
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +6 -11
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +31 -138
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +56 -76
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +168 -127
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +54 -23
- 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 +32 -8
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +2 -2
- 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 +2 -2
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +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 +2 -2
- 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 +2 -2
- 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/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +60 -4
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +2 -2
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +50 -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/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +23 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +2 -2
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +15 -2
- 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/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +39 -70
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/contracts/authorization/AccessAdmin.sol +31 -24
- package/contracts/authorization/Authorization.sol +5 -2
- package/contracts/authorization/IAccessAdmin.sol +3 -2
- package/contracts/authorization/IServiceAuthorization.sol +4 -2
- package/contracts/authorization/ServiceAuthorization.sol +27 -11
- package/contracts/distribution/Distribution.sol +1 -1
- package/contracts/distribution/DistributionService.sol +32 -33
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionService.sol +9 -5
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +75 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +34 -0
- package/contracts/examples/fire/FireProduct.sol +411 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +50 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +137 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +76 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +351 -0
- package/contracts/instance/IInstance.sol +7 -30
- package/contracts/instance/Instance.sol +10 -35
- package/contracts/instance/InstanceAdmin.sol +29 -7
- package/contracts/instance/InstanceAuthorizationV3.sol +3 -3
- package/contracts/instance/InstanceReader.sol +115 -25
- package/contracts/instance/InstanceService.sol +63 -41
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +11 -1
- package/contracts/instance/base/ObjectLifecycle.sol +9 -4
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +4 -7
- package/contracts/instance/module/IPolicy.sol +24 -24
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/Oracle.sol +2 -1
- package/contracts/oracle/OracleService.sol +11 -8
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +7 -5
- package/contracts/pool/BasicPoolAuthorization.sol +5 -2
- package/contracts/pool/BundleService.sol +166 -46
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +31 -8
- package/contracts/pool/IPoolComponent.sol +18 -8
- package/contracts/pool/IPoolService.sol +57 -36
- package/contracts/pool/Pool.sol +59 -34
- package/contracts/pool/PoolService.sol +231 -102
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +50 -29
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +1 -0
- package/contracts/product/ClaimService.sol +251 -87
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +1 -0
- package/contracts/product/IClaimService.sol +31 -7
- package/contracts/product/IPolicyService.sol +34 -34
- package/contracts/product/IPricingService.sol +7 -7
- package/contracts/product/IProductComponent.sol +17 -4
- package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
- package/contracts/product/PolicyService.sol +379 -192
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +46 -46
- package/contracts/product/PricingServiceManager.sol +3 -3
- package/contracts/product/Product.sol +81 -50
- package/contracts/product/{ProductService.sol → RiskService.sol} +7 -10
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +65 -32
- package/contracts/registry/IRegistry.sol +51 -18
- package/contracts/registry/IRegistryService.sol +0 -9
- package/contracts/registry/Registry.sol +328 -197
- package/contracts/registry/RegistryAdmin.sol +134 -51
- package/contracts/registry/RegistryService.sol +55 -48
- package/contracts/registry/RegistryServiceManager.sol +2 -2
- package/contracts/registry/ReleaseLifecycle.sol +6 -3
- package/contracts/registry/ReleaseRegistry.sol +194 -183
- package/contracts/registry/ServiceAuthorizationV3.sol +8 -10
- package/contracts/shared/Component.sol +25 -29
- package/contracts/shared/ComponentService.sol +20 -30
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ComponentVerifyingService.sol +2 -3
- package/contracts/shared/ContractLib.sol +38 -0
- package/contracts/shared/IComponent.sol +7 -4
- package/contracts/shared/IInstanceLinkedComponent.sol +8 -15
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/InitializableERC165.sol +2 -2
- package/contracts/shared/InstanceLinkedComponent.sol +5 -6
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +13 -2
- package/contracts/shared/NftOwnable.sol +5 -5
- package/contracts/shared/PolicyHolder.sol +15 -52
- package/contracts/shared/Registerable.sol +4 -4
- package/contracts/shared/RegistryLinked.sol +3 -2
- package/contracts/shared/Service.sol +16 -11
- package/contracts/shared/TokenHandler.sol +100 -19
- package/contracts/shared/TokenHandlerDeployerLib.sol +12 -0
- package/contracts/staking/IStaking.sol +2 -1
- package/contracts/staking/StakeManagerLib.sol +18 -25
- package/contracts/staking/Staking.sol +11 -29
- package/contracts/staking/StakingManager.sol +8 -6
- package/contracts/staking/StakingReader.sol +12 -5
- package/contracts/staking/StakingService.sol +10 -14
- package/contracts/staking/StakingServiceManager.sol +2 -2
- package/contracts/staking/TargetManagerLib.sol +7 -3
- package/contracts/type/Amount.sol +15 -0
- package/contracts/type/Blocknumber.sol +7 -1
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/NftId.sol +1 -0
- package/contracts/type/ObjectType.sol +16 -11
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +15 -1
- package/contracts/type/Seconds.sol +21 -1
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/Timestamp.sol +11 -1
- package/contracts/type/UFixed.sol +4 -0
- package/contracts/upgradeability/ProxyManager.sol +67 -34
- package/contracts/upgradeability/Versionable.sol +2 -2
- package/package.json +2 -1
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- 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/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/contracts/product/ProductServiceManager.sol +0 -39
- package/contracts/shared/InitializableCustom.sol +0 -177
| @@ -2,14 +2,15 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {Amount} from "../type/Amount.sol";
         | 
| 5 | 
            +
            import {ClaimId} from "../type/ClaimId.sol";
         | 
| 5 6 | 
             
            import {Fee} from "../type/Fee.sol";
         | 
| 6 | 
            -
            import {NftId} from "../type/NftId.sol";
         | 
| 7 | 
            -
            import {PayoutId} from "../type/PayoutId.sol";
         | 
| 8 7 | 
             
            import {IBundle} from "../instance/module/IBundle.sol";
         | 
| 9 8 | 
             
            import {IInstance} from "../instance/IInstance.sol";
         | 
| 10 9 | 
             
            import {InstanceReader} from "../instance/InstanceReader.sol";
         | 
| 11 10 | 
             
            import {IPolicy} from "../instance/module/IPolicy.sol";
         | 
| 12 11 | 
             
            import {IService} from "../shared/IService.sol";
         | 
| 12 | 
            +
            import {NftId} from "../type/NftId.sol";
         | 
| 13 | 
            +
            import {PayoutId} from "../type/PayoutId.sol";
         | 
| 13 14 | 
             
            import {RoleId} from "../type/RoleId.sol";
         | 
| 14 15 | 
             
            import {Seconds} from "../type/Seconds.sol";
         | 
| 15 16 | 
             
            import {StateId} from "../type/StateId.sol";
         | 
| @@ -17,29 +18,29 @@ import {UFixed} from "../type/UFixed.sol"; | |
| 17 18 |  | 
| 18 19 | 
             
            interface IPoolService is IService {
         | 
| 19 20 |  | 
| 20 | 
            -
                event  | 
| 21 | 
            +
                event LogPoolServiceMaxBalanceAmountUpdated(NftId poolNftId, Amount previousMaxCapitalAmount, Amount currentMaxCapitalAmount);
         | 
| 21 22 | 
             
                event LogPoolServiceBundleOwnerRoleSet(NftId poolNftId, RoleId bundleOwnerRole);
         | 
| 22 23 |  | 
| 23 24 | 
             
                event LogPoolServiceBundleCreated(NftId instanceNftId, NftId poolNftId, NftId bundleNftId);
         | 
| 24 25 | 
             
                event LogPoolServiceBundleClosed(NftId instanceNftId, NftId poolNftId, NftId bundleNftId);
         | 
| 25 26 |  | 
| 27 | 
            +
                event LogPoolServiceBundleStaked(NftId instanceNftId, NftId poolNftId, NftId bundleNftId, Amount amount, Amount netAmount);
         | 
| 28 | 
            +
                event LogPoolServiceBundleUnstaked(NftId instanceNftId, NftId poolNftId, NftId bundleNftId, Amount amount);
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                event LogPoolServiceProcessFundedClaim(NftId policyNftId, ClaimId claimId, Amount availableAmount);
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                error ErrorPoolServicePolicyPoolMismatch(NftId policyNftId, NftId productNftId, NftId expectedProductNftId);
         | 
| 26 33 | 
             
                error ErrorPoolServiceBundleOwnerRoleAlreadySet(NftId poolNftId);
         | 
| 27 34 | 
             
                error ErrorPoolServiceInvalidTransferAmount(Amount expectedAmount, Amount actualAmount);
         | 
| 28 | 
            -
             | 
| 35 | 
            +
                error ErrorPoolServiceBundlePoolMismatch(NftId bundleNftId, NftId poolNftId);
         | 
| 36 | 
            +
                error ErrorPoolServiceMaxBalanceAmountExceeded(NftId poolNftId, Amount maxBalanceAmount, Amount currentBalanceAmount, Amount transferAmount);
         | 
| 37 | 
            +
                
         | 
| 29 38 | 
             
                /// @dev defines the required role for bundle owners for the calling pool
         | 
| 30 39 | 
             
                /// default implementation returns PUBLIC ROLE
         | 
| 31 40 | 
             
                function setBundleOwnerRole(RoleId bundleOwnerRole) external;
         | 
| 32 41 |  | 
| 33 | 
            -
                /// @dev sets the max  | 
| 34 | 
            -
                function  | 
| 35 | 
            -
             | 
| 36 | 
            -
                /// @dev set pool sepecific fees
         | 
| 37 | 
            -
                function setFees(
         | 
| 38 | 
            -
                    Fee memory poolFee,
         | 
| 39 | 
            -
                    Fee memory stakingFee,
         | 
| 40 | 
            -
                    Fee memory performanceFee
         | 
| 41 | 
            -
                ) external;
         | 
| 42 | 
            -
             | 
| 42 | 
            +
                /// @dev sets the max balance amount for the calling pool
         | 
| 43 | 
            +
                function setMaxBalanceAmount(Amount maxBalanceAmount) external;
         | 
| 43 44 |  | 
| 44 45 | 
             
                /// @dev locks required collateral to cover the specified application (and turn it into a policy)
         | 
| 45 46 | 
             
                /// - retention level == 1: the full collateral amount will be locked by the specified bundle
         | 
| @@ -71,10 +72,10 @@ interface IPoolService is IService { | |
| 71 72 | 
             
                ) external;
         | 
| 72 73 |  | 
| 73 74 |  | 
| 74 | 
            -
                /// @dev reduces the locked collateral in the bundle associated with the specified policy
         | 
| 75 | 
            +
                /// @dev reduces the locked collateral in the bundle associated with the specified policy and updates pool/bundle counters
         | 
| 75 76 | 
             
                /// every payout of a policy reduces the collateral by the payout amount
         | 
| 76 77 | 
             
                /// may only be called by the claim service for unlocked pool components
         | 
| 77 | 
            -
                function  | 
| 78 | 
            +
                function processPayout(
         | 
| 78 79 | 
             
                    IInstance instance, 
         | 
| 79 80 | 
             
                    address token,
         | 
| 80 81 | 
             
                    NftId policyNftId, 
         | 
| @@ -83,13 +84,11 @@ interface IPoolService is IService { | |
| 83 84 | 
             
                ) external;
         | 
| 84 85 |  | 
| 85 86 |  | 
| 86 | 
            -
                /// @dev create a new bundle  | 
| 87 | 
            -
                ///  | 
| 88 | 
            -
                /// may only be called by registered and unlocked pool components
         | 
| 87 | 
            +
                /// @dev create a new empty bundle with the provided parameters
         | 
| 88 | 
            +
                /// may only be called by registered and unlocked pool components.
         | 
| 89 89 | 
             
                function createBundle(
         | 
| 90 90 | 
             
                    address owner, // initial bundle owner
         | 
| 91 91 | 
             
                    Fee memory fee, // fees deducted from premium that go to bundle owner
         | 
| 92 | 
            -
                    Amount stakingAmount, // staking amount - staking fees result in initial bundle capital
         | 
| 93 92 | 
             
                    Seconds lifetime, // initial duration for which new policies are covered
         | 
| 94 93 | 
             
                    bytes calldata filter // optional use case specific criteria that define if a policy may be covered by this bundle
         | 
| 95 94 | 
             
                )
         | 
| @@ -97,6 +96,18 @@ interface IPoolService is IService { | |
| 97 96 | 
             
                    returns(NftId bundleNftId); // the nft id of the newly created bundle
         | 
| 98 97 |  | 
| 99 98 |  | 
| 99 | 
            +
                /// @dev increase stakes for bundle
         | 
| 100 | 
            +
                /// staking fees will be deducted by the pool service from the staking amount
         | 
| 101 | 
            +
                /// may only be called by registered and unlocked pool components
         | 
| 102 | 
            +
                function stake(NftId bundleNftId, Amount amount) external returns(Amount netAmount);
         | 
| 103 | 
            +
             | 
| 104 | 
            +
             | 
| 105 | 
            +
                /// @dev decrease stakes for bundle
         | 
| 106 | 
            +
                /// performance fees will be deducted by the pool service from the staking amount
         | 
| 107 | 
            +
                /// may only be called by registered and unlocked pool components
         | 
| 108 | 
            +
                function unstake(NftId bundleNftId, Amount amount) external returns(Amount netAmount);
         | 
| 109 | 
            +
             | 
| 110 | 
            +
             | 
| 100 111 | 
             
                /// @dev closes the specified bundle
         | 
| 101 112 | 
             
                /// only open bundles (active or locked) may be closed
         | 
| 102 113 | 
             
                /// to close a bundle it may not have any non-closed polices attached to it
         | 
| @@ -105,22 +116,30 @@ interface IPoolService is IService { | |
| 105 116 | 
             
                function closeBundle(NftId bundleNftId) external;
         | 
| 106 117 |  | 
| 107 118 |  | 
| 108 | 
            -
                /// @dev  | 
| 109 | 
            -
                function  | 
| 119 | 
            +
                /// @dev Informs product about available funds to process a confirmed claim.
         | 
| 120 | 
            +
                /// The function triggers a callback to the product component when the product's property isProcessingFundedClaims is set.
         | 
| 121 | 
            +
                function processFundedClaim(NftId policyNftId, ClaimId claimId, Amount availableAmount) external;
         | 
| 110 122 |  | 
| 111 | 
            -
                /// @dev increase stakes for bundle
         | 
| 112 | 
            -
                /// staking fees will be deducted by the pool service from the staking amount
         | 
| 113 | 
            -
                /// may only be called by registered and unlocked pool components
         | 
| 114 | 
            -
                // function stake(NftId bundleNftId, uint256 amount) external returns(uint256 netAmount);
         | 
| 115 123 |  | 
| 124 | 
            +
                /// @dev Fund the specified pool wallet with the provided amount.
         | 
| 125 | 
            +
                /// This function will collect the amount from the sender address and transfers it to the pool wallet.
         | 
| 126 | 
            +
                /// The function will not update balance amounts managed by the framework.
         | 
| 127 | 
            +
                /// Only available for externally managed pools.
         | 
| 128 | 
            +
                function fundPoolWallet(NftId poolNftId, Amount amount) external;
         | 
| 116 129 |  | 
| 117 | 
            -
             | 
| 118 | 
            -
                ///  | 
| 119 | 
            -
                ///  | 
| 120 | 
            -
                 | 
| 130 | 
            +
             | 
| 131 | 
            +
                /// @dev Defund the specified pool wallet with the provided amount.
         | 
| 132 | 
            +
                /// This function will transfer the amount from the pool wallet to the sender address.
         | 
| 133 | 
            +
                /// The function will not update balance amounts managed by the framework.
         | 
| 134 | 
            +
                /// Only available for externally managed pools.
         | 
| 135 | 
            +
                function defundPoolWallet(NftId poolNftId, Amount amount) external;
         | 
| 136 | 
            +
             | 
| 137 | 
            +
             | 
| 138 | 
            +
                /// @dev processes the sale of a bundle and track the pool fee and bundle fee amounts
         | 
| 139 | 
            +
                function processSale(NftId bundleNftId, IPolicy.PremiumInfo memory premium) external;
         | 
| 121 140 |  | 
| 122 141 |  | 
| 123 | 
            -
                /// @dev  | 
| 142 | 
            +
                /// @dev Calulate required collateral for the provided parameters.
         | 
| 124 143 | 
             
                function calculateRequiredCollateral(
         | 
| 125 144 | 
             
                    InstanceReader instanceReader,
         | 
| 126 145 | 
             
                    NftId productNftId, 
         | 
| @@ -129,12 +148,14 @@ interface IPoolService is IService { | |
| 129 148 | 
             
                    external
         | 
| 130 149 | 
             
                    view 
         | 
| 131 150 | 
             
                    returns(
         | 
| 132 | 
            -
                        Amount  | 
| 133 | 
            -
                        Amount  | 
| 151 | 
            +
                        Amount totalCollateralAmount,
         | 
| 152 | 
            +
                        Amount localCollateralAmount
         | 
| 134 153 | 
             
                    );
         | 
| 135 154 |  | 
| 136 155 |  | 
| 137 | 
            -
                /// @dev calulate required collateral for the provided parameters
         | 
| 156 | 
            +
                /// @dev calulate required collateral for the provided parameters.
         | 
| 157 | 
            +
                /// Collateralization is applied to sum insured.
         | 
| 158 | 
            +
                /// Retention level defines the fraction of the collateral that is required locally.
         | 
| 138 159 | 
             
                function calculateRequiredCollateral(
         | 
| 139 160 | 
             
                    UFixed collateralizationLevel, 
         | 
| 140 161 | 
             
                    UFixed retentionLevel, 
         | 
| @@ -143,8 +164,8 @@ interface IPoolService is IService { | |
| 143 164 | 
             
                    external
         | 
| 144 165 | 
             
                    pure 
         | 
| 145 166 | 
             
                    returns(
         | 
| 146 | 
            -
                        Amount  | 
| 147 | 
            -
                        Amount  | 
| 167 | 
            +
                        Amount totalCollateralAmount,
         | 
| 168 | 
            +
                        Amount localCollateralAmount
         | 
| 148 169 | 
             
                    );
         | 
| 149 170 |  | 
| 150 171 | 
             
            }
         | 
    
        package/contracts/pool/Pool.sol
    CHANGED
    
    | @@ -3,6 +3,7 @@ pragma solidity ^0.8.20; | |
| 3 3 |  | 
| 4 4 | 
             
            import {Amount, AmountLib} from "../type/Amount.sol";
         | 
| 5 5 | 
             
            import {BUNDLE, COMPONENT, POOL} from "../type/ObjectType.sol";
         | 
| 6 | 
            +
            import {ClaimId} from "../type/ClaimId.sol";
         | 
| 6 7 | 
             
            import {IBundleService} from "./IBundleService.sol";
         | 
| 7 8 | 
             
            import {IAuthorization} from "../authorization/IAuthorization.sol";
         | 
| 8 9 | 
             
            import {IPoolComponent} from "./IPoolComponent.sol";
         | 
| @@ -14,6 +15,7 @@ import {Fee, FeeLib} from "../type/Fee.sol"; | |
| 14 15 | 
             
            import {NftId, NftIdLib} from "../type/NftId.sol";
         | 
| 15 16 | 
             
            import {RoleId, PUBLIC_ROLE} from "../type/RoleId.sol";
         | 
| 16 17 | 
             
            import {Seconds} from "../type/Seconds.sol";
         | 
| 18 | 
            +
            import {Timestamp} from "../type/Timestamp.sol";
         | 
| 17 19 | 
             
            import {TokenHandler} from "../shared/TokenHandler.sol";
         | 
| 18 20 | 
             
            import {UFixed, UFixedLib} from "../type/UFixed.sol";
         | 
| 19 21 |  | 
| @@ -39,6 +41,16 @@ abstract contract Pool is | |
| 39 41 | 
             
                }
         | 
| 40 42 |  | 
| 41 43 |  | 
| 44 | 
            +
                function register()
         | 
| 45 | 
            +
                    external
         | 
| 46 | 
            +
                    virtual
         | 
| 47 | 
            +
                    onlyOwner()
         | 
| 48 | 
            +
                {
         | 
| 49 | 
            +
                    _getPoolStorage()._componentService.registerPool();
         | 
| 50 | 
            +
                    _approveTokenHandler(type(uint256).max);
         | 
| 51 | 
            +
                }
         | 
| 52 | 
            +
             | 
| 53 | 
            +
             | 
| 42 54 | 
             
                /// @dev see {IPoolComponent.verifyApplication}
         | 
| 43 55 | 
             
                function verifyApplication(
         | 
| 44 56 | 
             
                    NftId applicationNftId, 
         | 
| @@ -66,6 +78,20 @@ abstract contract Pool is | |
| 66 78 | 
             
                }
         | 
| 67 79 |  | 
| 68 80 |  | 
| 81 | 
            +
                /// @dev see {IPoolComponent.processConfirmedClaim}
         | 
| 82 | 
            +
                function processConfirmedClaim(
         | 
| 83 | 
            +
                    NftId policyNftId, 
         | 
| 84 | 
            +
                    ClaimId claimId, 
         | 
| 85 | 
            +
                    Amount amount
         | 
| 86 | 
            +
                )
         | 
| 87 | 
            +
                    public
         | 
| 88 | 
            +
                    virtual
         | 
| 89 | 
            +
                    restricted()
         | 
| 90 | 
            +
                {
         | 
| 91 | 
            +
                    // default implementation is empty
         | 
| 92 | 
            +
                }
         | 
| 93 | 
            +
             | 
| 94 | 
            +
             | 
| 69 95 | 
             
                /// @dev see {IPoolComponent.applicationMatchesBundle}
         | 
| 70 96 | 
             
                /// Override this function to implement any custom application verification 
         | 
| 71 97 | 
             
                /// Default implementation always returns true
         | 
| @@ -84,16 +110,6 @@ abstract contract Pool is | |
| 84 110 | 
             
                    return true;
         | 
| 85 111 | 
             
                }
         | 
| 86 112 |  | 
| 87 | 
            -
             | 
| 88 | 
            -
                function register()
         | 
| 89 | 
            -
                    external
         | 
| 90 | 
            -
                    virtual
         | 
| 91 | 
            -
                    onlyOwner()
         | 
| 92 | 
            -
                {
         | 
| 93 | 
            -
                    _getPoolStorage()._componentService.registerPool();
         | 
| 94 | 
            -
                    _approveTokenHandler(type(uint256).max);
         | 
| 95 | 
            -
                }
         | 
| 96 | 
            -
             | 
| 97 113 | 
             
                /// @inheritdoc IPoolComponent
         | 
| 98 114 | 
             
                function withdrawBundleFees(NftId bundleNftId, Amount amount) 
         | 
| 99 115 | 
             
                    external 
         | 
| @@ -112,19 +128,16 @@ abstract contract Pool is | |
| 112 128 | 
             
                    view 
         | 
| 113 129 | 
             
                    returns (IComponents.PoolInfo memory poolInfo)
         | 
| 114 130 | 
             
                {
         | 
| 115 | 
            -
                    return IComponents.PoolInfo(
         | 
| 116 | 
            -
                         | 
| 117 | 
            -
                        PUBLIC_ROLE(),  | 
| 118 | 
            -
                         | 
| 119 | 
            -
                         | 
| 120 | 
            -
                        false, | 
| 121 | 
            -
                        false, | 
| 122 | 
            -
                        UFixedLib.toUFixed(1), | 
| 123 | 
            -
                        UFixedLib.toUFixed(1) | 
| 124 | 
            -
             | 
| 125 | 
            -
                        FeeLib.zero(), // initialStakingFee,
         | 
| 126 | 
            -
                        FeeLib.zero() // initialPerformanceFee,
         | 
| 127 | 
            -
                    );
         | 
| 131 | 
            +
                    return IComponents.PoolInfo({
         | 
| 132 | 
            +
                        maxBalanceAmount: AmountLib.max(),
         | 
| 133 | 
            +
                        bundleOwnerRole: PUBLIC_ROLE(), 
         | 
| 134 | 
            +
                        isInterceptingBundleTransfers: isNftInterceptor(),
         | 
| 135 | 
            +
                        isProcessingConfirmedClaims: false,
         | 
| 136 | 
            +
                        isExternallyManaged: false,
         | 
| 137 | 
            +
                        isVerifyingApplications: false,
         | 
| 138 | 
            +
                        collateralizationLevel: UFixedLib.toUFixed(1),
         | 
| 139 | 
            +
                        retentionLevel: UFixedLib.toUFixed(1)
         | 
| 140 | 
            +
                    });
         | 
| 128 141 | 
             
                }
         | 
| 129 142 |  | 
| 130 143 | 
             
                // Internals
         | 
| @@ -161,7 +174,7 @@ abstract contract Pool is | |
| 161 174 | 
             
                    $._bundleService = IBundleService(_getServiceAddress(BUNDLE()));
         | 
| 162 175 | 
             
                    $._componentService = IComponentService(_getServiceAddress(COMPONENT())); 
         | 
| 163 176 |  | 
| 164 | 
            -
                     | 
| 177 | 
            +
                    _registerInterface(type(IPoolComponent).interfaceId);
         | 
| 165 178 | 
             
                }
         | 
| 166 179 |  | 
| 167 180 | 
             
                /// @dev increases the staked tokens by the specified amount
         | 
| @@ -172,8 +185,9 @@ abstract contract Pool is | |
| 172 185 | 
             
                )
         | 
| 173 186 | 
             
                    internal
         | 
| 174 187 | 
             
                    virtual
         | 
| 188 | 
            +
                    returns(Amount) 
         | 
| 175 189 | 
             
                {
         | 
| 176 | 
            -
                     | 
| 190 | 
            +
                    return _getPoolStorage()._poolService.stake(bundleNftId, amount);
         | 
| 177 191 | 
             
                }
         | 
| 178 192 |  | 
| 179 193 |  | 
| @@ -185,8 +199,9 @@ abstract contract Pool is | |
| 185 199 | 
             
                )
         | 
| 186 200 | 
             
                    internal
         | 
| 187 201 | 
             
                    virtual
         | 
| 202 | 
            +
                    returns(Amount netAmount) 
         | 
| 188 203 | 
             
                {
         | 
| 189 | 
            -
                     | 
| 204 | 
            +
                    return _getPoolStorage()._poolService.unstake(bundleNftId, amount);
         | 
| 190 205 | 
             
                }
         | 
| 191 206 |  | 
| 192 207 |  | 
| @@ -198,8 +213,9 @@ abstract contract Pool is | |
| 198 213 | 
             
                )
         | 
| 199 214 | 
             
                    internal
         | 
| 200 215 | 
             
                    virtual
         | 
| 216 | 
            +
                    returns (Timestamp extendedExpiredAt) 
         | 
| 201 217 | 
             
                {
         | 
| 202 | 
            -
                     | 
| 218 | 
            +
                    return _getPoolStorage()._bundleService.extend(bundleNftId, lifetimeExtension);
         | 
| 203 219 | 
             
                }
         | 
| 204 220 |  | 
| 205 221 |  | 
| @@ -229,7 +245,7 @@ abstract contract Pool is | |
| 229 245 | 
             
                /// To close a bundle all all linked policies MUST be in closed state as well.
         | 
| 230 246 | 
             
                /// Closing a bundle finalizes the bundle bookkeeping including overall profit calculation.
         | 
| 231 247 | 
             
                /// Once a bundle is closed this action cannot be reversed.
         | 
| 232 | 
            -
                function  | 
| 248 | 
            +
                function _closeBundle(NftId bundleNftId)
         | 
| 233 249 | 
             
                    internal
         | 
| 234 250 | 
             
                    virtual
         | 
| 235 251 | 
             
                {
         | 
| @@ -251,13 +267,13 @@ abstract contract Pool is | |
| 251 267 | 
             
                }
         | 
| 252 268 |  | 
| 253 269 |  | 
| 254 | 
            -
                /// @dev Sets the maximum  | 
| 270 | 
            +
                /// @dev Sets the maximum balance amound held by this pool.
         | 
| 255 271 | 
             
                /// Function may only be called by pool owner.
         | 
| 256 | 
            -
                function  | 
| 272 | 
            +
                function _setMaxBalanceAmount(Amount maxBalanceAmount)
         | 
| 257 273 | 
             
                    internal
         | 
| 258 274 | 
             
                    virtual
         | 
| 259 275 | 
             
                {
         | 
| 260 | 
            -
                    _getPoolStorage()._poolService. | 
| 276 | 
            +
                    _getPoolStorage()._poolService.setMaxBalanceAmount(maxBalanceAmount);
         | 
| 261 277 | 
             
                }
         | 
| 262 278 |  | 
| 263 279 | 
             
                /// @dev Sets the required role to create/own bundles.
         | 
| @@ -287,11 +303,10 @@ abstract contract Pool is | |
| 287 303 | 
             
                    _getPoolStorage()._componentService.setPoolFees(poolFee, stakingFee, performanceFee);
         | 
| 288 304 | 
             
                }
         | 
| 289 305 |  | 
| 290 | 
            -
                /// @dev Creates a new bundle using the provided parameter values.
         | 
| 306 | 
            +
                /// @dev Creates a new empty bundle using the provided parameter values.
         | 
| 291 307 | 
             
                function _createBundle(
         | 
| 292 308 | 
             
                    address bundleOwner,
         | 
| 293 309 | 
             
                    Fee memory fee,
         | 
| 294 | 
            -
                    Amount amount,
         | 
| 295 310 | 
             
                    Seconds lifetime, 
         | 
| 296 311 | 
             
                    bytes memory filter
         | 
| 297 312 | 
             
                )
         | 
| @@ -301,7 +316,6 @@ abstract contract Pool is | |
| 301 316 | 
             
                    bundleNftId = _getPoolStorage()._poolService.createBundle(
         | 
| 302 317 | 
             
                        bundleOwner,
         | 
| 303 318 | 
             
                        fee,
         | 
| 304 | 
            -
                        amount,
         | 
| 305 319 | 
             
                        lifetime,
         | 
| 306 320 | 
             
                        filter);
         | 
| 307 321 |  | 
| @@ -320,6 +334,17 @@ abstract contract Pool is | |
| 320 334 | 
             
                    return _getPoolStorage()._bundleService.withdrawBundleFees(bundleNftId, amount);
         | 
| 321 335 | 
             
                }
         | 
| 322 336 |  | 
| 337 | 
            +
                function _processFundedClaim(
         | 
| 338 | 
            +
                    NftId policyNftId, 
         | 
| 339 | 
            +
                    ClaimId claimId, 
         | 
| 340 | 
            +
                    Amount availableAmount
         | 
| 341 | 
            +
                )
         | 
| 342 | 
            +
                    internal
         | 
| 343 | 
            +
                {
         | 
| 344 | 
            +
                    _getPoolStorage()._poolService.processFundedClaim(
         | 
| 345 | 
            +
                        policyNftId, claimId, availableAmount);
         | 
| 346 | 
            +
                }
         | 
| 347 | 
            +
             | 
| 323 348 | 
             
                function _getPoolStorage() private pure returns (PoolStorage storage $) {
         | 
| 324 349 | 
             
                    assembly {
         | 
| 325 350 | 
             
                        $.slot := POOL_STORAGE_LOCATION_V1
         |