@etherisc/gif-next 3.0.0-f90c901-018 → 3.0.0-fb87f3a-607
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 +10 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +83 -164
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +115 -113
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +1 -1
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +46 -91
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +70 -105
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +150 -126
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +84 -20
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +55 -31
- 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 +10 -20
- 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 +42 -18
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +75 -126
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +65 -41
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +57 -72
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +224 -198
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +150 -140
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +56 -84
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +117 -71
- 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 +104 -166
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +65 -41
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +138 -200
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +65 -41
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +1 -1
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightLib.sol/FlightLib.json +799 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightMessageVerifier.sol/FlightMessageVerifier.json +229 -0
- package/artifacts/contracts/examples/flight/FlightNft.sol/FlightNft.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightNft.sol/FlightNft.json +801 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracle.sol/FlightOracle.json +1353 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightOracleAuthorization.sol/FlightOracleAuthorization.json +896 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPool.sol/FlightPool.json +1466 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightPoolAuthorization.sol/FlightPoolAuthorization.json +844 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProduct.sol/FlightProduct.json +2289 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductAuthorization.sol/FlightProductAuthorization.json +891 -0
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightProductManager.sol/FlightProductManager.json +711 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/FlightUSD.sol/FlightUSD.json +586 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.dbg.json +4 -0
- package/artifacts/contracts/examples/flight/originalV1.sol/FlightDelayChainlink.json +901 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +102 -159
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +65 -41
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +106 -163
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +120 -177
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +65 -41
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +114 -171
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +65 -41
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.json +50 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +54 -49
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +1 -1
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +50 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +26 -78
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +105 -83
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +51 -145
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +151 -185
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +67 -43
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +238 -77
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +136 -138
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +112 -104
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +82 -32
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +1 -1
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +68 -18
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +1 -1
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +58 -53
- 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 +8 -3
- 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 +81 -132
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +65 -41
- 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 +66 -94
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +83 -80
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +67 -82
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +148 -149
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +129 -111
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +73 -88
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +65 -41
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +129 -176
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +139 -129
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +44 -71
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +72 -100
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +98 -94
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +73 -88
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +247 -24
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +177 -233
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +130 -140
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +63 -138
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +112 -110
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +57 -72
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +65 -41
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +115 -182
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +138 -132
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +32 -71
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +32 -71
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +76 -82
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +43 -82
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +56 -84
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +1 -1
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.json +36 -75
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +139 -173
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +20 -12
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +128 -122
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +94 -161
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +122 -116
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +57 -72
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +1 -1
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +63 -146
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +107 -109
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +2 -2
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +62 -155
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +216 -202
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +1 -1
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +15 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +102 -314
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +146 -179
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +77 -57
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +244 -285
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +110 -115
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +154 -175
- 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 +187 -135
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +56 -32
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +29 -13
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +39 -84
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +345 -164
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +141 -115
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +169 -421
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/IInstanceAdminHelper.json +24 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.dbg.json +1 -1
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITokenRegistryHelper.json +40 -0
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.dbg.json +4 -0
- package/artifacts/contracts/shared/IAuthorizedComponent.sol/IAuthorizedComponent.json +633 -0
- package/artifacts/contracts/shared/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +38 -96
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +251 -82
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +56 -84
- 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 +28 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +12 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +25 -77
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.json +12 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +32 -71
- 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 +57 -72
- 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 +34 -15
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +14 -3
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +24 -76
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +37 -3
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +31 -70
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +29 -42
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +17 -30
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +34 -34
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +81 -101
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +48 -75
- 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 +134 -170
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +31 -26
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +124 -112
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +22 -5
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +77 -132
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +111 -105
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +204 -212
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +19 -27
- 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 +22 -25
- 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 +23 -4
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.dbg.json +4 -0
- package/artifacts/contracts/type/RequestIdSet.sol/LibRequestIdSet.json +33 -0
- 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 +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +21 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +36 -4
- 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 +6 -19
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/{IUpgradeable.sol/IUpgradeable.json → IVersionable.sol/IVersionable.json} +4 -54
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +86 -63
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +4 -0
- package/artifacts/contracts/upgradeability/{Upgradeable.sol/Upgradeable.json → Versionable.sol/Versionable.json} +4 -54
- package/contracts/accounting/AccountingService.sol +22 -33
- package/contracts/accounting/AccountingServiceManager.sol +6 -4
- package/contracts/accounting/IAccountingService.sol +7 -8
- package/contracts/authorization/AccessAdmin.sol +24 -47
- package/contracts/authorization/AccessAdminLib.sol +29 -15
- package/contracts/authorization/AccessManagerCloneable.sol +51 -24
- 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 +2 -0
- package/contracts/distribution/BasicDistributionAuthorization.sol +4 -5
- package/contracts/distribution/Distribution.sol +2 -0
- package/contracts/distribution/DistributionService.sol +25 -27
- package/contracts/distribution/DistributionServiceManager.sol +6 -4
- package/contracts/distribution/IDistributionService.sol +4 -3
- package/contracts/examples/fire/FirePool.sol +4 -0
- package/contracts/examples/fire/FireProduct.sol +4 -0
- package/contracts/examples/flight/FlightLib.sol +337 -0
- package/contracts/examples/flight/FlightMessageVerifier.sol +128 -0
- package/contracts/examples/flight/FlightNft.sol +234 -0
- package/contracts/examples/flight/FlightOracle.sol +226 -0
- package/contracts/examples/flight/FlightOracleAuthorization.sol +57 -0
- package/contracts/examples/flight/FlightPool.sol +89 -0
- package/contracts/examples/flight/FlightPoolAuthorization.sol +37 -0
- package/contracts/examples/flight/FlightProduct.sol +687 -0
- package/contracts/examples/flight/FlightProductAuthorization.sol +70 -0
- package/contracts/examples/flight/FlightProductManager.sol +49 -0
- package/contracts/examples/flight/FlightUSD.sol +28 -0
- package/contracts/examples/flight/originalV1.sol +396 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +4 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +4 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +4 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +4 -0
- package/contracts/instance/BaseStore.sol +4 -0
- package/contracts/instance/IBaseStore.sol +8 -0
- package/contracts/instance/IInstance.sol +1 -1
- package/contracts/instance/IInstanceService.sol +2 -0
- package/contracts/instance/Instance.sol +12 -8
- package/contracts/instance/InstanceAdmin.sol +17 -11
- package/contracts/instance/InstanceAuthorizationV3.sol +2 -4
- package/contracts/instance/InstanceReader.sol +56 -22
- package/contracts/instance/InstanceService.sol +24 -18
- package/contracts/instance/InstanceServiceManager.sol +6 -4
- package/contracts/instance/base/Cloneable.sol +10 -4
- package/contracts/instance/base/ObjectSet.sol +2 -2
- package/contracts/oracle/BasicOracle.sol +3 -0
- package/contracts/oracle/BasicOracleAuthorization.sol +1 -3
- package/contracts/oracle/IOracleService.sol +16 -12
- package/contracts/oracle/Oracle.sol +6 -5
- package/contracts/oracle/OracleService.sol +67 -37
- package/contracts/oracle/OracleServiceManager.sol +6 -4
- package/contracts/pool/BasicPool.sol +4 -2
- package/contracts/pool/BasicPoolAuthorization.sol +4 -5
- package/contracts/pool/BundleService.sol +20 -26
- package/contracts/pool/BundleServiceManager.sol +7 -5
- package/contracts/pool/IBundleService.sol +1 -1
- package/contracts/pool/IPoolService.sol +6 -5
- package/contracts/pool/Pool.sol +3 -1
- package/contracts/pool/PoolLib.sol +102 -5
- package/contracts/pool/PoolService.sol +101 -67
- package/contracts/pool/PoolServiceManager.sol +6 -4
- package/contracts/product/ApplicationService.sol +34 -13
- package/contracts/product/ApplicationServiceManager.sol +6 -4
- package/contracts/product/BasicProduct.sol +2 -0
- package/contracts/product/BasicProductAuthorization.sol +7 -7
- package/contracts/product/ClaimService.sol +34 -10
- package/contracts/product/ClaimServiceManager.sol +7 -5
- package/contracts/product/IPolicyService.sol +2 -1
- package/contracts/product/PolicyService.sol +58 -45
- package/contracts/product/PolicyServiceLib.sol +5 -3
- package/contracts/product/PolicyServiceManager.sol +6 -4
- package/contracts/product/PricingService.sol +8 -7
- package/contracts/product/PricingServiceManager.sol +6 -4
- package/contracts/product/Product.sol +2 -0
- package/contracts/product/RiskService.sol +40 -8
- package/contracts/product/RiskServiceManager.sol +6 -4
- package/contracts/registry/ChainNft.sol +1 -1
- package/contracts/registry/IRegistry.sol +14 -20
- package/contracts/registry/IRegistryService.sol +14 -10
- package/contracts/registry/IRelease.sol +3 -0
- package/contracts/registry/Registry.sol +78 -124
- package/contracts/registry/RegistryAdmin.sol +29 -12
- package/contracts/registry/RegistryAuthorization.sol +3 -4
- package/contracts/registry/RegistryService.sol +82 -99
- package/contracts/registry/RegistryServiceManager.sol +11 -4
- package/contracts/registry/ReleaseAdmin.sol +23 -9
- package/contracts/registry/ReleaseRegistry.sol +74 -64
- package/contracts/registry/ServiceAuthorizationV3.sol +3 -4
- package/contracts/registry/TokenRegistry.sol +15 -6
- package/contracts/shared/Component.sol +22 -27
- package/contracts/shared/ComponentService.sol +135 -45
- package/contracts/shared/ComponentServiceManager.sol +7 -5
- package/contracts/shared/ContractLib.sol +93 -359
- package/contracts/shared/EcdsaChecker.sol +5 -0
- package/contracts/shared/IAuthorizedComponent.sol +15 -0
- package/contracts/shared/IComponent.sol +3 -5
- package/contracts/shared/IComponentService.sol +15 -0
- package/contracts/shared/IInstanceLinkedComponent.sol +9 -9
- package/contracts/shared/INftOwnable.sol +2 -0
- package/contracts/shared/IRegisterable.sol +3 -14
- package/contracts/shared/IRegistryLinked.sol +3 -1
- package/contracts/shared/IService.sol +2 -2
- package/contracts/shared/InstanceLinkedComponent.sol +130 -39
- package/contracts/shared/NftOwnable.sol +22 -9
- package/contracts/shared/PolicyHolder.sol +4 -2
- package/contracts/shared/Registerable.sol +20 -37
- package/contracts/shared/RegistryLinked.sol +23 -4
- package/contracts/shared/Service.sol +9 -8
- package/contracts/shared/TokenHandler.sol +1 -4
- package/contracts/staking/IStaking.sol +4 -2
- package/contracts/staking/IStakingService.sol +1 -1
- package/contracts/staking/Staking.sol +34 -28
- package/contracts/staking/StakingLib.sol +1 -3
- package/contracts/staking/StakingManager.sol +6 -3
- package/contracts/staking/StakingReader.sol +17 -9
- package/contracts/staking/StakingService.sol +14 -17
- package/contracts/staking/StakingServiceManager.sol +8 -4
- package/contracts/staking/StakingStore.sol +8 -8
- package/contracts/staking/TargetHandler.sol +5 -4
- package/contracts/type/ObjectType.sol +2 -31
- package/contracts/type/Referral.sol +6 -0
- package/contracts/type/RequestIdSet.sol +62 -0
- package/contracts/type/Seconds.sol +4 -0
- package/contracts/type/String.sol +30 -0
- package/contracts/type/Timestamp.sol +10 -1
- package/contracts/type/Version.sol +16 -15
- package/contracts/upgradeability/{IUpgradeable.sol → IVersionable.sol} +19 -13
- package/contracts/upgradeability/ProxyManager.sol +54 -46
- package/contracts/upgradeability/{Upgradeable.sol → Versionable.sol} +14 -25
- package/package.json +2 -1
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +0 -4
- package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +0 -74
- package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +0 -4
- package/artifacts/contracts/shared/Versionable.sol/Versionable.json +0 -74
- package/artifacts/contracts/upgradeability/IUpgradeable.sol/IUpgradeable.dbg.json +0 -4
- package/artifacts/contracts/upgradeability/Upgradeable.sol/Upgradeable.dbg.json +0 -4
- package/contracts/shared/IVersionable.sol +0 -19
- package/contracts/shared/Versionable.sol +0 -47
@@ -5,376 +5,114 @@ import {ERC165Checker} from "@openzeppelin/contracts/utils/introspection/ERC165C
|
|
5
5
|
import {IAccessManager} from "@openzeppelin/contracts/access/manager/IAccessManager.sol";
|
6
6
|
import {IAccessManaged} from "@openzeppelin/contracts/access/manager/IAccessManaged.sol";
|
7
7
|
|
8
|
-
import {IInstance} from "../instance/IInstance.sol";
|
9
|
-
import {IOracleComponent} from "../oracle/IOracleComponent.sol";
|
10
8
|
import {IPolicyHolder} from "../shared/IPolicyHolder.sol";
|
11
9
|
import {IRegistry} from "../registry/IRegistry.sol";
|
12
10
|
import {IService} from "../shared/IService.sol";
|
13
11
|
|
14
12
|
import {ChainId} from "../type/ChainId.sol";
|
15
13
|
import {NftId} from "../type/NftId.sol";
|
16
|
-
import {ObjectType, INSTANCE,
|
17
|
-
import {TokenRegistry} from "../registry/TokenRegistry.sol";
|
14
|
+
import {ObjectType, INSTANCE, PRODUCT, DISTRIBUTION, ORACLE, POOL} from "../type/ObjectType.sol";
|
18
15
|
import {VersionPart} from "../type/Version.sol";
|
19
16
|
|
20
17
|
interface ITargetHelper {
|
21
18
|
function isTargetLocked(address target) external view returns (bool);
|
22
19
|
}
|
23
20
|
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
error ErrorContractLibCallerNotComponent(/*address caller, */NftId callerNftId, ObjectType callerType);
|
28
|
-
error ErrorContractLibParentNotInstance(/*address component, */NftId componentNftId, NftId parentNftId/*, ObjectType parentType*/);
|
29
|
-
error ErrorContractLibParentNotProduct(/*address component, */NftId componentNftId, NftId parentNftId/*, ObjectType parentType*/);
|
30
|
-
error ErrorContractLibComponentTypeMismatch(/*address component, */NftId componentNftId, ObjectType expectedType, ObjectType actualType);
|
31
|
-
error ErrorContractLibComponentReleaseMismatch(/*address component, */NftId componentNftId, VersionPart expectedRelease, VersionPart actualRelease);
|
32
|
-
error ErrorContractLibComponentInactive(/*address component, */NftId componentNftId);
|
33
|
-
|
34
|
-
error ErrorContractLibObjectNotRegistered(NftId objectNftId);
|
35
|
-
error ErrorContractLibObjectTypeMismatch(NftId objectNftId, ObjectType expectedType, ObjectType actualType);
|
36
|
-
error ErrorContractLibObjectReleaseMismatch(NftId objectNftId, VersionPart expectedRelease, VersionPart actualRelease);
|
37
|
-
error ErrorContractLibObjectParentMismatch(NftId objectNftId, NftId expectedParentNftId, NftId actualParentNftId);
|
38
|
-
|
39
|
-
error ErrorContractLibParentsMismatch(NftId componentNftId, NftId componentParentNftId, NftId objectNftId, NftId objectParentNftId);
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
// update registry address whenever it changes
|
44
|
-
address public constant REGISTRY_ADDRESS = address(0xD38896EE8e95078A53d1e2122F111F518EFbD443);
|
45
|
-
|
46
|
-
function getRegistry() internal pure returns (IRegistry) {
|
47
|
-
return IRegistry(REGISTRY_ADDRESS);
|
48
|
-
}
|
49
|
-
|
50
|
-
function getAndVerifyProduct(VersionPart expectedRelease)
|
51
|
-
external
|
52
|
-
view
|
53
|
-
returns (
|
54
|
-
NftId, // productNftId
|
55
|
-
IInstance // instance,
|
56
|
-
)
|
57
|
-
{
|
58
|
-
return getAndVerifyComponent(
|
59
|
-
msg.sender,
|
60
|
-
PRODUCT(),
|
61
|
-
expectedRelease,
|
62
|
-
true); // only active product
|
63
|
-
}
|
64
|
-
|
65
|
-
function getAndVerifyPool(VersionPart expectedRelease)
|
66
|
-
external
|
67
|
-
view
|
68
|
-
returns (
|
69
|
-
NftId, // poolNftId
|
70
|
-
IInstance // instance,
|
71
|
-
)
|
72
|
-
{
|
73
|
-
return getAndVerifyComponent(
|
74
|
-
msg.sender,
|
75
|
-
POOL(),
|
76
|
-
expectedRelease,
|
77
|
-
true); // only active pool
|
78
|
-
}
|
79
|
-
|
80
|
-
function getAndVerifyProductForPolicy(NftId policyNftId, VersionPart expectedRelease)
|
81
|
-
external
|
82
|
-
view
|
83
|
-
returns (
|
84
|
-
NftId, // productNftId
|
85
|
-
IInstance // instance,
|
86
|
-
)
|
87
|
-
{
|
88
|
-
return getAndVerifyComponentWithChild(
|
89
|
-
msg.sender, // product
|
90
|
-
true, // only active product
|
91
|
-
policyNftId, // child nft id
|
92
|
-
POLICY(), // child must be policy
|
93
|
-
expectedRelease);
|
94
|
-
}
|
21
|
+
interface IInstanceAdminHelper {
|
22
|
+
function getInstanceAdmin() external view returns (ITargetHelper);
|
23
|
+
}
|
95
24
|
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
returns (
|
100
|
-
NftId, // poolNftId
|
101
|
-
IInstance // instance,
|
102
|
-
)
|
103
|
-
{
|
104
|
-
return getAndVerifyComponentWithChild({
|
105
|
-
component: msg.sender, // pool
|
106
|
-
onlyActive: true, // only active pool
|
107
|
-
childNftId: bundleNftId, // child nft id
|
108
|
-
expectedChildType: BUNDLE(), // child must be bundle
|
109
|
-
expectedRelease: expectedRelease});
|
110
|
-
}
|
25
|
+
interface ITokenRegistryHelper {
|
26
|
+
function isActive(ChainId chainId, address token, VersionPart release) external view returns (bool);
|
27
|
+
}
|
111
28
|
|
112
|
-
|
113
|
-
external
|
114
|
-
view
|
115
|
-
returns (
|
116
|
-
NftId poolNftId,
|
117
|
-
IInstance instance
|
118
|
-
)
|
119
|
-
{
|
120
|
-
(poolNftId,, instance) = getAndVerifyComponentAndObject({
|
121
|
-
component: msg.sender, // pool
|
122
|
-
expectedComponentType: POOL(),
|
123
|
-
onlyActive: true,
|
124
|
-
objectNftId: policyNftId,
|
125
|
-
expectedObjectType: POLICY(),
|
126
|
-
expectedRelease: expectedRelease
|
127
|
-
});
|
128
|
-
}
|
29
|
+
library ContractLib {
|
129
30
|
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
)
|
134
|
-
|
135
|
-
|
136
|
-
returns (
|
137
|
-
NftId requesterNftId,
|
138
|
-
IOracleComponent oracle,
|
139
|
-
IInstance instance
|
140
|
-
)
|
141
|
-
{
|
142
|
-
address oracleAddress;
|
143
|
-
(requesterNftId, oracleAddress, instance) = getAndVerifyComponentAndObject({
|
144
|
-
component: msg.sender,
|
145
|
-
expectedComponentType: COMPONENT(),
|
146
|
-
onlyActive: true,
|
147
|
-
objectNftId: oracleNftId,
|
148
|
-
expectedObjectType: ORACLE(),
|
149
|
-
expectedRelease: expectedRelease
|
150
|
-
});
|
151
|
-
|
152
|
-
oracle = IOracleComponent(oracleAddress);
|
153
|
-
}
|
31
|
+
error ErrorContractLibCallerNotRegistered(address target);
|
32
|
+
error ErrorContractLibCallerNotComponent(NftId componentNftId, ObjectType objectType);
|
33
|
+
error ErrorContractLibParentNotInstance(NftId componentNftId, NftId parentNftId);
|
34
|
+
error ErrorContractLibParentNotProduct(NftId componentNftId, NftId parentNftId);
|
35
|
+
error ErrorContractLibComponentTypeMismatch(NftId componentNftId, ObjectType expectedType, ObjectType actualType);
|
36
|
+
error ErrorContractLibComponentInactive(NftId componentNftId);
|
154
37
|
|
155
38
|
|
156
39
|
function getInfoAndInstance(
|
40
|
+
IRegistry registry,
|
157
41
|
NftId componentNftId,
|
158
|
-
VersionPart release,
|
159
42
|
bool onlyActive
|
160
43
|
)
|
161
|
-
|
44
|
+
external
|
162
45
|
view
|
163
46
|
returns (
|
164
47
|
IRegistry.ObjectInfo memory info,
|
165
|
-
|
48
|
+
address instance
|
166
49
|
)
|
167
50
|
{
|
168
|
-
IRegistry registry = getRegistry();
|
169
51
|
info = registry.getObjectInfo(componentNftId);
|
170
|
-
(,
|
52
|
+
return _getAndVerifyComponentAndInstance(registry, info, info.objectType, onlyActive);
|
171
53
|
}
|
172
54
|
|
173
55
|
|
174
|
-
function
|
56
|
+
function getAndVerifyAnyComponent(
|
57
|
+
IRegistry registry,
|
175
58
|
address caller,
|
176
|
-
ObjectType expectedType,
|
177
|
-
VersionPart expectedRelease,
|
178
59
|
bool onlyActive
|
179
60
|
)
|
180
|
-
|
61
|
+
external
|
181
62
|
view
|
182
63
|
returns (
|
183
|
-
|
184
|
-
|
64
|
+
IRegistry.ObjectInfo memory callerInfo,
|
65
|
+
address instance
|
185
66
|
)
|
186
67
|
{
|
187
|
-
// check caller is
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
ObjectType expectedChildType, // assume valid component type
|
198
|
-
VersionPart expectedRelease
|
199
|
-
)
|
200
|
-
public
|
201
|
-
view
|
202
|
-
returns (
|
203
|
-
//IRegistry.ObjectInfo memory info, // component info
|
204
|
-
NftId componentNftId,
|
205
|
-
IInstance instance)
|
206
|
-
{
|
207
|
-
IRegistry registry = getRegistry();
|
208
|
-
IRegistry.ObjectInfo memory info = registry.getObjectInfo(childNftId);
|
209
|
-
|
210
|
-
// check child registration
|
211
|
-
if(info.nftId.eqz()) {
|
212
|
-
revert ErrorContractLibObjectNotRegistered(childNftId);
|
213
|
-
}
|
214
|
-
|
215
|
-
// check child type
|
216
|
-
if(info.objectType != expectedChildType) {
|
217
|
-
revert ErrorContractLibObjectTypeMismatch(
|
218
|
-
childNftId,
|
219
|
-
expectedChildType,
|
220
|
-
info.objectType);
|
221
|
-
}
|
222
|
-
|
223
|
-
// check child release
|
224
|
-
if(info.release != expectedRelease) {
|
225
|
-
revert ErrorContractLibObjectReleaseMismatch(
|
226
|
-
childNftId,
|
227
|
-
expectedRelease,
|
228
|
-
info.release);
|
229
|
-
}
|
230
|
-
|
231
|
-
info = registry.getObjectInfo(info.parentNftId);
|
232
|
-
componentNftId = info.nftId;
|
233
|
-
|
234
|
-
// check parent is component
|
235
|
-
if(info.objectAddress != component) {
|
236
|
-
revert ErrorContractLibObjectParentMismatch(
|
237
|
-
childNftId,
|
238
|
-
registry.getNftIdForAddress(component),
|
239
|
-
info.nftId);
|
68
|
+
// check caller is component
|
69
|
+
callerInfo = _getAndVerifyObjectInfo(registry, caller);
|
70
|
+
if(!(callerInfo.objectType == PRODUCT()
|
71
|
+
|| callerInfo.objectType == POOL()
|
72
|
+
|| callerInfo.objectType == DISTRIBUTION()
|
73
|
+
|| callerInfo.objectType == ORACLE())
|
74
|
+
) {
|
75
|
+
revert ErrorContractLibCallerNotComponent(
|
76
|
+
callerInfo.nftId,
|
77
|
+
callerInfo.objectType);
|
240
78
|
}
|
241
79
|
|
242
|
-
|
243
|
-
instance = getAndVerifyInstance(info);// _getAndVerifyInstance(info);
|
244
|
-
|
245
|
-
// check component is active
|
246
|
-
_checkComponentActive(
|
247
|
-
instance,
|
248
|
-
component,
|
249
|
-
componentNftId,
|
250
|
-
onlyActive);
|
80
|
+
return _getAndVerifyComponentAndInstance(registry, callerInfo, callerInfo.objectType, onlyActive);
|
251
81
|
}
|
252
82
|
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
ObjectType expectedComponentType,
|
260
|
-
bool onlyActive,
|
261
|
-
NftId objectNftId,
|
262
|
-
ObjectType expectedObjectType,
|
263
|
-
VersionPart expectedRelease
|
83
|
+
|
84
|
+
function getAndVerifyComponent(
|
85
|
+
IRegistry registry,
|
86
|
+
address caller,
|
87
|
+
ObjectType expectedType,
|
88
|
+
bool onlyActive
|
264
89
|
)
|
265
|
-
|
90
|
+
external
|
266
91
|
view
|
267
92
|
returns (
|
268
|
-
|
269
|
-
address
|
270
|
-
|
93
|
+
IRegistry.ObjectInfo memory info,
|
94
|
+
address instance
|
95
|
+
)
|
271
96
|
{
|
272
|
-
|
273
|
-
|
274
|
-
IRegistry.ObjectInfo memory componentInfo = registry.getObjectInfo(component);
|
275
|
-
componentNftId = componentInfo.nftId;
|
276
|
-
|
277
|
-
// check component registered
|
278
|
-
|
279
|
-
// check component type
|
280
|
-
if(expectedComponentType != COMPONENT()) {
|
281
|
-
if(componentInfo.objectType != expectedComponentType) {
|
282
|
-
revert ErrorContractLibComponentTypeMismatch(
|
283
|
-
//component,
|
284
|
-
componentInfo.nftId,
|
285
|
-
expectedComponentType,
|
286
|
-
componentInfo.objectType);
|
287
|
-
}
|
288
|
-
} else if(
|
289
|
-
!(
|
290
|
-
componentInfo.objectType == PRODUCT() ||
|
291
|
-
componentInfo.objectType == POOL() ||
|
292
|
-
componentInfo.objectType == DISTRIBUTION() ||
|
293
|
-
componentInfo.objectType == ORACLE()
|
294
|
-
)
|
295
|
-
) {
|
296
|
-
revert ErrorContractLibCallerNotComponent(
|
297
|
-
//component,
|
298
|
-
componentInfo.nftId,
|
299
|
-
componentInfo.objectType);
|
300
|
-
}
|
301
|
-
|
302
|
-
// check component release
|
303
|
-
if(componentInfo.release != expectedRelease) {
|
304
|
-
revert ErrorContractLibComponentReleaseMismatch(
|
305
|
-
//component,
|
306
|
-
componentInfo.nftId,
|
307
|
-
expectedRelease,
|
308
|
-
componentInfo.release);
|
309
|
-
}
|
310
|
-
|
311
|
-
IRegistry.ObjectInfo memory objectInfo = registry.getObjectInfo(objectNftId);
|
312
|
-
objectAddress = objectInfo.objectAddress;
|
313
|
-
|
314
|
-
// check object type
|
315
|
-
if(objectInfo.objectType != expectedObjectType) {
|
316
|
-
revert ErrorContractLibObjectTypeMismatch(
|
317
|
-
objectNftId,
|
318
|
-
expectedObjectType,
|
319
|
-
objectInfo.objectType);
|
320
|
-
}
|
321
|
-
|
322
|
-
if(componentInfo.objectType == PRODUCT()) {
|
323
|
-
// check object parent is product
|
324
|
-
if(componentInfo.nftId != objectInfo.parentNftId) {
|
325
|
-
revert ErrorContractLibObjectParentMismatch(
|
326
|
-
objectNftId,
|
327
|
-
objectInfo.parentNftId,
|
328
|
-
componentInfo.nftId);
|
329
|
-
}
|
330
|
-
} else {
|
331
|
-
// check component parent is product
|
332
|
-
|
333
|
-
// check object parent is same product
|
334
|
-
if(componentInfo.parentNftId != objectInfo.parentNftId) {
|
335
|
-
revert ErrorContractLibParentsMismatch(
|
336
|
-
componentInfo.nftId,
|
337
|
-
componentInfo.parentNftId,
|
338
|
-
objectNftId,
|
339
|
-
objectInfo.parentNftId);
|
340
|
-
}
|
341
|
-
}
|
342
|
-
|
343
|
-
// get instance
|
344
|
-
instance = getAndVerifyInstance(componentInfo);
|
345
|
-
|
346
|
-
// check component is active
|
347
|
-
_checkComponentActive(
|
348
|
-
instance,
|
349
|
-
component,
|
350
|
-
componentNftId,
|
351
|
-
onlyActive);
|
97
|
+
info = _getAndVerifyObjectInfo(registry, caller);
|
98
|
+
return _getAndVerifyComponentAndInstance(registry, info, expectedType, onlyActive);
|
352
99
|
}
|
353
100
|
|
354
101
|
|
355
102
|
function getInstanceForComponent(
|
103
|
+
IRegistry registry,
|
356
104
|
NftId componentNftId
|
357
105
|
)
|
358
106
|
public
|
359
107
|
view
|
360
108
|
returns (address instance)
|
361
109
|
{
|
362
|
-
IRegistry registry = getRegistry();
|
363
110
|
NftId productNftId = registry.getParentNftId(componentNftId);
|
364
111
|
NftId instanceNftId = registry.getParentNftId(productNftId);
|
365
112
|
return registry.getObjectInfo(instanceNftId).objectAddress;
|
366
113
|
}
|
367
114
|
|
368
|
-
// TODO check array of nfts and array of types
|
369
|
-
// need to call: checkNftType({nftId: {nftId1, nftId2, nftId3}, expectedObjectType: {.., .., ..}})
|
370
|
-
/*function checkNftType(NftId nftId, ObjectType expectedObjectType) external view {
|
371
|
-
VersionPart expectedRelease = getRelease();
|
372
|
-
if(expectedObjectType.eqz() || !_getRegistry().isObjectType(nftId, expectedObjectType, expectedRelease)) {
|
373
|
-
revert ErrorNftOwnableInvalidType(nftId, expectedObjectType, expectedRelease);
|
374
|
-
}
|
375
|
-
}*/
|
376
115
|
|
377
|
-
// TODO hardcoded token registry address?
|
378
116
|
function isActiveToken(
|
379
117
|
address tokenRegistryAddress,
|
380
118
|
ChainId chainId,
|
@@ -385,7 +123,7 @@ library ContractLib {
|
|
385
123
|
view
|
386
124
|
returns (bool)
|
387
125
|
{
|
388
|
-
return
|
126
|
+
return ITokenRegistryHelper(
|
389
127
|
tokenRegistryAddress).isActive(
|
390
128
|
chainId, token, release);
|
391
129
|
}
|
@@ -422,6 +160,16 @@ library ContractLib {
|
|
422
160
|
}
|
423
161
|
|
424
162
|
|
163
|
+
function isRegistered(address registry, address caller, ObjectType expectedType) public view returns (bool) {
|
164
|
+
NftId nftId = IRegistry(registry).getNftIdForAddress(caller);
|
165
|
+
if (nftId.eqz()) {
|
166
|
+
return false;
|
167
|
+
}
|
168
|
+
|
169
|
+
return IRegistry(registry).getObjectInfo(nftId).objectType == expectedType;
|
170
|
+
}
|
171
|
+
|
172
|
+
|
425
173
|
function isService(address service) public view returns (bool) {
|
426
174
|
if (!isContract(service)) {
|
427
175
|
return false;
|
@@ -431,8 +179,12 @@ library ContractLib {
|
|
431
179
|
}
|
432
180
|
|
433
181
|
|
434
|
-
function isRegistry(address registry) public
|
435
|
-
|
182
|
+
function isRegistry(address registry) public view returns (bool) {
|
183
|
+
if (!isContract(registry)) {
|
184
|
+
return false;
|
185
|
+
}
|
186
|
+
|
187
|
+
return supportsInterface(registry, type(IRegistry).interfaceId);
|
436
188
|
}
|
437
189
|
|
438
190
|
|
@@ -454,59 +206,39 @@ library ContractLib {
|
|
454
206
|
|
455
207
|
|
456
208
|
function _getAndVerifyComponentAndInstance(
|
209
|
+
IRegistry registry,
|
457
210
|
IRegistry.ObjectInfo memory info,
|
458
211
|
ObjectType expectedType,
|
459
|
-
VersionPart expectedRelease,
|
460
212
|
bool onlyActive
|
461
213
|
)
|
462
214
|
internal
|
463
215
|
view
|
464
216
|
returns (
|
465
|
-
|
466
|
-
|
217
|
+
IRegistry.ObjectInfo memory,
|
218
|
+
address instance
|
467
219
|
)
|
468
220
|
{
|
469
|
-
if(
|
470
|
-
|
471
|
-
revert ErrorContractLibComponentTypeMismatch(
|
472
|
-
//info.objectAddress,
|
473
|
-
info.nftId,
|
474
|
-
expectedType,
|
475
|
-
info.objectType);
|
476
|
-
}
|
477
|
-
} else if(
|
478
|
-
!(
|
479
|
-
info.objectType == PRODUCT() ||
|
480
|
-
info.objectType == POOL() ||
|
481
|
-
info.objectType == DISTRIBUTION() ||
|
482
|
-
info.objectType == ORACLE()
|
483
|
-
)
|
484
|
-
) {
|
485
|
-
revert ErrorContractLibCallerNotComponent(
|
486
|
-
//info.objectAddress,
|
221
|
+
if(info.objectType != expectedType) {
|
222
|
+
revert ErrorContractLibComponentTypeMismatch(
|
487
223
|
info.nftId,
|
224
|
+
expectedType,
|
488
225
|
info.objectType);
|
489
226
|
}
|
490
227
|
|
491
|
-
if(info.release != expectedRelease) {
|
492
|
-
revert ErrorContractLibComponentReleaseMismatch(
|
493
|
-
//info.objectAddress,
|
494
|
-
info.nftId,
|
495
|
-
expectedRelease,
|
496
|
-
info.release);
|
497
|
-
}
|
498
|
-
|
499
|
-
componentNftId = info.nftId;
|
500
|
-
|
501
228
|
// get instance and check component is active
|
502
|
-
instance = getAndVerifyInstance(info);
|
229
|
+
instance = getAndVerifyInstance(registry, info);
|
503
230
|
_checkComponentActive(instance, info.objectAddress, info.nftId, onlyActive);
|
231
|
+
|
232
|
+
return (
|
233
|
+
info,
|
234
|
+
instance
|
235
|
+
);
|
504
236
|
}
|
505
237
|
|
506
238
|
|
507
239
|
function _checkComponentActive(
|
508
|
-
|
509
|
-
address
|
240
|
+
address instance,
|
241
|
+
address target,
|
510
242
|
NftId componentNftId,
|
511
243
|
bool onlyActive
|
512
244
|
)
|
@@ -514,8 +246,11 @@ library ContractLib {
|
|
514
246
|
view
|
515
247
|
{
|
516
248
|
if (onlyActive) {
|
517
|
-
if (
|
518
|
-
|
249
|
+
if (IInstanceAdminHelper(
|
250
|
+
instance).getInstanceAdmin().isTargetLocked(
|
251
|
+
target)
|
252
|
+
) {
|
253
|
+
revert ErrorContractLibComponentInactive(componentNftId);
|
519
254
|
}
|
520
255
|
}
|
521
256
|
}
|
@@ -525,14 +260,13 @@ library ContractLib {
|
|
525
260
|
/// The info may represent a product or any other component.
|
526
261
|
/// If the parent of the provided info is not registered with the correct type, the function reverts.
|
527
262
|
function getAndVerifyInstance(
|
263
|
+
IRegistry registry,
|
528
264
|
IRegistry.ObjectInfo memory info
|
529
265
|
)
|
530
266
|
public
|
531
267
|
view
|
532
|
-
returns (
|
268
|
+
returns (address instance)
|
533
269
|
{
|
534
|
-
IRegistry registry = getRegistry();
|
535
|
-
|
536
270
|
// get instance for product case
|
537
271
|
if (info.objectType == PRODUCT()) {
|
538
272
|
// verify that parent of product is registered instance
|
@@ -544,7 +278,7 @@ library ContractLib {
|
|
544
278
|
}
|
545
279
|
|
546
280
|
// we have verified that parent object is a registerd instance -> we return the instance address
|
547
|
-
return
|
281
|
+
return instanceInfo.objectAddress;
|
548
282
|
}
|
549
283
|
|
550
284
|
// not product: verify parent is registered product
|
@@ -556,23 +290,23 @@ library ContractLib {
|
|
556
290
|
}
|
557
291
|
|
558
292
|
// we have verified that parent is registerd product -> we can rely on registry that its parent is an instance
|
559
|
-
return
|
293
|
+
return registry.getObjectAddress(info.parentNftId);
|
560
294
|
}
|
561
295
|
|
562
|
-
|
296
|
+
|
563
297
|
function _getAndVerifyObjectInfo(
|
298
|
+
IRegistry registry,
|
564
299
|
address caller
|
565
300
|
)
|
566
301
|
internal
|
567
302
|
view
|
568
303
|
returns (IRegistry.ObjectInfo memory info)
|
569
304
|
{
|
570
|
-
|
571
|
-
|
572
|
-
info = registry.getObjectInfo(caller);
|
573
|
-
|
574
|
-
if (info.nftId.eqz()) {
|
305
|
+
NftId componentNftId = registry.getNftIdForAddress(caller);
|
306
|
+
if (componentNftId.eqz()) {
|
575
307
|
revert ErrorContractLibCallerNotRegistered(caller);
|
576
308
|
}
|
309
|
+
|
310
|
+
info = registry.getObjectInfo(componentNftId);
|
577
311
|
}
|
578
312
|
}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
// SPDX-License-Identifier: Apache-2.0
|
2
|
+
pragma solidity ^0.8.20;
|
3
|
+
|
4
|
+
import {IComponent} from "../shared/IComponent.sol";
|
5
|
+
import {IAuthorization} from "../authorization/IAuthorization.sol";
|
6
|
+
|
7
|
+
/// @dev component base class
|
8
|
+
/// component examples are product, distribution, pool and oracle
|
9
|
+
interface IAuthorizedComponent is
|
10
|
+
IComponent
|
11
|
+
{
|
12
|
+
/// @dev returns the initial component authorization specification.
|
13
|
+
function getAuthorization() external view returns (IAuthorization authorization);
|
14
|
+
|
15
|
+
}
|
@@ -29,11 +29,6 @@ interface IComponent is
|
|
29
29
|
event LogComponentWalletTokensTransferred(address from, address to, uint256 amount);
|
30
30
|
event LogComponentTokenHandlerApproved(address tokenHandler, address token, Amount limit, bool isMaxAmount);
|
31
31
|
|
32
|
-
/// @dev Withdraw fees from the distribution component. Only component owner is allowed to withdraw fees.
|
33
|
-
/// @param amount the amount to withdraw
|
34
|
-
/// @return withdrawnAmount the amount that was actually withdrawn
|
35
|
-
function withdrawFees(Amount amount) external returns (Amount withdrawnAmount);
|
36
|
-
|
37
32
|
/// @dev returns the name of this component
|
38
33
|
/// to successfully register the component with an instance the name MUST be unique in the linked instance
|
39
34
|
function getName() external view returns (string memory name);
|
@@ -48,6 +43,9 @@ interface IComponent is
|
|
48
43
|
/// the default address is the token handler address
|
49
44
|
function getWallet() external view returns (address walletAddress);
|
50
45
|
|
46
|
+
/// @dev returns true iff this compoent intercepts nft minting and transfers for objects registered by this component
|
47
|
+
function isNftInterceptor() external view returns(bool isInterceptor);
|
48
|
+
|
51
49
|
/// @dev returns true iff this component is registered with the registry
|
52
50
|
function isRegistered() external view returns (bool);
|
53
51
|
|