@etherisc/gif-next 3.0.0-d6cf78d-199 → 3.0.0-f90c901-018
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 +2 -2
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +139 -72
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +110 -116
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +72 -33
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +89 -66
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +122 -101
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +20 -65
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +31 -55
- 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 +20 -10
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +18 -42
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +126 -75
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +41 -65
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +72 -57
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +198 -139
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +140 -150
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +84 -56
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +71 -32
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +166 -104
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +41 -65
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +200 -138
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +41 -65
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +159 -102
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +41 -65
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +163 -106
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +177 -120
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +41 -65
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +171 -114
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +41 -65
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +49 -54
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +77 -25
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +83 -44
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +144 -50
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +169 -147
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +43 -67
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +34 -34
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +138 -75
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +104 -112
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +2 -2
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +2 -2
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +53 -58
- 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/Cloneable.sol/Cloneable.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +2 -2
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +3 -8
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +2 -2
- package/artifacts/contracts/instance/module/IBundle.sol/IBundle.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IComponents.sol/IComponents.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IDistribution.sol/IDistribution.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IPolicy.sol/IPolicy.dbg.json +1 -1
- package/artifacts/contracts/instance/module/IRisk.sol/IRisk.dbg.json +1 -1
- package/artifacts/contracts/mock/Dip.sol/Dip.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracle.sol/BasicOracle.json +132 -81
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +41 -65
- package/artifacts/contracts/oracle/IOracle.sol/IOracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleComponent.sol/IOracleComponent.json +94 -66
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +80 -83
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +82 -67
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +149 -148
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +111 -129
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +88 -73
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +41 -65
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +176 -117
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +129 -139
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +71 -32
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +100 -72
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +94 -86
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +88 -73
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +24 -247
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +233 -165
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +140 -130
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +138 -63
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +110 -112
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +72 -57
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +41 -65
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +182 -115
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +132 -138
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +71 -32
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +71 -32
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +82 -64
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +82 -43
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +84 -56
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +75 -36
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +173 -127
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +2 -2
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +122 -128
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +161 -94
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +116 -122
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +72 -57
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +146 -63
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +109 -107
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +155 -56
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +202 -216
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +1 -1
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +1 -15
- 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 +314 -96
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +163 -142
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +57 -77
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +285 -244
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +115 -110
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +159 -150
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +2 -2
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +127 -185
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +32 -56
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +13 -29
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +84 -39
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +164 -320
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +115 -141
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +421 -169
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +96 -38
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +82 -226
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +84 -56
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +1 -28
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +1 -12
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +77 -25
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +1 -12
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +71 -32
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +74 -0
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +72 -57
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.dbg.json +1 -1
- package/artifacts/contracts/shared/NftIdSet.sol/NftIdSet.json +2 -2
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +15 -34
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +3 -14
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +76 -24
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +3 -37
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +70 -31
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +42 -29
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +30 -17
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +34 -34
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +74 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +101 -56
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +75 -36
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +170 -109
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +26 -31
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +112 -124
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +5 -22
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +132 -65
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +105 -111
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +212 -204
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +27 -19
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +16 -16
- 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/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +2 -2
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +2 -2
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.dbg.json +1 -1
- package/artifacts/contracts/type/Key32.sol/Key32Lib.json +2 -2
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.dbg.json +1 -1
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +2 -2
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +2 -2
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
- package/artifacts/contracts/type/NftIdSet.sol/LibNftIdSet.json +2 -2
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/ObjectType.sol/ObjectTypeLib.json +4 -4
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +2 -2
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +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 +2 -2
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +4 -4
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +10 -10
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +19 -6
- package/artifacts/contracts/upgradeability/IUpgradeable.sol/IUpgradeable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/{IVersionable.sol/IVersionable.json → IUpgradeable.sol/IUpgradeable.json} +54 -4
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +63 -86
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Upgradeable.sol/Upgradeable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/{Versionable.sol/Versionable.json → Upgradeable.sol/Upgradeable.json} +54 -4
- package/contracts/accounting/AccountingService.sol +5 -6
- package/contracts/accounting/AccountingServiceManager.sol +4 -6
- package/contracts/accounting/IAccountingService.sol +1 -1
- package/contracts/authorization/AccessAdmin.sol +22 -18
- package/contracts/authorization/AccessAdminLib.sol +12 -9
- package/contracts/authorization/AccessManagerCloneable.sol +24 -48
- package/contracts/authorization/Authorization.sol +2 -2
- package/contracts/authorization/IAccessAdmin.sol +3 -3
- package/contracts/authorization/IServiceAuthorization.sol +1 -1
- package/contracts/authorization/ServiceAuthorization.sol +4 -4
- package/contracts/distribution/BasicDistribution.sol +0 -2
- package/contracts/distribution/BasicDistributionAuthorization.sol +5 -4
- package/contracts/distribution/Distribution.sol +0 -2
- package/contracts/distribution/DistributionService.sol +24 -20
- package/contracts/distribution/DistributionServiceManager.sol +4 -6
- package/contracts/examples/fire/FirePool.sol +0 -4
- package/contracts/examples/fire/FireProduct.sol +0 -4
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +0 -4
- package/contracts/examples/unpermissioned/SimpleOracle.sol +0 -4
- package/contracts/examples/unpermissioned/SimplePool.sol +0 -4
- package/contracts/examples/unpermissioned/SimpleProduct.sol +0 -4
- package/contracts/instance/Instance.sol +7 -11
- package/contracts/instance/InstanceAdmin.sol +10 -17
- package/contracts/instance/InstanceAuthorizationV3.sol +4 -2
- package/contracts/instance/InstanceReader.sol +15 -15
- package/contracts/instance/InstanceService.sol +18 -20
- package/contracts/instance/InstanceServiceManager.sol +4 -6
- package/contracts/instance/base/Cloneable.sol +4 -10
- package/contracts/instance/base/ObjectSet.sol +2 -2
- package/contracts/oracle/BasicOracle.sol +0 -2
- package/contracts/oracle/BasicOracleAuthorization.sol +3 -1
- package/contracts/oracle/IOracleService.sol +0 -4
- package/contracts/oracle/Oracle.sol +3 -4
- package/contracts/oracle/OracleService.sol +37 -67
- package/contracts/oracle/OracleServiceManager.sol +4 -6
- package/contracts/pool/BasicPool.sol +2 -4
- package/contracts/pool/BasicPoolAuthorization.sol +5 -4
- package/contracts/pool/BundleService.sol +25 -19
- package/contracts/pool/BundleServiceManager.sol +5 -7
- package/contracts/pool/IPoolService.sol +5 -6
- package/contracts/pool/Pool.sol +1 -3
- package/contracts/pool/PoolLib.sol +5 -102
- package/contracts/pool/PoolService.sol +67 -101
- package/contracts/pool/PoolServiceManager.sol +4 -6
- package/contracts/product/ApplicationService.sol +13 -34
- package/contracts/product/ApplicationServiceManager.sol +4 -6
- package/contracts/product/BasicProduct.sol +0 -2
- package/contracts/product/BasicProductAuthorization.sol +5 -4
- package/contracts/product/ClaimService.sol +10 -34
- package/contracts/product/ClaimServiceManager.sol +5 -7
- package/contracts/product/IPolicyService.sol +0 -1
- package/contracts/product/PolicyService.sol +44 -57
- package/contracts/product/PolicyServiceManager.sol +4 -6
- package/contracts/product/PricingService.sol +7 -8
- package/contracts/product/PricingServiceManager.sol +4 -6
- package/contracts/product/Product.sol +0 -2
- package/contracts/product/RiskService.sol +8 -40
- package/contracts/product/RiskServiceManager.sol +4 -6
- package/contracts/registry/IRegistry.sol +20 -14
- package/contracts/registry/IRegistryService.sol +10 -14
- package/contracts/registry/IRelease.sol +0 -3
- package/contracts/registry/Registry.sol +124 -78
- package/contracts/registry/RegistryAdmin.sol +11 -22
- package/contracts/registry/RegistryAuthorization.sol +4 -3
- package/contracts/registry/RegistryService.sol +99 -82
- package/contracts/registry/RegistryServiceManager.sol +4 -11
- package/contracts/registry/ReleaseAdmin.sol +9 -16
- package/contracts/registry/ReleaseRegistry.sol +64 -74
- package/contracts/registry/ServiceAuthorizationV3.sol +4 -3
- package/contracts/registry/TokenRegistry.sol +6 -15
- package/contracts/shared/Component.sol +27 -22
- package/contracts/shared/ComponentService.sol +45 -130
- package/contracts/shared/ComponentServiceManager.sol +5 -7
- package/contracts/shared/ContractLib.sol +359 -93
- package/contracts/shared/IComponent.sol +5 -3
- package/contracts/shared/IComponentService.sol +0 -14
- package/contracts/shared/IInstanceLinkedComponent.sol +4 -7
- package/contracts/shared/INftOwnable.sol +0 -2
- package/contracts/shared/IRegisterable.sol +14 -3
- package/contracts/shared/IRegistryLinked.sol +1 -3
- package/contracts/shared/IService.sol +2 -2
- package/contracts/shared/IVersionable.sol +19 -0
- package/contracts/shared/InstanceLinkedComponent.sol +32 -82
- package/contracts/shared/NftOwnable.sol +9 -22
- package/contracts/shared/PolicyHolder.sol +2 -4
- package/contracts/shared/Registerable.sol +37 -20
- package/contracts/shared/RegistryLinked.sol +4 -23
- package/contracts/shared/Service.sol +8 -9
- package/contracts/shared/TokenHandler.sol +4 -1
- package/contracts/shared/Versionable.sol +47 -0
- package/contracts/staking/IStaking.sol +2 -2
- package/contracts/staking/Staking.sol +28 -33
- package/contracts/staking/StakingLib.sol +3 -1
- package/contracts/staking/StakingManager.sol +3 -6
- package/contracts/staking/StakingReader.sol +9 -17
- package/contracts/staking/StakingService.sol +16 -13
- package/contracts/staking/StakingServiceManager.sol +4 -8
- package/contracts/staking/StakingStore.sol +8 -8
- package/contracts/staking/TargetHandler.sol +4 -5
- package/contracts/type/Version.sol +15 -16
- package/contracts/upgradeability/{IVersionable.sol → IUpgradeable.sol} +13 -19
- package/contracts/upgradeability/ProxyManager.sol +46 -54
- package/contracts/upgradeability/{Versionable.sol → Upgradeable.sol} +25 -14
- package/package.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +0 -24
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +0 -4
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +0 -40
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +0 -4
@@ -20,8 +20,6 @@ import {KEEP_STATE} from "../type/StateId.sol";
|
|
20
20
|
import {ObjectType, ACCOUNTING, COMPONENT, DISTRIBUTION, INSTANCE, DISTRIBUTION, DISTRIBUTOR, REGISTRY} from "../type/ObjectType.sol";
|
21
21
|
import {InstanceReader} from "../instance/InstanceReader.sol";
|
22
22
|
import {InstanceStore} from "../instance/InstanceStore.sol";
|
23
|
-
// TODO PoolLib feels wrong, should likely go in a component type independent lib
|
24
|
-
import {PoolLib} from "../pool/PoolLib.sol";
|
25
23
|
import {ReferralId, ReferralStatus, ReferralLib, REFERRAL_OK, REFERRAL_ERROR_UNKNOWN, REFERRAL_ERROR_EXPIRED, REFERRAL_ERROR_EXHAUSTED} from "../type/Referral.sol";
|
26
24
|
import {Seconds} from "../type/Seconds.sol";
|
27
25
|
import {Service} from "../shared/Service.sol";
|
@@ -44,14 +42,13 @@ contract DistributionService is
|
|
44
42
|
)
|
45
43
|
internal
|
46
44
|
virtual override
|
47
|
-
|
45
|
+
onlyInitializing()
|
48
46
|
{
|
49
47
|
(
|
50
|
-
address authority
|
51
|
-
|
52
|
-
) = abi.decode(data, (address, address));
|
48
|
+
address authority
|
49
|
+
) = abi.decode(data, (address));
|
53
50
|
|
54
|
-
__Service_init(authority,
|
51
|
+
__Service_init(authority, owner);
|
55
52
|
|
56
53
|
_accountingService = IAccountingService(_getServiceAddress(ACCOUNTING()));
|
57
54
|
_componentService = IComponentService(_getServiceAddress(COMPONENT()));
|
@@ -81,7 +78,7 @@ contract DistributionService is
|
|
81
78
|
(NftId distributionNftId, IInstance instance) = _getAndVerifyActiveDistribution();
|
82
79
|
|
83
80
|
{
|
84
|
-
NftId productNftId =
|
81
|
+
NftId productNftId = _getRegistry().getParentNftId(distributionNftId);
|
85
82
|
IComponents.FeeInfo memory feeInfo = instance.getInstanceReader().getFeeInfo(productNftId);
|
86
83
|
|
87
84
|
UFixed variableDistributionFees = feeInfo.distributionFee.fractionalFee;
|
@@ -134,11 +131,12 @@ contract DistributionService is
|
|
134
131
|
NftIdLib.zero(),
|
135
132
|
distributionNftId,
|
136
133
|
DISTRIBUTOR(),
|
134
|
+
getRelease(),
|
137
135
|
true, // intercepting property for bundles is defined on pool
|
138
|
-
address(0),
|
139
|
-
|
140
|
-
|
141
|
-
|
136
|
+
address(0)),
|
137
|
+
distributor,
|
138
|
+
""
|
139
|
+
);
|
142
140
|
|
143
141
|
IDistribution.DistributorInfo memory info = IDistribution.DistributorInfo({
|
144
142
|
distributorType: distributorType,
|
@@ -197,9 +195,11 @@ contract DistributionService is
|
|
197
195
|
revert ErrorDistributionServiceExpirationInvalid(expiryAt);
|
198
196
|
}
|
199
197
|
|
200
|
-
|
201
|
-
|
202
|
-
|
198
|
+
{
|
199
|
+
NftId distributorDistributionNftId = _getRegistry().getParentNftId(distributorNftId);
|
200
|
+
if (distributorDistributionNftId != distributionNftId) {
|
201
|
+
revert ErrorDistributionServiceDistributorDistributionMismatch(distributorNftId, distributorDistributionNftId, distributionNftId);
|
202
|
+
}
|
203
203
|
}
|
204
204
|
|
205
205
|
{
|
@@ -251,7 +251,7 @@ contract DistributionService is
|
|
251
251
|
onlyNftOfType(distributionNftId, DISTRIBUTION())
|
252
252
|
{
|
253
253
|
if (referralIsValid(distributionNftId, referralId)) {
|
254
|
-
IInstance instance = IInstance(ContractLib.getInstanceForComponent(
|
254
|
+
IInstance instance = IInstance(ContractLib.getInstanceForComponent(distributionNftId));
|
255
255
|
|
256
256
|
// update book keeping for referral info
|
257
257
|
IDistribution.ReferralInfo memory referralInfo = instance.getInstanceReader().getReferralInfo(referralId);
|
@@ -272,7 +272,7 @@ contract DistributionService is
|
|
272
272
|
restricted()
|
273
273
|
onlyNftOfType(distributionNftId, DISTRIBUTION())
|
274
274
|
{
|
275
|
-
IInstance instance = IInstance(ContractLib.getInstanceForComponent(
|
275
|
+
IInstance instance = IInstance(ContractLib.getInstanceForComponent(distributionNftId));
|
276
276
|
InstanceReader reader = instance.getInstanceReader();
|
277
277
|
InstanceStore store = instance.getInstanceStore();
|
278
278
|
|
@@ -340,7 +340,7 @@ contract DistributionService is
|
|
340
340
|
|
341
341
|
// transfer amount to distributor
|
342
342
|
{
|
343
|
-
address distributor =
|
343
|
+
address distributor = _getRegistry().ownerOf(distributorNftId);
|
344
344
|
emit LogDistributionServiceCommissionWithdrawn(distributorNftId, distributor, address(distributionInfo.tokenHandler.TOKEN()), withdrawnAmount);
|
345
345
|
distributionInfo.tokenHandler.pushToken(distributor, withdrawnAmount);
|
346
346
|
}
|
@@ -357,7 +357,7 @@ contract DistributionService is
|
|
357
357
|
return false;
|
358
358
|
}
|
359
359
|
|
360
|
-
IInstance instance = IInstance(ContractLib.getInstanceForComponent(
|
360
|
+
IInstance instance = IInstance(ContractLib.getInstanceForComponent(distributionNftId));
|
361
361
|
IDistribution.ReferralInfo memory info = instance.getInstanceReader().getReferralInfo(referralId);
|
362
362
|
|
363
363
|
if (info.distributorNftId.eqz()) {
|
@@ -438,7 +438,11 @@ contract DistributionService is
|
|
438
438
|
IInstance instance
|
439
439
|
)
|
440
440
|
{
|
441
|
-
|
441
|
+
(poolNftId, instance) = ContractLib.getAndVerifyComponent(
|
442
|
+
msg.sender,
|
443
|
+
DISTRIBUTION(),
|
444
|
+
getRelease(),
|
445
|
+
true);
|
442
446
|
}
|
443
447
|
|
444
448
|
|
@@ -1,7 +1,7 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
4
|
+
import {IUpgradeable} from "../upgradeability/IUpgradeable.sol";
|
5
5
|
import {ProxyManager} from "../upgradeability/ProxyManager.sol";
|
6
6
|
import {DistributionService} from "./DistributionService.sol";
|
7
7
|
|
@@ -12,19 +12,17 @@ contract DistributionServiceManager is ProxyManager {
|
|
12
12
|
/// @dev initializes proxy manager with distribution service implementation and deploys instance
|
13
13
|
constructor(
|
14
14
|
address authority,
|
15
|
-
address registry,
|
16
15
|
bytes32 salt
|
17
16
|
)
|
18
17
|
{
|
19
18
|
DistributionService svc = new DistributionService{salt: salt}();
|
20
|
-
bytes memory data = abi.encode(authority
|
21
|
-
|
22
|
-
registry,
|
19
|
+
bytes memory data = abi.encode(authority);
|
20
|
+
IUpgradeable upgradeable = initialize(
|
23
21
|
address(svc),
|
24
22
|
data,
|
25
23
|
salt);
|
26
24
|
|
27
|
-
_distributionService = DistributionService(address(
|
25
|
+
_distributionService = DistributionService(address(upgradeable));
|
28
26
|
}
|
29
27
|
|
30
28
|
//--- view functions ----------------------------------------------------//
|
@@ -16,7 +16,6 @@ contract FirePool is
|
|
16
16
|
BasicPool
|
17
17
|
{
|
18
18
|
constructor(
|
19
|
-
address registry,
|
20
19
|
NftId fireProductNftId,
|
21
20
|
string memory componentName,
|
22
21
|
IAuthorization authorization
|
@@ -24,7 +23,6 @@ contract FirePool is
|
|
24
23
|
{
|
25
24
|
address initialOwner = msg.sender;
|
26
25
|
_intialize(
|
27
|
-
registry,
|
28
26
|
fireProductNftId,
|
29
27
|
componentName,
|
30
28
|
IComponents.PoolInfo({
|
@@ -41,7 +39,6 @@ contract FirePool is
|
|
41
39
|
}
|
42
40
|
|
43
41
|
function _intialize(
|
44
|
-
address registry,
|
45
42
|
NftId fireProductNftId,
|
46
43
|
string memory componentName,
|
47
44
|
IComponents.PoolInfo memory poolInfo,
|
@@ -52,7 +49,6 @@ contract FirePool is
|
|
52
49
|
initializer
|
53
50
|
{
|
54
51
|
_initializeBasicPool(
|
55
|
-
registry,
|
56
52
|
fireProductNftId,
|
57
53
|
componentName,
|
58
54
|
poolInfo,
|
@@ -65,7 +65,6 @@ contract FireProduct is
|
|
65
65
|
mapping(uint256 fireId => mapping (NftId policyId => bool claimed)) private _claimed;
|
66
66
|
|
67
67
|
constructor(
|
68
|
-
address registry,
|
69
68
|
NftId instanceNftid,
|
70
69
|
string memory componentName,
|
71
70
|
IAuthorization authorization
|
@@ -74,7 +73,6 @@ contract FireProduct is
|
|
74
73
|
address initialOwner = msg.sender;
|
75
74
|
|
76
75
|
_initialize(
|
77
|
-
registry,
|
78
76
|
instanceNftid,
|
79
77
|
componentName,
|
80
78
|
authorization,
|
@@ -82,7 +80,6 @@ contract FireProduct is
|
|
82
80
|
}
|
83
81
|
|
84
82
|
function _initialize(
|
85
|
-
address registry,
|
86
83
|
NftId instanceNftId,
|
87
84
|
string memory componentName,
|
88
85
|
IAuthorization authorization,
|
@@ -92,7 +89,6 @@ contract FireProduct is
|
|
92
89
|
initializer
|
93
90
|
{
|
94
91
|
_initializeBasicProduct(
|
95
|
-
registry,
|
96
92
|
instanceNftId,
|
97
93
|
componentName,
|
98
94
|
IComponents.ProductInfo({
|
@@ -17,14 +17,12 @@ contract SimpleDistribution is
|
|
17
17
|
{
|
18
18
|
|
19
19
|
constructor(
|
20
|
-
address registry,
|
21
20
|
NftId productNftId,
|
22
21
|
IAuthorization authorization,
|
23
22
|
address initialOwner
|
24
23
|
)
|
25
24
|
{
|
26
25
|
initialize(
|
27
|
-
registry,
|
28
26
|
productNftId,
|
29
27
|
authorization,
|
30
28
|
initialOwner,
|
@@ -32,7 +30,6 @@ contract SimpleDistribution is
|
|
32
30
|
}
|
33
31
|
|
34
32
|
function initialize(
|
35
|
-
address registry,
|
36
33
|
NftId productNftId,
|
37
34
|
IAuthorization authorization,
|
38
35
|
address initialOwner,
|
@@ -43,7 +40,6 @@ contract SimpleDistribution is
|
|
43
40
|
initializer()
|
44
41
|
{
|
45
42
|
_initializeBasicDistribution(
|
46
|
-
registry,
|
47
43
|
productNftId,
|
48
44
|
authorization,
|
49
45
|
initialOwner,
|
@@ -31,14 +31,12 @@ contract SimpleOracle is
|
|
31
31
|
event LogSimpleOracleSyncResponseSent(RequestId requestId, string responseText);
|
32
32
|
|
33
33
|
constructor(
|
34
|
-
address registry,
|
35
34
|
NftId productNftId,
|
36
35
|
IAuthorization authorization,
|
37
36
|
address initialOwner
|
38
37
|
)
|
39
38
|
{
|
40
39
|
initialize(
|
41
|
-
registry,
|
42
40
|
productNftId,
|
43
41
|
authorization,
|
44
42
|
initialOwner,
|
@@ -47,7 +45,6 @@ contract SimpleOracle is
|
|
47
45
|
}
|
48
46
|
|
49
47
|
function initialize(
|
50
|
-
address registry,
|
51
48
|
NftId productNftId,
|
52
49
|
IAuthorization authorization,
|
53
50
|
address initialOwner,
|
@@ -58,7 +55,6 @@ contract SimpleOracle is
|
|
58
55
|
initializer()
|
59
56
|
{
|
60
57
|
_initializeBasicOracle(
|
61
|
-
registry,
|
62
58
|
productNftId,
|
63
59
|
authorization,
|
64
60
|
initialOwner,
|
@@ -17,7 +17,6 @@ contract SimplePool is
|
|
17
17
|
{
|
18
18
|
|
19
19
|
constructor(
|
20
|
-
address registry,
|
21
20
|
NftId productNftId,
|
22
21
|
IComponents.PoolInfo memory poolInfo,
|
23
22
|
IAuthorization authorization,
|
@@ -25,7 +24,6 @@ contract SimplePool is
|
|
25
24
|
)
|
26
25
|
{
|
27
26
|
initialize(
|
28
|
-
registry,
|
29
27
|
productNftId,
|
30
28
|
poolInfo,
|
31
29
|
authorization,
|
@@ -35,7 +33,6 @@ contract SimplePool is
|
|
35
33
|
|
36
34
|
|
37
35
|
function initialize(
|
38
|
-
address registry,
|
39
36
|
NftId productNftId,
|
40
37
|
IComponents.PoolInfo memory poolInfo,
|
41
38
|
IAuthorization authorization,
|
@@ -46,7 +43,6 @@ contract SimplePool is
|
|
46
43
|
initializer()
|
47
44
|
{
|
48
45
|
_initializeBasicPool(
|
49
|
-
registry,
|
50
46
|
productNftId,
|
51
47
|
"SimplePool",
|
52
48
|
poolInfo,
|
@@ -34,7 +34,6 @@ contract SimpleProduct is
|
|
34
34
|
IOracleService private _oracleService;
|
35
35
|
|
36
36
|
constructor(
|
37
|
-
address registry,
|
38
37
|
NftId instanceNftId,
|
39
38
|
string memory name,
|
40
39
|
IComponents.ProductInfo memory productInfo,
|
@@ -44,7 +43,6 @@ contract SimpleProduct is
|
|
44
43
|
)
|
45
44
|
{
|
46
45
|
initialize(
|
47
|
-
registry,
|
48
46
|
instanceNftId,
|
49
47
|
name,
|
50
48
|
productInfo,
|
@@ -55,7 +53,6 @@ contract SimpleProduct is
|
|
55
53
|
|
56
54
|
|
57
55
|
function initialize(
|
58
|
-
address registry,
|
59
56
|
NftId instanceNftid,
|
60
57
|
string memory name,
|
61
58
|
IComponents.ProductInfo memory productInfo,
|
@@ -68,7 +65,6 @@ contract SimpleProduct is
|
|
68
65
|
initializer()
|
69
66
|
{
|
70
67
|
_initializeBasicProduct(
|
71
|
-
registry,
|
72
68
|
instanceNftid,
|
73
69
|
name,
|
74
70
|
productInfo,
|
@@ -26,8 +26,6 @@ contract Instance is
|
|
26
26
|
IInstance,
|
27
27
|
Registerable
|
28
28
|
{
|
29
|
-
bool private _initialized;
|
30
|
-
|
31
29
|
IComponentService internal _componentService;
|
32
30
|
IInstanceService internal _instanceService;
|
33
31
|
|
@@ -59,8 +57,6 @@ contract Instance is
|
|
59
57
|
|
60
58
|
function initialize(
|
61
59
|
InstanceContracts memory instanceContracts,
|
62
|
-
IRegistry registry,
|
63
|
-
VersionPart release,
|
64
60
|
address initialOwner,
|
65
61
|
bool tokenRegistryDisabled // only disable for testing
|
66
62
|
)
|
@@ -74,9 +70,9 @@ contract Instance is
|
|
74
70
|
_instanceAdmin = instanceContracts.instanceAdmin;
|
75
71
|
|
76
72
|
// setup instance object info
|
73
|
+
IRegistry registry = _getRegistry();
|
77
74
|
__Registerable_init({
|
78
75
|
authority: instanceContracts.instanceAdmin.authority(),
|
79
|
-
registry: address(registry),
|
80
76
|
parentNftId: registry.getNftId(),
|
81
77
|
objectType: INSTANCE(),
|
82
78
|
isInterceptor: false,
|
@@ -93,19 +89,19 @@ contract Instance is
|
|
93
89
|
// initialize instance supporting contracts
|
94
90
|
_instanceStore.initialize();
|
95
91
|
_productStore.initialize();
|
96
|
-
_bundleSet.initialize(instanceContracts.instanceAdmin.authority()
|
97
|
-
_riskSet.initialize(instanceContracts.instanceAdmin.authority()
|
92
|
+
_bundleSet.initialize(instanceContracts.instanceAdmin.authority());
|
93
|
+
_riskSet.initialize(instanceContracts.instanceAdmin.authority());
|
98
94
|
_instanceReader.initialize();
|
99
95
|
|
100
96
|
_componentService = IComponentService(
|
101
|
-
|
97
|
+
registry.getServiceAddress(
|
102
98
|
COMPONENT(),
|
103
|
-
|
99
|
+
getRelease()));
|
104
100
|
|
105
101
|
_instanceService = IInstanceService(
|
106
|
-
|
102
|
+
registry.getServiceAddress(
|
107
103
|
INSTANCE(),
|
108
|
-
|
104
|
+
getRelease()));
|
109
105
|
|
110
106
|
_tokenRegistryDisabled = tokenRegistryDisabled;
|
111
107
|
|
@@ -11,9 +11,10 @@ import {AccessAdminLib} from "../authorization/AccessAdminLib.sol";
|
|
11
11
|
import {AccessManagerCloneable} from "../authorization/AccessManagerCloneable.sol";
|
12
12
|
import {ObjectType, INSTANCE} from "../type/ObjectType.sol";
|
13
13
|
import {RoleId, ADMIN_ROLE} from "../type/RoleId.sol";
|
14
|
+
import {GIF_INITIAL_RELEASE} from "../registry/Registry.sol";
|
14
15
|
import {Str} from "../type/String.sol";
|
15
|
-
import {VersionPart} from "../type/Version.sol";
|
16
16
|
import {INSTANCE_TARGET_NAME, INSTANCE_ADMIN_TARGET_NAME, INSTANCE_STORE_TARGET_NAME, PRODUCT_STORE_TARGET_NAME, BUNDLE_SET_TARGET_NAME, RISK_SET_TARGET_NAME} from "./TargetNames.sol";
|
17
|
+
import {VersionPart} from "../type/Version.sol";
|
17
18
|
|
18
19
|
|
19
20
|
contract InstanceAdmin is
|
@@ -26,13 +27,12 @@ contract InstanceAdmin is
|
|
26
27
|
error ErrorInstanceAdminNotComponentOrCustomTarget(address target);
|
27
28
|
|
28
29
|
IInstance internal _instance;
|
29
|
-
IRegistry internal _registry;
|
30
30
|
|
31
31
|
uint64 internal _customRoleIdNext;
|
32
32
|
|
33
33
|
|
34
34
|
modifier onlyInstanceService() {
|
35
|
-
if (msg.sender !=
|
35
|
+
if (msg.sender != _getRegistry().getServiceAddress(INSTANCE(), getRelease())) {
|
36
36
|
revert ErrorInstanceAdminNotInstanceService(msg.sender);
|
37
37
|
}
|
38
38
|
_;
|
@@ -43,7 +43,8 @@ contract InstanceAdmin is
|
|
43
43
|
constructor(address accessManager) {
|
44
44
|
initialize(
|
45
45
|
accessManager,
|
46
|
-
"MasterInstanceAdmin"
|
46
|
+
"MasterInstanceAdmin",
|
47
|
+
GIF_INITIAL_RELEASE());
|
47
48
|
}
|
48
49
|
|
49
50
|
|
@@ -51,32 +52,23 @@ contract InstanceAdmin is
|
|
51
52
|
/// Important: Initialization of instance admin is only complete after calling this function.
|
52
53
|
/// Important: The instance MUST be registered and all instance supporting contracts must be wired to this instance.
|
53
54
|
function completeSetup(
|
54
|
-
address registry,
|
55
55
|
address authorization,
|
56
|
-
VersionPart release,
|
57
56
|
address instance
|
58
57
|
)
|
59
58
|
external
|
60
|
-
reinitializer(uint64(release.toInt()))
|
61
59
|
{
|
62
60
|
// checks
|
63
|
-
AccessAdminLib.checkIsRegistered(
|
61
|
+
AccessAdminLib.checkIsRegistered(instance, INSTANCE(), getRelease());
|
64
62
|
|
65
63
|
// effects
|
66
|
-
AccessManagerCloneable(
|
67
|
-
authority()).completeSetup(
|
68
|
-
registry,
|
69
|
-
release);
|
70
|
-
|
71
64
|
AccessAdminLib.checkAuthorization(
|
72
65
|
address(_authorization),
|
73
66
|
authorization,
|
74
67
|
INSTANCE(), // expectedDomain
|
75
|
-
|
68
|
+
getRelease(), // expectedRelease
|
76
69
|
false, // expectServiceAuthorization
|
77
70
|
true); // checkAlreadyInitialized
|
78
71
|
|
79
|
-
_registry = IRegistry(registry);
|
80
72
|
_instance = IInstance(instance);
|
81
73
|
_authorization = IAuthorization(authorization);
|
82
74
|
_customRoleIdNext = 0;
|
@@ -105,7 +97,7 @@ contract InstanceAdmin is
|
|
105
97
|
for(uint256 i = 0; i < serviceDomains.length; i++) {
|
106
98
|
ObjectType serviceDomain = serviceDomains[i];
|
107
99
|
RoleId serviceRoleId = authorization.getServiceRole(serviceDomain);
|
108
|
-
address service =
|
100
|
+
address service = _getRegistry().getServiceAddress(serviceDomain, getRelease());
|
109
101
|
|
110
102
|
_grantRoleToAccount(
|
111
103
|
serviceRoleId,
|
@@ -135,7 +127,8 @@ contract InstanceAdmin is
|
|
135
127
|
/// Important: The component MUST be registered.
|
136
128
|
function initializeComponentAuthorization(
|
137
129
|
address componentAddress,
|
138
|
-
ObjectType expectedType
|
130
|
+
ObjectType expectedType,
|
131
|
+
VersionPart expectedRelease
|
139
132
|
)
|
140
133
|
external
|
141
134
|
restricted()
|
@@ -13,7 +13,9 @@ import {InstanceStore} from "../instance/InstanceStore.sol";
|
|
13
13
|
import {INSTANCE_TARGET_NAME, INSTANCE_ADMIN_TARGET_NAME, INSTANCE_STORE_TARGET_NAME, PRODUCT_STORE_TARGET_NAME, BUNDLE_SET_TARGET_NAME, RISK_SET_TARGET_NAME} from "./TargetNames.sol";
|
14
14
|
import {ProductStore} from "../instance/ProductStore.sol";
|
15
15
|
import {ADMIN_ROLE, INSTANCE_OWNER_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
|
16
|
-
import {
|
16
|
+
import {GIF_INITIAL_RELEASE} from "../registry/Registry.sol";
|
17
|
+
import {RiskSet} from "../instance/RiskSet.sol";
|
18
|
+
import {VersionPartLib} from "../type/Version.sol";
|
17
19
|
|
18
20
|
|
19
21
|
contract InstanceAuthorizationV3
|
@@ -27,7 +29,7 @@ contract InstanceAuthorizationV3
|
|
27
29
|
Authorization(
|
28
30
|
INSTANCE_TARGET_NAME,
|
29
31
|
INSTANCE(),
|
30
|
-
|
32
|
+
GIF_INITIAL_RELEASE(),
|
31
33
|
COMMIT_HASH,
|
32
34
|
TargetType.Instance,
|
33
35
|
false)
|
@@ -28,6 +28,7 @@ import {NftId} from "../type/NftId.sol";
|
|
28
28
|
import {PayoutId, PayoutIdLib} from "../type/PayoutId.sol";
|
29
29
|
import {PolicyServiceLib} from "../product/PolicyServiceLib.sol";
|
30
30
|
import {ProductStore} from "./ProductStore.sol";
|
31
|
+
import {RegistryLinked} from "../shared/RegistryLinked.sol";
|
31
32
|
import {ReferralId, ReferralStatus, ReferralLib} from "../type/Referral.sol";
|
32
33
|
import {RequestId} from "../type/RequestId.sol";
|
33
34
|
import {RiskId} from "../type/RiskId.sol";
|
@@ -40,14 +41,19 @@ import {UFixed, UFixedLib} from "../type/UFixed.sol";
|
|
40
41
|
|
41
42
|
/// @dev Central reader contract for a specific instance.
|
42
43
|
/// Provides reading functions for all instance data and related component data.
|
43
|
-
contract InstanceReader
|
44
|
+
contract InstanceReader is
|
45
|
+
RegistryLinked
|
46
|
+
{
|
44
47
|
|
45
48
|
error ErrorInstanceReaderAlreadyInitialized();
|
46
49
|
error ErrorInstanceReaderInstanceAddressZero();
|
47
|
-
|
50
|
+
// TODO make state immutable:
|
51
|
+
// 1. instance receives reader through setInstanceReader()
|
52
|
+
// 2. this way instance initialization is not depends on reader
|
53
|
+
// 3. and reader is simple contract with constructor
|
54
|
+
// 4. no _initialized in storage, the rest is immutable
|
48
55
|
bool private _initialized = false;
|
49
56
|
|
50
|
-
IRegistry internal _registry;
|
51
57
|
IInstance internal _instance;
|
52
58
|
InstanceAdmin internal _instanceAdmin;
|
53
59
|
|
@@ -78,27 +84,24 @@ contract InstanceReader {
|
|
78
84
|
_initialized = true;
|
79
85
|
_instance = IInstance(instanceAddress);
|
80
86
|
_instanceAdmin = _instance.getInstanceAdmin();
|
81
|
-
_registry = _instance.getRegistry();
|
82
87
|
|
83
88
|
_store = _instance.getInstanceStore();
|
84
89
|
_productStore = _instance.getProductStore();
|
85
90
|
_bundleSet = _instance.getBundleSet();
|
86
91
|
_riskSet = _instance.getRiskSet();
|
87
|
-
|
92
|
+
|
93
|
+
_distributionService = IDistributionService(
|
94
|
+
_getRegistry().getServiceAddress(DISTRIBUTION(), _instance.getRelease()));
|
88
95
|
}
|
89
96
|
|
90
97
|
|
91
98
|
//--- instance functions ---------------------------------------------------------//
|
92
99
|
|
93
|
-
/// @dev Returns the registry this instance is registered in.
|
94
|
-
function getRegistry() public view returns (IRegistry registry) {
|
95
|
-
return _registry;
|
96
|
-
}
|
97
100
|
|
98
101
|
|
99
102
|
/// @dev Returns the instance NFT ID.
|
100
103
|
function getInstanceNftId() public view returns (NftId instanceNftid) {
|
101
|
-
return
|
104
|
+
return _getRegistry().getNftIdForAddress(address(_instance));
|
102
105
|
}
|
103
106
|
|
104
107
|
|
@@ -413,7 +416,7 @@ contract InstanceReader {
|
|
413
416
|
return _store.getReferralInfo(referralId);
|
414
417
|
}
|
415
418
|
|
416
|
-
|
419
|
+
// TODO reader dependce on service os wrong?
|
417
420
|
function getDiscountPercentage(ReferralId referralId)
|
418
421
|
public
|
419
422
|
view
|
@@ -422,10 +425,7 @@ contract InstanceReader {
|
|
422
425
|
ReferralStatus status
|
423
426
|
)
|
424
427
|
{
|
425
|
-
return
|
426
|
-
_registry.getServiceAddress(
|
427
|
-
DISTRIBUTION(),
|
428
|
-
_instance.getRelease())).getDiscountPercentage(
|
428
|
+
return _distributionService.getDiscountPercentage(
|
429
429
|
this, // instance reader
|
430
430
|
referralId);
|
431
431
|
}
|