@etherisc/gif-next 3.0.0-2c4b8cb-070 → 3.0.0-2e16ebd-614
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 +0 -1
- 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 +78 -26
- 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 +145 -51
- 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 +77 -179
- 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 +25 -22
- 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 +4 -23
- 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/Seconds.sol/SecondsLib.json +2 -21
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +2 -21
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +4 -36
- 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/IInstance.sol +1 -1
- package/contracts/instance/Instance.sol +8 -12
- package/contracts/instance/InstanceAdmin.sol +10 -17
- package/contracts/instance/InstanceAuthorizationV3.sol +4 -2
- package/contracts/instance/InstanceReader.sol +18 -40
- 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 +12 -16
- 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 +7 -7
- 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 +38 -128
- 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/ObjectType.sol +31 -2
- package/contracts/type/Referral.sol +0 -6
- package/contracts/type/Seconds.sol +0 -4
- package/contracts/type/String.sol +0 -30
- package/contracts/type/Timestamp.sol +1 -10
- 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 -2
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +0 -635
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +0 -229
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +0 -1198
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +0 -849
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +0 -1466
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +0 -844
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +0 -2514
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +0 -844
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +0 -586
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +0 -4
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +0 -901
- 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/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +0 -4
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +0 -33
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +0 -4
- package/contracts/examples/flight/FlightLib.sol +0 -322
- package/contracts/examples/flight/FlightMessageVerifier.sol +0 -128
- package/contracts/examples/flight/FlightOracle.sol +0 -167
- package/contracts/examples/flight/FlightOracleAuthorization.sol +0 -34
- package/contracts/examples/flight/FlightPool.sol +0 -89
- package/contracts/examples/flight/FlightPoolAuthorization.sol +0 -37
- package/contracts/examples/flight/FlightProduct.sol +0 -651
- package/contracts/examples/flight/FlightProductAuthorization.sol +0 -45
- package/contracts/examples/flight/FlightUSD.sol +0 -28
- package/contracts/examples/flight/originalV1.sol +0 -396
- package/contracts/shared/EcdsaChecker.sol +0 -5
- package/contracts/type/RequestIdSet.sol +0 -62
| @@ -2,7 +2,7 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {AccountingService} from "./AccountingService.sol";
         | 
| 5 | 
            -
            import { | 
| 5 | 
            +
            import {IUpgradeable} from "../upgradeability/IUpgradeable.sol";
         | 
| 6 6 | 
             
            import {ProxyManager} from "../upgradeability/ProxyManager.sol";
         | 
| 7 7 |  | 
| 8 8 | 
             
            contract AccountingServiceManager is ProxyManager {
         | 
| @@ -12,19 +12,17 @@ contract AccountingServiceManager is ProxyManager { | |
| 12 12 | 
             
                /// @dev initializes proxy manager with service implementation 
         | 
| 13 13 | 
             
                constructor(
         | 
| 14 14 | 
             
                    address authority, 
         | 
| 15 | 
            -
                    address registry,
         | 
| 16 15 | 
             
                    bytes32 salt
         | 
| 17 16 | 
             
                )
         | 
| 18 17 | 
             
                {
         | 
| 19 18 | 
             
                    AccountingService svc = new AccountingService();
         | 
| 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 | 
            -
                    _accountingService = AccountingService(address( | 
| 25 | 
            +
                    _accountingService = AccountingService(address(upgradeable));
         | 
| 28 26 | 
             
                }
         | 
| 29 27 |  | 
| 30 28 | 
             
                //--- view functions ----------------------------------------------------//
         | 
| @@ -14,13 +14,14 @@ import {AccessAdminLib} from "./AccessAdminLib.sol"; | |
| 14 14 | 
             
            import {AccessManagerCloneable} from "./AccessManagerCloneable.sol";
         | 
| 15 15 | 
             
            import {Blocknumber, BlocknumberLib} from "../type/Blocknumber.sol";
         | 
| 16 16 | 
             
            import {ContractLib} from "../shared/ContractLib.sol";
         | 
| 17 | 
            -
            import {NftId | 
| 17 | 
            +
            import {NftId} from "../type/NftId.sol";
         | 
| 18 18 | 
             
            import {ObjectType} from "../type/ObjectType.sol";
         | 
| 19 19 | 
             
            import {RoleId, RoleIdLib, ADMIN_ROLE, PUBLIC_ROLE} from "../type/RoleId.sol";
         | 
| 20 | 
            +
            import {RegistryLinked} from "../shared/RegistryLinked.sol";
         | 
| 20 21 | 
             
            import {Selector, SelectorSetLib} from "../type/Selector.sol";
         | 
| 21 22 | 
             
            import {Str, StrLib} from "../type/String.sol";
         | 
| 22 23 | 
             
            import {TimestampLib} from "../type/Timestamp.sol";
         | 
| 23 | 
            -
            import {VersionPart} from "../type/Version.sol";
         | 
| 24 | 
            +
            import {VersionPartLib, VersionPart} from "../type/Version.sol";
         | 
| 24 25 |  | 
| 25 26 |  | 
| 26 27 | 
             
            /**
         | 
| @@ -30,6 +31,7 @@ import {VersionPart} from "../type/Version.sol"; | |
| 30 31 | 
             
             */ 
         | 
| 31 32 | 
             
            contract AccessAdmin is
         | 
| 32 33 | 
             
                AccessManagedUpgradeable,
         | 
| 34 | 
            +
                RegistryLinked,
         | 
| 33 35 | 
             
                IAccessAdmin
         | 
| 34 36 | 
             
            {
         | 
| 35 37 | 
             
                using EnumerableSet for EnumerableSet.AddressSet;
         | 
| @@ -91,12 +93,16 @@ contract AccessAdmin is | |
| 91 93 | 
             
                /// Internally initializes access manager with this admin and creates basic role setup.
         | 
| 92 94 | 
             
                function initialize(
         | 
| 93 95 | 
             
                    address authority,
         | 
| 94 | 
            -
                    string memory adminName | 
| 96 | 
            +
                    string memory adminName,
         | 
| 97 | 
            +
                    VersionPart release 
         | 
| 95 98 | 
             
                )
         | 
| 96 99 | 
             
                    public
         | 
| 97 | 
            -
                    initializer()
         | 
| 98 100 | 
             
                {
         | 
| 99 | 
            -
                     | 
| 101 | 
            +
                    if(_getInitializedVersion() != 0) {
         | 
| 102 | 
            +
                        revert InvalidInitialization();
         | 
| 103 | 
            +
                    }
         | 
| 104 | 
            +
             | 
| 105 | 
            +
                    __AccessAdmin_init(authority, adminName, release);
         | 
| 100 106 | 
             
                }
         | 
| 101 107 |  | 
| 102 108 |  | 
| @@ -106,14 +112,16 @@ contract AccessAdmin is | |
| 106 112 | 
             
                /// - this function as well as any completeSetup functions MUST be called in the same tx.
         | 
| 107 113 | 
             
                function __AccessAdmin_init(
         | 
| 108 114 | 
             
                    address authority, 
         | 
| 109 | 
            -
                    string memory adminName | 
| 115 | 
            +
                    string memory adminName,
         | 
| 116 | 
            +
                    VersionPart release
         | 
| 110 117 | 
             
                )
         | 
| 111 118 | 
             
                    internal
         | 
| 112 | 
            -
                     | 
| 119 | 
            +
                    reinitializer(release.toInt())
         | 
| 113 120 | 
             
                {
         | 
| 114 121 | 
             
                    AccessAdminLib.checkInitParameters(authority, adminName);
         | 
| 122 | 
            +
             | 
| 115 123 | 
             
                    _authority = AccessManagerCloneable(authority);
         | 
| 116 | 
            -
                    _authority.initialize(address(this));
         | 
| 124 | 
            +
                    _authority.initialize(address(this), release);
         | 
| 117 125 |  | 
| 118 126 | 
             
                    // delayed additional check for authority after its initialization
         | 
| 119 127 | 
             
                    if (!ContractLib.isAuthority(authority)) {
         | 
| @@ -121,7 +129,7 @@ contract AccessAdmin is | |
| 121 129 | 
             
                    }
         | 
| 122 130 |  | 
| 123 131 | 
             
                    // effects
         | 
| 124 | 
            -
                    // set and initialize this  | 
| 132 | 
            +
                    // set and initialize this contract as
         | 
| 125 133 | 
             
                    // the admin (ADMIN_ROLE) of the provided authority
         | 
| 126 134 | 
             
                    __AccessManaged_init(authority);
         | 
| 127 135 |  | 
| @@ -129,7 +137,7 @@ contract AccessAdmin is | |
| 129 137 | 
             
                    _adminName = adminName;
         | 
| 130 138 |  | 
| 131 139 | 
             
                    // set initial linked NFT ID to zero
         | 
| 132 | 
            -
                    _linkedNftId = NftIdLib.zero();
         | 
| 140 | 
            +
                    //_linkedNftId = NftIdLib.zero();
         | 
| 133 141 |  | 
| 134 142 | 
             
                    // setup admin role
         | 
| 135 143 | 
             
                    _createRoleUnchecked(
         | 
| @@ -149,12 +157,7 @@ contract AccessAdmin is | |
| 149 157 | 
             
                //--- view functions for access admin ---------------------------------------//
         | 
| 150 158 |  | 
| 151 159 | 
             
                function getRelease() public view virtual returns (VersionPart release) {
         | 
| 152 | 
            -
                    return  | 
| 153 | 
            -
                }
         | 
| 154 | 
            -
             | 
| 155 | 
            -
             | 
| 156 | 
            -
                function getRegistry() public view returns (IRegistry registry) {
         | 
| 157 | 
            -
                    return _authority.getRegistry();
         | 
| 160 | 
            +
                    return VersionPartLib.toVersionPart(uint8(_getInitializedVersion()));
         | 
| 158 161 | 
             
                }
         | 
| 159 162 |  | 
| 160 163 |  | 
| @@ -297,11 +300,12 @@ contract AccessAdmin is | |
| 297 300 | 
             
                //--- internal/private functions -------------------------------------------------//
         | 
| 298 301 |  | 
| 299 302 | 
             
                function _linkToNftOwnable(address registerable) internal {
         | 
| 300 | 
            -
                     | 
| 303 | 
            +
                    NftId nftId = _getRegistry().getNftIdForAddress(registerable);
         | 
| 304 | 
            +
                    if (nftId.eqz()) {
         | 
| 301 305 | 
             
                        revert ErrorAccessAdminNotRegistered(registerable);
         | 
| 302 306 | 
             
                    }
         | 
| 303 307 |  | 
| 304 | 
            -
                    _linkedNftId =  | 
| 308 | 
            +
                    _linkedNftId = nftId;
         | 
| 305 309 | 
             
                }
         | 
| 306 310 |  | 
| 307 311 |  | 
| @@ -335,9 +335,9 @@ library AccessAdminLib { // ACCESS_ADMIN_LIB | |
| 335 335 | 
             
                    view
         | 
| 336 336 | 
             
                    returns (IAuthorization componentAuthorization)
         | 
| 337 337 | 
             
                {
         | 
| 338 | 
            -
                    checkIsRegistered(address(accessAdmin.getRegistry()), componentAddress, expectedType);
         | 
| 339 | 
            -
             | 
| 340 338 | 
             
                    VersionPart expecteRelease = accessAdmin.getRelease();
         | 
| 339 | 
            +
                    checkIsRegistered(componentAddress, expectedType, expecteRelease);
         | 
| 340 | 
            +
             | 
| 341 341 | 
             
                    IInstanceLinkedComponent component = IInstanceLinkedComponent(componentAddress);
         | 
| 342 342 | 
             
                    componentAuthorization = component.getAuthorization();
         | 
| 343 343 |  | 
| @@ -435,22 +435,25 @@ library AccessAdminLib { // ACCESS_ADMIN_LIB | |
| 435 435 |  | 
| 436 436 |  | 
| 437 437 | 
             
                function checkIsRegistered( 
         | 
| 438 | 
            -
                    address registry,
         | 
| 439 438 | 
             
                    address target,
         | 
| 440 | 
            -
                    ObjectType expectedType
         | 
| 439 | 
            +
                    ObjectType expectedType,
         | 
| 440 | 
            +
                    VersionPart expectedRelease
         | 
| 441 441 | 
             
                )
         | 
| 442 442 | 
             
                    public
         | 
| 443 443 | 
             
                    view 
         | 
| 444 444 | 
             
                {
         | 
| 445 | 
            -
                     | 
| 445 | 
            +
                    IRegistry.ObjectInfo memory info = ContractLib.getRegistry().getObjectInfo(target);
         | 
| 446 446 |  | 
| 447 | 
            -
                     | 
| 448 | 
            -
                    if (tagetType.eqz()) {
         | 
| 447 | 
            +
                    if (info.objectType.eqz()) {
         | 
| 449 448 | 
             
                        revert IAccessAdmin.ErrorAccessAdminNotRegistered(target);
         | 
| 450 449 | 
             
                    }
         | 
| 451 450 |  | 
| 452 | 
            -
                    if ( | 
| 453 | 
            -
                        revert IAccessAdmin.ErrorAccessAdminTargetTypeMismatch(target, expectedType,  | 
| 451 | 
            +
                    if (info.objectType != expectedType) {
         | 
| 452 | 
            +
                        revert IAccessAdmin.ErrorAccessAdminTargetTypeMismatch(target, expectedType, info.objectType);
         | 
| 453 | 
            +
                    }
         | 
| 454 | 
            +
             | 
| 455 | 
            +
                    if (info.release != expectedRelease) {
         | 
| 456 | 
            +
                        revert IAccessAdmin.ErrorAccessAdminTargetReleaseMismatch(target, expectedRelease, info.release);
         | 
| 454 457 | 
             
                    }
         | 
| 455 458 | 
             
                }
         | 
| 456 459 |  | 
| @@ -4,9 +4,9 @@ pragma solidity ^0.8.20; | |
| 4 4 | 
             
            import {AccessManagerUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagerUpgradeable.sol";
         | 
| 5 5 | 
             
            import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
         | 
| 6 6 |  | 
| 7 | 
            +
            import {IAccessAdmin} from "./IAccessAdmin.sol";
         | 
| 7 8 | 
             
            import {InitializableERC165} from "../shared/InitializableERC165.sol";
         | 
| 8 | 
            -
            import { | 
| 9 | 
            -
            import {VersionPart} from "../type/Version.sol";
         | 
| 9 | 
            +
            import {VersionPartLib, VersionPart} from "../type/Version.sol";
         | 
| 10 10 |  | 
| 11 11 |  | 
| 12 12 | 
             
            /// @dev An AccessManager based on OpenZeppelin that is cloneable and has a central lock property.
         | 
| @@ -14,8 +14,7 @@ import {VersionPart} from "../type/Version.sol"; | |
| 14 14 | 
             
            /// Cloned by upon release preparation and instance cloning.
         | 
| 15 15 | 
             
            contract AccessManagerCloneable is
         | 
| 16 16 | 
             
                AccessManagerUpgradeable,
         | 
| 17 | 
            -
                InitializableERC165 | 
| 18 | 
            -
                RegistryLinked
         | 
| 17 | 
            +
                InitializableERC165
         | 
| 19 18 | 
             
            {
         | 
| 20 19 | 
             
                error ErrorAccessManagerCallerNotAdmin(address caller);
         | 
| 21 20 | 
             
                error ErrorAccessManagerRegistryAlreadySet(address registry);
         | 
| @@ -24,7 +23,6 @@ contract AccessManagerCloneable is | |
| 24 23 | 
             
                error ErrorAccessManagerTargetAdminLocked(address target);
         | 
| 25 24 | 
             
                error ErrorAccessManagerCallerAdminLocked(address caller);
         | 
| 26 25 |  | 
| 27 | 
            -
                VersionPart private _release;
         | 
| 28 26 | 
             
                bool private _isLocked;
         | 
| 29 27 |  | 
| 30 28 |  | 
| @@ -36,34 +34,36 @@ contract AccessManagerCloneable is | |
| 36 34 | 
             
                    _;
         | 
| 37 35 | 
             
                }
         | 
| 38 36 |  | 
| 39 | 
            -
             | 
| 40 | 
            -
                function initialize(address admin)
         | 
| 37 | 
            +
                function initialize(address adminAddress, VersionPart release)
         | 
| 41 38 | 
             
                    public
         | 
| 42 | 
            -
             | 
| 39 | 
            +
             | 
| 43 40 | 
             
                {
         | 
| 44 | 
            -
                     | 
| 45 | 
            -
             | 
| 41 | 
            +
                    if(_getInitializedVersion() != 0) {
         | 
| 42 | 
            +
                        revert InvalidInitialization();
         | 
| 43 | 
            +
                    }
         | 
| 46 44 |  | 
| 47 | 
            -
                     | 
| 45 | 
            +
                    AccessManagerCloneable_init(adminAddress, release);
         | 
| 48 46 | 
             
                }
         | 
| 49 47 |  | 
| 50 | 
            -
             | 
| 51 | 
            -
             | 
| 52 | 
            -
                /// Links the access manager to the registry and sets the release version.
         | 
| 53 | 
            -
                function completeSetup(
         | 
| 54 | 
            -
                    address registry, 
         | 
| 48 | 
            +
                function AccessManagerCloneable_init(
         | 
| 49 | 
            +
                    address admin,
         | 
| 55 50 | 
             
                    VersionPart release
         | 
| 56 51 | 
             
                )
         | 
| 57 | 
            -
                     | 
| 58 | 
            -
                     | 
| 59 | 
            -
                    reinitializer(uint64(release.toInt()))
         | 
| 52 | 
            +
                    internal
         | 
| 53 | 
            +
                    reinitializer(release.toInt())
         | 
| 60 54 | 
             
                {
         | 
| 61 | 
            -
                     | 
| 62 | 
            -
             | 
| 55 | 
            +
                    if (!release.isValidRelease()) {
         | 
| 56 | 
            +
                        revert ErrorAccessManagerInvalidRelease(release);
         | 
| 57 | 
            +
                    }
         | 
| 58 | 
            +
             | 
| 59 | 
            +
                    __ERC165_init();
         | 
| 60 | 
            +
                    __AccessManager_init(admin);
         | 
| 61 | 
            +
             | 
| 62 | 
            +
                    _registerInterface(type(IAccessManager).interfaceId);
         | 
| 63 63 | 
             
                }
         | 
| 64 64 |  | 
| 65 65 | 
             
                /// @dev Returns true if the caller is authorized to call the target with the given selector and the manager lock is not set to locked.
         | 
| 66 | 
            -
                ///  | 
| 66 | 
            +
                /// Return values as in OpenZeppelin AccessManager.
         | 
| 67 67 | 
             
                /// For a locked manager the function reverts with ErrorAccessManagerTargetAdminLocked.
         | 
| 68 68 | 
             
                function canCall(
         | 
| 69 69 | 
             
                    address caller,
         | 
| @@ -101,10 +101,10 @@ contract AccessManagerCloneable is | |
| 101 101 | 
             
                /// For the registry admin release 3 is returned.
         | 
| 102 102 | 
             
                /// For the release admin and the instance admin the actual release version is returned.
         | 
| 103 103 | 
             
                function getRelease() external view returns (VersionPart release) {
         | 
| 104 | 
            -
                    return  | 
| 104 | 
            +
                    return VersionPartLib.toVersionPart(
         | 
| 105 | 
            +
                        uint8(_getInitializedVersion()));
         | 
| 105 106 | 
             
                }
         | 
| 106 107 |  | 
| 107 | 
            -
             | 
| 108 108 | 
             
                /// @dev Returns true iff all contracts of this access manager are locked.
         | 
| 109 109 | 
             
                function isLocked()
         | 
| 110 110 | 
             
                    public
         | 
| @@ -113,28 +113,4 @@ contract AccessManagerCloneable is | |
| 113 113 | 
             
                {
         | 
| 114 114 | 
             
                    return _isLocked;
         | 
| 115 115 | 
             
                }
         | 
| 116 | 
            -
             | 
| 117 | 
            -
             | 
| 118 | 
            -
                function _checkAndSetRelease(VersionPart release)
         | 
| 119 | 
            -
                    internal
         | 
| 120 | 
            -
                {
         | 
| 121 | 
            -
                    if (!release.isValidRelease()) {
         | 
| 122 | 
            -
                        revert ErrorAccessManagerInvalidRelease(release);
         | 
| 123 | 
            -
                    }
         | 
| 124 | 
            -
             | 
| 125 | 
            -
                    _release = release;
         | 
| 126 | 
            -
                }
         | 
| 127 | 
            -
             | 
| 128 | 
            -
             | 
| 129 | 
            -
                function _checkAndSetRegistry(address registry)
         | 
| 130 | 
            -
                    internal
         | 
| 131 | 
            -
                {
         | 
| 132 | 
            -
                    // checks
         | 
| 133 | 
            -
                    if(address(getRegistry()) != address(0)) {
         | 
| 134 | 
            -
                        revert ErrorAccessManagerRegistryAlreadySet(address(getRegistry()) );
         | 
| 135 | 
            -
                    }
         | 
| 136 | 
            -
             | 
| 137 | 
            -
                    // effects
         | 
| 138 | 
            -
                    __RegistryLinked_init(registry);
         | 
| 139 | 
            -
                }
         | 
| 140 116 | 
             
            }
         | 
| @@ -9,7 +9,7 @@ import {ObjectType} from "../type/ObjectType.sol"; | |
| 9 9 | 
             
            import {RoleId, RoleIdLib} from "../type/RoleId.sol";
         | 
| 10 10 | 
             
            import {ServiceAuthorization} from "../authorization/ServiceAuthorization.sol";
         | 
| 11 11 | 
             
            import {Str, StrLib} from "../type/String.sol";
         | 
| 12 | 
            -
             | 
| 12 | 
            +
            import {VersionPart} from "../type/Version.sol";
         | 
| 13 13 |  | 
| 14 14 | 
             
            contract Authorization is
         | 
| 15 15 | 
             
                ServiceAuthorization,
         | 
| @@ -30,7 +30,7 @@ contract Authorization is | |
| 30 30 | 
             
                constructor(
         | 
| 31 31 | 
             
                    string memory mainTargetName, 
         | 
| 32 32 | 
             
                    ObjectType domain,
         | 
| 33 | 
            -
                     | 
| 33 | 
            +
                    VersionPart release,
         | 
| 34 34 | 
             
                    string memory commitHash,
         | 
| 35 35 | 
             
                    IAccess.TargetType targetType,
         | 
| 36 36 | 
             
                    bool includeTokenHandler
         | 
| @@ -6,7 +6,6 @@ import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessMana | |
| 6 6 | 
             
            import {IAccess} from "./IAccess.sol";
         | 
| 7 7 | 
             
            import {IAuthorization} from "./IAuthorization.sol";
         | 
| 8 8 | 
             
            import {IRegistryLinked} from "../shared/IRegistryLinked.sol";
         | 
| 9 | 
            -
            import {IRelease} from "../registry/IRelease.sol";
         | 
| 10 9 |  | 
| 11 10 | 
             
            import {Blocknumber} from "../type/Blocknumber.sol";
         | 
| 12 11 | 
             
            import {NftId} from "../type/NftId.sol";
         | 
| @@ -19,8 +18,7 @@ import {VersionPart} from "../type/Version.sol"; | |
| 19 18 | 
             
            interface IAccessAdmin is 
         | 
| 20 19 | 
             
                IAccessManaged,
         | 
| 21 20 | 
             
                IAccess,
         | 
| 22 | 
            -
                IRegistryLinked | 
| 23 | 
            -
                IRelease
         | 
| 21 | 
            +
                IRegistryLinked
         | 
| 24 22 | 
             
            {
         | 
| 25 23 |  | 
| 26 24 | 
             
                // roles, targets and functions
         | 
| @@ -59,6 +57,7 @@ interface IAccessAdmin is | |
| 59 57 | 
             
                error ErrorAccessAdminTargetNotCreated(address target);
         | 
| 60 58 | 
             
                error ErrorAccessAdminTargetNotRegistered(address target);
         | 
| 61 59 | 
             
                error ErrorAccessAdminTargetTypeMismatch(address target, ObjectType expectedType, ObjectType actualType);
         | 
| 60 | 
            +
                error ErrorAccessAdminTargetReleaseMismatch(address target, VersionPart expectedRelease, VersionPart actualRelease);
         | 
| 62 61 |  | 
| 63 62 | 
             
                // check authorization
         | 
| 64 63 | 
             
                error ErrorAccessAdminAlreadyInitialized(address authorization);
         | 
| @@ -139,4 +138,5 @@ interface IAccessAdmin is | |
| 139 138 |  | 
| 140 139 | 
             
                function authorizedFunctions(address target) external view returns (uint256 numberOfFunctions);
         | 
| 141 140 | 
             
                function getAuthorizedFunction(address target, uint256 idx) external view returns (FunctionInfo memory func, RoleId roleId);
         | 
| 141 | 
            +
                    function getRelease() external view returns (VersionPart);
         | 
| 142 142 | 
             
            }
         | 
| @@ -16,7 +16,7 @@ interface IServiceAuthorization is | |
| 16 16 |  | 
| 17 17 | 
             
                 error ErrorAuthorizationMainTargetNameEmpty();
         | 
| 18 18 | 
             
                 error ErrorAuthorizationTargetDomainZero();
         | 
| 19 | 
            -
                 error ErrorAuthorizationReleaseInvalid( | 
| 19 | 
            +
                 error ErrorAuthorizationReleaseInvalid(VersionPart release);
         | 
| 20 20 | 
             
                 error ErrorAuthorizationCommitHashInvalid(string commitHash);
         | 
| 21 21 |  | 
| 22 22 | 
             
                 /// @dev Returns the main domain of the authorization.
         | 
| @@ -30,7 +30,7 @@ contract ServiceAuthorization is | |
| 30 30 | 
             
                 string public constant ROLE_NAME_SUFFIX = "_Role";
         | 
| 31 31 |  | 
| 32 32 | 
             
                 ObjectType public immutable DOMAIN;
         | 
| 33 | 
            -
                  | 
| 33 | 
            +
                 VersionPart internal immutable _release;
         | 
| 34 34 | 
             
                 string internal _commitHash;
         | 
| 35 35 |  | 
| 36 36 | 
             
                 string internal _mainTargetName;
         | 
| @@ -55,7 +55,7 @@ contract ServiceAuthorization is | |
| 55 55 | 
             
                 constructor(
         | 
| 56 56 | 
             
                      string memory mainTargetName, 
         | 
| 57 57 | 
             
                      ObjectType domain,
         | 
| 58 | 
            -
                       | 
| 58 | 
            +
                      VersionPart release,
         | 
| 59 59 | 
             
                      string memory commitHash
         | 
| 60 60 | 
             
                 )
         | 
| 61 61 | 
             
                 {
         | 
| @@ -68,7 +68,7 @@ contract ServiceAuthorization is | |
| 68 68 | 
             
                           revert ErrorAuthorizationTargetDomainZero();
         | 
| 69 69 | 
             
                      }
         | 
| 70 70 |  | 
| 71 | 
            -
                      if ( | 
| 71 | 
            +
                      if (!VersionPartLib.isValidRelease(release)) {
         | 
| 72 72 | 
             
                           revert ErrorAuthorizationReleaseInvalid(release);
         | 
| 73 73 | 
             
                      }
         | 
| 74 74 |  | 
| @@ -103,7 +103,7 @@ contract ServiceAuthorization is | |
| 103 103 |  | 
| 104 104 | 
             
                 /// @inheritdoc IServiceAuthorization
         | 
| 105 105 | 
             
                 function getRelease() public view returns(VersionPart release) {
         | 
| 106 | 
            -
                      return  | 
| 106 | 
            +
                      return _release;
         | 
| 107 107 | 
             
                 }
         | 
| 108 108 |  | 
| 109 109 | 
             
                 /// @inheritdoc IServiceAuthorization
         | 
| @@ -119,7 +119,6 @@ contract BasicDistribution is | |
| 119 119 | 
             
                }
         | 
| 120 120 |  | 
| 121 121 | 
             
                function _initializeBasicDistribution(
         | 
| 122 | 
            -
                    address registry,
         | 
| 123 122 | 
             
                    NftId instanceNftId,
         | 
| 124 123 | 
             
                    IAuthorization authorization, 
         | 
| 125 124 | 
             
                    address initialOwner,
         | 
| @@ -130,7 +129,6 @@ contract BasicDistribution is | |
| 130 129 | 
             
                    onlyInitializing()
         | 
| 131 130 | 
             
                {
         | 
| 132 131 | 
             
                    __Distribution_init(
         | 
| 133 | 
            -
                        registry, 
         | 
| 134 132 | 
             
                        instanceNftId, 
         | 
| 135 133 | 
             
                        authorization,
         | 
| 136 134 | 
             
                        false,
         | 
| @@ -2,15 +2,16 @@ | |
| 2 2 | 
             
            pragma solidity ^0.8.20;
         | 
| 3 3 |  | 
| 4 4 | 
             
            import {IAccess} from "../authorization/IAccess.sol";
         | 
| 5 | 
            -
            import { | 
| 5 | 
            +
            import {IComponent} from "../shared/IInstanceLinkedComponent.sol";
         | 
| 6 6 |  | 
| 7 7 | 
             
            import {Authorization} from "../authorization/Authorization.sol";
         | 
| 8 8 | 
             
            import {BasicDistribution} from "./BasicDistribution.sol"; 
         | 
| 9 9 | 
             
            import {Distribution} from "./Distribution.sol";
         | 
| 10 10 | 
             
            import {COMPONENT, DISTRIBUTION} from "../type/ObjectType.sol";
         | 
| 11 11 | 
             
            import {PUBLIC_ROLE} from "../type/RoleId.sol";
         | 
| 12 | 
            +
            import {GIF_INITIAL_RELEASE} from "../registry/Registry.sol";
         | 
| 12 13 | 
             
            import {TokenHandler} from "../shared/TokenHandler.sol";
         | 
| 13 | 
            -
             | 
| 14 | 
            +
            import {VersionPartLib} from "../type/Version.sol";
         | 
| 14 15 |  | 
| 15 16 | 
             
            contract BasicDistributionAuthorization
         | 
| 16 17 | 
             
                 is Authorization
         | 
| @@ -20,7 +21,7 @@ contract BasicDistributionAuthorization | |
| 20 21 | 
             
                      Authorization(
         | 
| 21 22 | 
             
                           distributionName, 
         | 
| 22 23 | 
             
                           DISTRIBUTION(), 
         | 
| 23 | 
            -
                            | 
| 24 | 
            +
                           GIF_INITIAL_RELEASE(),
         | 
| 24 25 | 
             
                           COMMIT_HASH,
         | 
| 25 26 | 
             
                           TargetType.Component, 
         | 
| 26 27 | 
             
                           true)
         | 
| @@ -60,7 +61,7 @@ contract BasicDistributionAuthorization | |
| 60 61 | 
             
                      _authorize(functions, BasicDistribution.changeDistributorType.selector, "changeDistributorType");
         | 
| 61 62 | 
             
                      _authorize(functions, BasicDistribution.createReferral.selector, "createReferral");
         | 
| 62 63 |  | 
| 63 | 
            -
                      _authorize(functions,  | 
| 64 | 
            +
                      _authorize(functions, IComponent.withdrawFees.selector, "withdrawFees");
         | 
| 64 65 | 
             
                      _authorize(functions, Distribution.withdrawCommission.selector, "withdrawCommission");
         | 
| 65 66 | 
             
                 }
         | 
| 66 67 | 
             
            }
         | 
| @@ -104,7 +104,6 @@ abstract contract Distribution is | |
| 104 104 |  | 
| 105 105 |  | 
| 106 106 | 
             
                function __Distribution_init(
         | 
| 107 | 
            -
                    address registry,
         | 
| 108 107 | 
             
                    NftId productNftId,
         | 
| 109 108 | 
             
                    IAuthorization authorization, 
         | 
| 110 109 | 
             
                    bool isInterceptor,
         | 
| @@ -116,7 +115,6 @@ abstract contract Distribution is | |
| 116 115 | 
             
                    onlyInitializing()
         | 
| 117 116 | 
             
                {
         | 
| 118 117 | 
             
                    __InstanceLinkedComponent_init(
         | 
| 119 | 
            -
                        registry, 
         | 
| 120 118 | 
             
                        productNftId, 
         | 
| 121 119 | 
             
                        name, 
         | 
| 122 120 | 
             
                        DISTRIBUTION(), 
         | 
| @@ -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,
         |