@etherisc/gif-next 0.0.2-f18fb8b-243 → 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 +19 -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 +106 -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 +64 -222
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +228 -217
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +93 -101
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +64 -37
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +120 -31
- 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 +4 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +703 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +6 -6
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +5 -5
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +17 -106
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +146 -112
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +31 -31
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +437 -129
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +44 -151
- 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 -228
- 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 +4 -0
- package/artifacts/contracts/instance/base/{ObjectManager.sol/ObjectManager.json → ObjectSet.sol/ObjectSet.json} +6 -6
- 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 +74 -229
- 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 +45 -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 +42 -213
- 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 +94 -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 +458 -161
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +154 -86
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +229 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +87 -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 +84 -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 +62 -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 +295 -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 +62 -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 +406 -321
- 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 +118 -265
- 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 +62 -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 +274 -22
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +0 -183
- 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 +493 -80
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +263 -145
- 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 +4 -0
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +1061 -0
- 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 +247 -161
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +105 -95
- 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/IComponentService.sol/IComponentService.json +153 -0
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +34 -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 +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 +34 -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 +4 -0
- package/artifacts/contracts/shared/{NftIdSetManager.sol/NftIdSetManager.json → NftIdSet.sol/NftIdSet.json} +4 -4
- 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 +73 -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 +176 -130
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +59 -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 +61 -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 +7 -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 +9 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +52 -2
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -2
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +21 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/IVersionable.sol/IVersionable.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +586 -0
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +3 -3
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/{shared → upgradeability}/Versionable.sol/Versionable.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/BasicDistribution.sol +4 -15
- package/contracts/distribution/BasicDistributionAuthorization.sol +5 -1
- package/contracts/distribution/Distribution.sol +23 -11
- package/contracts/distribution/DistributionService.sol +76 -42
- package/contracts/distribution/DistributionServiceManager.sol +8 -11
- package/contracts/distribution/IDistributionComponent.sol +8 -4
- package/contracts/distribution/IDistributionService.sol +18 -2
- 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/{BundleManager.sol → BundleSet.sol} +23 -23
- package/contracts/instance/IInstance.sol +11 -34
- package/contracts/instance/IInstanceService.sol +5 -5
- package/contracts/instance/Instance.sol +13 -38
- package/contracts/instance/InstanceAdmin.sol +31 -9
- package/contracts/instance/InstanceAuthorizationV3.sol +16 -14
- package/contracts/instance/InstanceReader.sol +115 -25
- package/contracts/instance/InstanceService.sol +71 -49
- package/contracts/instance/InstanceServiceManager.sol +8 -13
- package/contracts/instance/InstanceStore.sol +12 -1
- package/contracts/instance/base/ObjectLifecycle.sol +9 -4
- package/contracts/instance/base/{ObjectManager.sol → ObjectSet.sol} +5 -5
- package/contracts/instance/module/IBundle.sol +1 -1
- package/contracts/instance/module/IComponents.sol +4 -8
- package/contracts/instance/module/IDistribution.sol +0 -1
- package/contracts/instance/module/IPolicy.sol +24 -24
- package/contracts/mock/Dip.sol +1 -1
- package/contracts/oracle/IOracleComponent.sol +2 -1
- package/contracts/oracle/Oracle.sol +17 -7
- package/contracts/oracle/OracleService.sol +11 -8
- package/contracts/oracle/OracleServiceManager.sol +8 -11
- package/contracts/pool/BasicPool.sol +7 -5
- package/contracts/pool/BasicPoolAuthorization.sol +11 -2
- package/contracts/pool/BundleService.sol +221 -56
- package/contracts/pool/BundleServiceManager.sol +8 -11
- package/contracts/pool/IBundleService.sol +42 -5
- package/contracts/pool/IPoolComponent.sol +24 -8
- package/contracts/pool/IPoolService.sol +57 -36
- package/contracts/pool/Pool.sol +72 -30
- package/contracts/pool/PoolService.sol +240 -129
- package/contracts/pool/PoolServiceManager.sol +6 -9
- package/contracts/product/ApplicationService.sol +62 -65
- package/contracts/product/ApplicationServiceManager.sol +6 -6
- package/contracts/product/BasicProduct.sol +3 -32
- package/contracts/product/BasicProductAuthorization.sol +3 -0
- package/contracts/product/ClaimService.sol +254 -115
- package/contracts/product/ClaimServiceManager.sol +6 -6
- package/contracts/product/IApplicationService.sol +1 -0
- package/contracts/product/IClaimService.sol +31 -7
- package/contracts/product/IPolicyService.sol +34 -32
- package/contracts/product/IPricingService.sol +7 -7
- package/contracts/product/IProductComponent.sol +18 -4
- package/contracts/product/{IProductService.sol → IRiskService.sol} +1 -1
- package/contracts/product/PolicyService.sol +404 -193
- package/contracts/product/PolicyServiceManager.sol +6 -9
- package/contracts/product/PricingService.sol +46 -46
- package/contracts/product/PricingServiceManager.sol +5 -8
- package/contracts/product/Product.sol +90 -50
- package/contracts/product/{ProductService.sol → RiskService.sol} +13 -41
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +65 -32
- package/contracts/registry/IRegistry.sol +65 -19
- package/contracts/registry/IRegistryService.sol +0 -9
- package/contracts/registry/Registry.sol +340 -211
- package/contracts/registry/RegistryAdmin.sol +155 -72
- package/contracts/registry/RegistryService.sol +59 -66
- package/contracts/registry/RegistryServiceManager.sol +4 -4
- package/contracts/registry/ReleaseLifecycle.sol +6 -3
- package/contracts/registry/ReleaseRegistry.sol +496 -0
- package/contracts/registry/ServiceAuthorizationV3.sol +13 -15
- package/contracts/registry/TokenRegistry.sol +2 -2
- package/contracts/shared/Component.sol +38 -43
- package/contracts/shared/ComponentService.sol +88 -28
- package/contracts/shared/ComponentServiceManager.sol +10 -7
- package/contracts/shared/ComponentVerifyingService.sol +2 -3
- package/contracts/shared/ContractLib.sol +38 -0
- package/contracts/shared/IComponent.sol +7 -4
- package/contracts/shared/IComponentService.sol +15 -9
- package/contracts/shared/IInstanceLinkedComponent.sol +9 -10
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IService.sol +1 -1
- package/contracts/shared/{ERC165.sol → InitializableERC165.sol} +3 -3
- package/contracts/shared/InstanceLinkedComponent.sol +26 -6
- package/contracts/shared/KeyValueStore.sol +1 -1
- package/contracts/shared/Lifecycle.sol +13 -2
- package/contracts/shared/{NftIdSetManager.sol → NftIdSet.sol} +1 -1
- package/contracts/shared/NftOwnable.sol +7 -7
- package/contracts/shared/PolicyHolder.sol +17 -57
- package/contracts/shared/Registerable.sol +4 -4
- package/contracts/shared/RegistryLinked.sol +3 -2
- package/contracts/shared/Service.sol +19 -15
- package/contracts/shared/TokenHandler.sol +100 -19
- package/contracts/shared/TokenHandlerDeployerLib.sol +12 -0
- package/contracts/staking/IStaking.sol +3 -3
- package/contracts/staking/IStakingService.sol +12 -5
- package/contracts/staking/StakeManagerLib.sol +18 -25
- package/contracts/staking/Staking.sol +27 -42
- package/contracts/staking/StakingManager.sol +10 -12
- package/contracts/staking/StakingReader.sol +23 -20
- package/contracts/staking/StakingService.sol +10 -14
- package/contracts/staking/StakingServiceManager.sol +4 -4
- package/contracts/staking/StakingStore.sol +12 -22
- package/contracts/staking/TargetManagerLib.sol +7 -3
- package/contracts/type/Amount.sol +27 -5
- 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 +19 -18
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/Referral.sol +1 -0
- 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 +33 -10
- package/contracts/type/Version.sol +3 -1
- package/contracts/{shared → upgradeability}/ProxyManager.sol +70 -38
- package/contracts/{shared → upgradeability}/UpgradableProxyWithAdmin.sol +1 -3
- package/contracts/{shared → upgradeability}/Versionable.sol +2 -2
- package/package.json +2 -1
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +0 -4
- package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +0 -703
- package/artifacts/contracts/instance/base/ObjectManager.sol/ObjectManager.dbg.json +0 -4
- 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/registry/ReleaseManager.sol/ReleaseManager.dbg.json +0 -4
- package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +0 -1159
- 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/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/shared/NftIdSetManager.sol/NftIdSetManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +0 -4
- package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +0 -617
- package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +0 -4
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
- package/contracts/product/ProductServiceManager.sol +0 -42
- package/contracts/registry/ReleaseManager.sol +0 -487
- package/contracts/shared/InitializableCustom.sol +0 -177
- /package/contracts/{shared → upgradeability}/IVersionable.sol +0 -0
| @@ -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,13 +110,15 @@ abstract contract Pool is | |
| 84 110 | 
             
                    return true;
         | 
| 85 111 | 
             
                }
         | 
| 86 112 |  | 
| 87 | 
            -
             | 
| 88 | 
            -
                function  | 
| 89 | 
            -
                    external
         | 
| 113 | 
            +
                /// @inheritdoc IPoolComponent
         | 
| 114 | 
            +
                function withdrawBundleFees(NftId bundleNftId, Amount amount) 
         | 
| 115 | 
            +
                    external 
         | 
| 90 116 | 
             
                    virtual
         | 
| 91 | 
            -
                     | 
| 117 | 
            +
                    restricted()
         | 
| 118 | 
            +
                    onlyBundleOwner(bundleNftId)
         | 
| 119 | 
            +
                    returns (Amount withdrawnAmount) 
         | 
| 92 120 | 
             
                {
         | 
| 93 | 
            -
                     | 
| 121 | 
            +
                    return _withdrawBundleFees(bundleNftId, amount);
         | 
| 94 122 | 
             
                }
         | 
| 95 123 |  | 
| 96 124 |  | 
| @@ -100,19 +128,16 @@ abstract contract Pool is | |
| 100 128 | 
             
                    view 
         | 
| 101 129 | 
             
                    returns (IComponents.PoolInfo memory poolInfo)
         | 
| 102 130 | 
             
                {
         | 
| 103 | 
            -
                    return IComponents.PoolInfo(
         | 
| 104 | 
            -
                         | 
| 105 | 
            -
                        PUBLIC_ROLE(),  | 
| 106 | 
            -
                         | 
| 107 | 
            -
                         | 
| 108 | 
            -
                        false, | 
| 109 | 
            -
                        false, | 
| 110 | 
            -
                        UFixedLib.toUFixed(1), | 
| 111 | 
            -
                        UFixedLib.toUFixed(1) | 
| 112 | 
            -
             | 
| 113 | 
            -
                        FeeLib.zero(), // initialStakingFee,
         | 
| 114 | 
            -
                        FeeLib.zero() // initialPerformanceFee,
         | 
| 115 | 
            -
                    );
         | 
| 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 | 
            +
                    });
         | 
| 116 141 | 
             
                }
         | 
| 117 142 |  | 
| 118 143 | 
             
                // Internals
         | 
| @@ -149,7 +174,7 @@ abstract contract Pool is | |
| 149 174 | 
             
                    $._bundleService = IBundleService(_getServiceAddress(BUNDLE()));
         | 
| 150 175 | 
             
                    $._componentService = IComponentService(_getServiceAddress(COMPONENT())); 
         | 
| 151 176 |  | 
| 152 | 
            -
                     | 
| 177 | 
            +
                    _registerInterface(type(IPoolComponent).interfaceId);
         | 
| 153 178 | 
             
                }
         | 
| 154 179 |  | 
| 155 180 | 
             
                /// @dev increases the staked tokens by the specified amount
         | 
| @@ -160,8 +185,9 @@ abstract contract Pool is | |
| 160 185 | 
             
                )
         | 
| 161 186 | 
             
                    internal
         | 
| 162 187 | 
             
                    virtual
         | 
| 188 | 
            +
                    returns(Amount) 
         | 
| 163 189 | 
             
                {
         | 
| 164 | 
            -
                     | 
| 190 | 
            +
                    return _getPoolStorage()._poolService.stake(bundleNftId, amount);
         | 
| 165 191 | 
             
                }
         | 
| 166 192 |  | 
| 167 193 |  | 
| @@ -173,8 +199,9 @@ abstract contract Pool is | |
| 173 199 | 
             
                )
         | 
| 174 200 | 
             
                    internal
         | 
| 175 201 | 
             
                    virtual
         | 
| 202 | 
            +
                    returns(Amount netAmount) 
         | 
| 176 203 | 
             
                {
         | 
| 177 | 
            -
                     | 
| 204 | 
            +
                    return _getPoolStorage()._poolService.unstake(bundleNftId, amount);
         | 
| 178 205 | 
             
                }
         | 
| 179 206 |  | 
| 180 207 |  | 
| @@ -186,8 +213,9 @@ abstract contract Pool is | |
| 186 213 | 
             
                )
         | 
| 187 214 | 
             
                    internal
         | 
| 188 215 | 
             
                    virtual
         | 
| 216 | 
            +
                    returns (Timestamp extendedExpiredAt) 
         | 
| 189 217 | 
             
                {
         | 
| 190 | 
            -
                     | 
| 218 | 
            +
                    return _getPoolStorage()._bundleService.extend(bundleNftId, lifetimeExtension);
         | 
| 191 219 | 
             
                }
         | 
| 192 220 |  | 
| 193 221 |  | 
| @@ -217,7 +245,7 @@ abstract contract Pool is | |
| 217 245 | 
             
                /// To close a bundle all all linked policies MUST be in closed state as well.
         | 
| 218 246 | 
             
                /// Closing a bundle finalizes the bundle bookkeeping including overall profit calculation.
         | 
| 219 247 | 
             
                /// Once a bundle is closed this action cannot be reversed.
         | 
| 220 | 
            -
                function  | 
| 248 | 
            +
                function _closeBundle(NftId bundleNftId)
         | 
| 221 249 | 
             
                    internal
         | 
| 222 250 | 
             
                    virtual
         | 
| 223 251 | 
             
                {
         | 
| @@ -239,13 +267,13 @@ abstract contract Pool is | |
| 239 267 | 
             
                }
         | 
| 240 268 |  | 
| 241 269 |  | 
| 242 | 
            -
                /// @dev Sets the maximum  | 
| 270 | 
            +
                /// @dev Sets the maximum balance amound held by this pool.
         | 
| 243 271 | 
             
                /// Function may only be called by pool owner.
         | 
| 244 | 
            -
                function  | 
| 272 | 
            +
                function _setMaxBalanceAmount(Amount maxBalanceAmount)
         | 
| 245 273 | 
             
                    internal
         | 
| 246 274 | 
             
                    virtual
         | 
| 247 275 | 
             
                {
         | 
| 248 | 
            -
                    _getPoolStorage()._poolService. | 
| 276 | 
            +
                    _getPoolStorage()._poolService.setMaxBalanceAmount(maxBalanceAmount);
         | 
| 249 277 | 
             
                }
         | 
| 250 278 |  | 
| 251 279 | 
             
                /// @dev Sets the required role to create/own bundles.
         | 
| @@ -275,11 +303,10 @@ abstract contract Pool is | |
| 275 303 | 
             
                    _getPoolStorage()._componentService.setPoolFees(poolFee, stakingFee, performanceFee);
         | 
| 276 304 | 
             
                }
         | 
| 277 305 |  | 
| 278 | 
            -
                /// @dev Creates a new bundle using the provided parameter values.
         | 
| 306 | 
            +
                /// @dev Creates a new empty bundle using the provided parameter values.
         | 
| 279 307 | 
             
                function _createBundle(
         | 
| 280 308 | 
             
                    address bundleOwner,
         | 
| 281 309 | 
             
                    Fee memory fee,
         | 
| 282 | 
            -
                    Amount amount,
         | 
| 283 310 | 
             
                    Seconds lifetime, 
         | 
| 284 311 | 
             
                    bytes memory filter
         | 
| 285 312 | 
             
                )
         | 
| @@ -289,19 +316,34 @@ abstract contract Pool is | |
| 289 316 | 
             
                    bundleNftId = _getPoolStorage()._poolService.createBundle(
         | 
| 290 317 | 
             
                        bundleOwner,
         | 
| 291 318 | 
             
                        fee,
         | 
| 292 | 
            -
                        amount,
         | 
| 293 319 | 
             
                        lifetime,
         | 
| 294 320 | 
             
                        filter);
         | 
| 295 321 |  | 
| 296 322 | 
             
                    // TODO add logging
         | 
| 297 323 | 
             
                }
         | 
| 298 324 |  | 
| 299 | 
            -
             | 
| 300 325 | 
             
                // TODO remove function once this is no longer used to produce contract locations on the fly ...
         | 
| 301 326 | 
             
                function getContractLocation(bytes memory name) external pure returns (bytes32 hash) {
         | 
| 302 327 | 
             
                    return keccak256(abi.encode(uint256(keccak256(name)) - 1)) & ~bytes32(uint256(0xff));
         | 
| 303 328 | 
             
                }
         | 
| 304 329 |  | 
| 330 | 
            +
                function _withdrawBundleFees(NftId bundleNftId, Amount amount) 
         | 
| 331 | 
            +
                    internal
         | 
| 332 | 
            +
                    returns (Amount withdrawnAmount) 
         | 
| 333 | 
            +
                {
         | 
| 334 | 
            +
                    return _getPoolStorage()._bundleService.withdrawBundleFees(bundleNftId, amount);
         | 
| 335 | 
            +
                }
         | 
| 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 | 
            +
                }
         | 
| 305 347 |  | 
| 306 348 | 
             
                function _getPoolStorage() private pure returns (PoolStorage storage $) {
         | 
| 307 349 | 
             
                    assembly {
         |