@etherisc/gif-next 0.0.2-afb1eb8-589 → 0.0.2-afc3897-527
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 +95 -9
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingService.sol/AccountingService.json +1075 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.dbg.json +4 -0
- package/artifacts/contracts/accounting/AccountingServiceManager.sol/AccountingServiceManager.json +790 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.dbg.json +4 -0
- package/artifacts/contracts/accounting/IAccountingService.sol/IAccountingService.json +843 -0
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessAdmin.sol/AccessAdmin.json +673 -262
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.dbg.json +4 -0
- package/artifacts/contracts/authorization/AccessAdminLib.sol/AccessAdminLib.json +1289 -0
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.dbg.json +1 -1
- package/artifacts/contracts/authorization/AccessManagerCloneable.sol/AccessManagerCloneable.json +202 -5
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/Authorization.sol/Authorization.json +456 -24
- 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 +549 -209
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IAuthorization.sol/IAuthorization.json +215 -18
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/IServiceAuthorization.sol/IServiceAuthorization.json +265 -16
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.dbg.json +1 -1
- package/artifacts/contracts/authorization/ServiceAuthorization.sol/ServiceAuthorization.json +473 -17
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistribution.sol/BasicDistribution.json +183 -487
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.dbg.json +1 -1
- package/artifacts/contracts/distribution/BasicDistributionAuthorization.sol/BasicDistributionAuthorization.json +431 -36
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.dbg.json +1 -1
- package/artifacts/contracts/distribution/Distribution.sol/Distribution.json +102 -387
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionService.sol/DistributionService.json +644 -392
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
- package/artifacts/contracts/distribution/DistributionServiceManager.sol/DistributionServiceManager.json +209 -133
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionComponent.sol/IDistributionComponent.json +96 -191
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.dbg.json +1 -1
- package/artifacts/contracts/distribution/IDistributionService.sol/IDistributionService.json +476 -137
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/DamageLevel.sol/DamageLevelLib.json +22 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePool.sol/FirePool.json +1484 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FirePoolAuthorization.sol/FirePoolAuthorization.json +805 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProduct.sol/FireProduct.json +2053 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireProductAuthorization.sol/FireProductAuthorization.json +805 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.dbg.json +4 -0
- package/artifacts/contracts/examples/fire/FireUSD.sol/FireUSD.json +376 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistribution.sol/SimpleDistribution.json +1439 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol/SimpleDistributionAuthorization.json +805 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleOracle.sol/SimpleOracle.json +1171 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePool.sol/SimplePool.json +1647 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimplePoolAuthorization.sol/SimplePoolAuthorization.json +805 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProduct.sol/SimpleProduct.json +2585 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.dbg.json +4 -0
- package/artifacts/contracts/examples/unpermissioned/SimpleProductAuthorization.sol/SimpleProductAuthorization.json +805 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/BaseStore.sol/BaseStore.json +498 -0
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.dbg.json +1 -1
- package/artifacts/contracts/instance/BundleSet.sol/BundleSet.json +193 -45
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.dbg.json +4 -0
- package/artifacts/contracts/instance/IBaseStore.sol/IBaseStore.json +470 -0
- package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstance.sol/IInstance.json +578 -65
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +395 -60
- package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
- package/artifacts/contracts/instance/Instance.sol/Instance.json +616 -183
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAdmin.sol/InstanceAdmin.json +1021 -363
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceAuthorizationV3.sol/InstanceAuthorizationV3.json +328 -92
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +1689 -736
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +409 -231
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +143 -105
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/InstanceStore.sol/InstanceStore.json +956 -1047
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.dbg.json +4 -0
- package/artifacts/contracts/instance/ProductStore.sol/ProductStore.json +1759 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.dbg.json +4 -0
- package/artifacts/contracts/instance/RiskSet.sol/RiskSet.json +866 -0
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.dbg.json +1 -1
- package/artifacts/contracts/instance/base/BalanceStore.sol/BalanceStore.json +8 -8
- package/artifacts/contracts/instance/base/Cloneable.sol/Cloneable.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectCounter.sol/ObjectCounter.json +2 -2
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectLifecycle.sol/ObjectLifecycle.json +46 -5
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.dbg.json +1 -1
- package/artifacts/contracts/instance/base/ObjectSet.sol/ObjectSet.json +16 -5
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.dbg.json +4 -0
- package/artifacts/contracts/instance/base/ObjectSetHelperLib.sol/ObjectSetHelperLib.json +168 -0
- 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 +127 -355
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.dbg.json +1 -1
- package/artifacts/contracts/oracle/BasicOracleAuthorization.sol/BasicOracleAuthorization.json +429 -37
- 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 +103 -133
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/IOracleService.sol/IOracleService.json +98 -11
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.dbg.json +1 -1
- package/artifacts/contracts/oracle/Oracle.sol/Oracle.json +103 -323
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleService.sol/OracleService.json +198 -190
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/oracle/OracleServiceManager.sol/OracleServiceManager.json +177 -97
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPool.sol/BasicPool.json +155 -383
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.dbg.json +1 -1
- package/artifacts/contracts/pool/BasicPoolAuthorization.sol/BasicPoolAuthorization.json +430 -35
- package/artifacts/contracts/pool/BundleService.sol/BundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleService.sol/BundleService.json +363 -446
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/BundleServiceManager.sol/BundleServiceManager.json +170 -134
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.dbg.json +1 -1
- package/artifacts/contracts/pool/IBundleService.sol/IBundleService.json +247 -152
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolComponent.sol/IPoolComponent.json +142 -183
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/IPoolService.sol/IPoolService.json +524 -288
- package/artifacts/contracts/pool/Pool.sol/Pool.dbg.json +1 -1
- package/artifacts/contracts/pool/Pool.sol/Pool.json +132 -363
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.dbg.json +4 -0
- package/artifacts/contracts/pool/PoolLib.sol/PoolLib.json +522 -0
- package/artifacts/contracts/pool/PoolService.sol/PoolService.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolService.sol/PoolService.json +705 -564
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
- package/artifacts/contracts/pool/PoolServiceManager.sol/PoolServiceManager.json +194 -122
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationService.sol/ApplicationService.json +353 -180
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ApplicationServiceManager.sol/ApplicationServiceManager.json +159 -99
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProduct.sol/BasicProduct.json +272 -431
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.dbg.json +1 -1
- package/artifacts/contracts/product/BasicProductAuthorization.sol/BasicProductAuthorization.json +430 -35
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimService.sol/ClaimService.json +466 -245
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/ClaimServiceManager.sol/ClaimServiceManager.json +187 -123
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.dbg.json +1 -1
- package/artifacts/contracts/product/IApplicationService.sol/IApplicationService.json +301 -9
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.dbg.json +1 -1
- package/artifacts/contracts/product/IClaimService.sol/IClaimService.json +350 -18
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/IPolicyService.sol/IPolicyService.json +358 -127
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.dbg.json +1 -1
- package/artifacts/contracts/product/IPricingService.sol/IPricingService.json +183 -80
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.dbg.json +1 -1
- package/artifacts/contracts/product/IProductComponent.sol/IProductComponent.json +257 -226
- package/artifacts/contracts/product/IRiskService.sol/IRiskService.dbg.json +4 -0
- package/artifacts/contracts/{shared/ComponentVerifyingService.sol/ComponentVerifyingService.json → product/IRiskService.sol/IRiskService.json} +283 -157
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyService.sol/PolicyService.json +477 -373
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.dbg.json +4 -0
- package/artifacts/contracts/product/PolicyServiceLib.sol/PolicyServiceLib.json +783 -0
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PolicyServiceManager.sol/PolicyServiceManager.json +196 -124
- package/artifacts/contracts/product/PricingService.sol/PricingService.dbg.json +1 -1
- package/artifacts/contracts/product/PricingService.sol/PricingService.json +247 -332
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/product/PricingServiceManager.sol/PricingServiceManager.json +165 -137
- package/artifacts/contracts/product/Product.sol/Product.dbg.json +1 -1
- package/artifacts/contracts/product/Product.sol/Product.json +264 -423
- package/artifacts/contracts/product/RiskService.sol/RiskService.dbg.json +4 -0
- package/artifacts/contracts/product/RiskService.sol/RiskService.json +873 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.dbg.json +4 -0
- package/artifacts/contracts/product/RiskServiceManager.sol/RiskServiceManager.json +774 -0
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.dbg.json +1 -1
- package/artifacts/contracts/registry/ChainNft.sol/ChainNft.json +59 -16
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistry.sol/IRegistry.json +359 -48
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +169 -37
- package/artifacts/contracts/registry/IRelease.sol/IRelease.dbg.json +4 -0
- package/artifacts/contracts/registry/IRelease.sol/IRelease.json +24 -0
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.dbg.json +1 -1
- package/artifacts/contracts/registry/ITransferInterceptor.sol/ITransferInterceptor.json +5 -18
- package/artifacts/contracts/registry/Registry.sol/Registry.dbg.json +1 -1
- package/artifacts/contracts/registry/Registry.sol/Registry.json +565 -109
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryAdmin.sol/RegistryAdmin.json +791 -377
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.dbg.json +4 -0
- package/artifacts/contracts/registry/RegistryAuthorization.sol/RegistryAuthorization.json +1074 -0
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +136 -290
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
- package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +141 -89
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.dbg.json +4 -0
- package/artifacts/contracts/registry/ReleaseAdmin.sol/ReleaseAdmin.json +2152 -0
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseLifecycle.sol/ReleaseLifecycle.json +47 -6
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/ReleaseRegistry.sol/ReleaseRegistry.json +483 -253
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.dbg.json +1 -1
- package/artifacts/contracts/registry/ServiceAuthorizationV3.sol/ServiceAuthorizationV3.json +489 -20
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
- package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +120 -60
- package/artifacts/contracts/shared/Component.sol/Component.dbg.json +1 -1
- package/artifacts/contracts/shared/Component.sol/Component.json +86 -277
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentService.sol/ComponentService.json +493 -638
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.dbg.json +1 -1
- package/artifacts/contracts/shared/ComponentServiceManager.sol/ComponentServiceManager.json +183 -133
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.dbg.json +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ContractLib.json +632 -0
- 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 +4 -0
- package/artifacts/contracts/shared/ContractLib.sol/ITargetHelper.json +30 -0
- 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/IComponent.sol/IComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponent.sol/IComponent.json +92 -93
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.dbg.json +1 -1
- package/artifacts/contracts/shared/IComponentService.sol/IComponentService.json +432 -290
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/IInstanceLinkedComponent.sol/IInstanceLinkedComponent.json +103 -133
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/IKeyValueStore.sol/IKeyValueStore.json +79 -6
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/ILifecycle.sol/ILifecycle.json +36 -0
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
- package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +35 -0
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +15 -47
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
- package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +167 -0
- package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
- package/artifacts/contracts/shared/IService.sol/IService.json +84 -2
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.dbg.json +1 -1
- package/artifacts/contracts/shared/InitializableERC165.sol/InitializableERC165.json +2 -22
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.dbg.json +1 -1
- package/artifacts/contracts/shared/InstanceLinkedComponent.sol/InstanceLinkedComponent.json +102 -322
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
- package/artifacts/contracts/shared/KeyValueStore.sol/KeyValueStore.json +85 -7
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.dbg.json +1 -1
- package/artifacts/contracts/shared/Lifecycle.sol/Lifecycle.json +42 -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 +41 -57
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +1 -1
- package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +19 -141
- package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
- package/artifacts/contracts/shared/Registerable.sol/Registerable.json +141 -97
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +1 -1
- package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +2 -15
- package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
- package/artifacts/contracts/shared/Service.sol/Service.json +86 -111
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.json +585 -12
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandler.sol/TokenHandlerBase.json +484 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.dbg.json +4 -0
- package/artifacts/contracts/shared/TokenHandlerDeployerLib.sol/TokenHandlerDeployerLib.json +172 -0
- package/artifacts/contracts/staking/IStaking.sol/IStaking.dbg.json +1 -1
- package/artifacts/contracts/staking/IStaking.sol/IStaking.json +1510 -191
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/IStakingService.sol/IStakingService.json +235 -123
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/ITargetLimitHandler.sol/ITargetLimitHandler.json +50 -0
- package/artifacts/contracts/staking/Staking.sol/Staking.dbg.json +1 -1
- package/artifacts/contracts/staking/Staking.sol/Staking.json +1635 -455
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.dbg.json +4 -0
- package/artifacts/contracts/staking/StakingLib.sol/StakingLib.json +470 -0
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingManager.sol/StakingManager.json +191 -105
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingReader.sol/StakingReader.json +295 -183
- package/artifacts/contracts/staking/StakingService.sol/StakingService.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingService.sol/StakingService.json +282 -281
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingServiceManager.sol/StakingServiceManager.json +144 -96
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.dbg.json +1 -1
- package/artifacts/contracts/staking/StakingStore.sol/StakingStore.json +1645 -790
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.dbg.json +4 -0
- package/artifacts/contracts/staking/TargetHandler.sol/TargetHandler.json +309 -0
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.dbg.json +1 -1
- package/artifacts/contracts/staking/TargetManagerLib.sol/TargetManagerLib.json +180 -77
- package/artifacts/contracts/type/AddressSet.sol/LibAddressSet.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.dbg.json +1 -1
- package/artifacts/contracts/type/Amount.sol/AmountLib.json +35 -11
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
- package/artifacts/contracts/type/Blocknumber.sol/BlocknumberLib.json +45 -19
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.dbg.json +4 -0
- package/artifacts/contracts/type/ChainId.sol/ChainIdLib.json +193 -0
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/ClaimId.sol/ClaimIdLib.json +28 -4
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
- package/artifacts/contracts/type/DistributorType.sol/DistributorTypeLib.json +2 -2
- package/artifacts/contracts/type/Fee.sol/FeeLib.dbg.json +1 -1
- package/artifacts/contracts/type/Fee.sol/FeeLib.json +94 -38
- 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 +4 -0
- package/artifacts/contracts/type/Key32Set.sol/LibKey32Set.json +33 -0
- package/artifacts/contracts/type/NftId.sol/NftIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/NftId.sol/NftIdLib.json +23 -4
- 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 +33 -31
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/PayoutId.sol/PayoutIdLib.json +19 -19
- package/artifacts/contracts/type/Referral.sol/ReferralLib.dbg.json +1 -1
- package/artifacts/contracts/type/Referral.sol/ReferralLib.json +2 -2
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RequestId.sol/RequestIdLib.json +2 -2
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RiskId.sol/RiskIdLib.json +125 -7
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/RoleId.sol/RoleIdLib.json +42 -157
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.dbg.json +1 -1
- package/artifacts/contracts/type/Seconds.sol/SecondsLib.json +69 -2
- package/artifacts/contracts/type/Selector.sol/SelectorLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorLib.json +21 -2
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.dbg.json +1 -1
- package/artifacts/contracts/type/Selector.sol/SelectorSetLib.json +2 -2
- package/artifacts/contracts/type/StateId.sol/StateIdLib.dbg.json +1 -1
- package/artifacts/contracts/type/StateId.sol/StateIdLib.json +15 -2
- package/artifacts/contracts/type/String.sol/StrLib.dbg.json +1 -1
- package/artifacts/contracts/type/String.sol/StrLib.json +50 -2
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.dbg.json +1 -1
- package/artifacts/contracts/type/Timestamp.sol/TimestampLib.json +3 -3
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.dbg.json +1 -1
- package/artifacts/contracts/type/UFixed.sol/UFixedLib.json +73 -36
- package/artifacts/contracts/type/Version.sol/VersionLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionLib.json +2 -21
- package/artifacts/contracts/type/Version.sol/VersionPartLib.dbg.json +1 -1
- package/artifacts/contracts/type/Version.sol/VersionPartLib.json +101 -2
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/IVersionable.sol/IVersionable.json +10 -0
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/ProxyManager.sol/ProxyManager.json +118 -79
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +15 -2
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.dbg.json +1 -1
- package/artifacts/contracts/upgradeability/Versionable.sol/Versionable.json +10 -0
- package/contracts/accounting/AccountingService.sol +274 -0
- package/contracts/accounting/AccountingServiceManager.sol +38 -0
- package/contracts/accounting/IAccountingService.sol +47 -0
- package/contracts/authorization/AccessAdmin.sol +458 -269
- package/contracts/authorization/AccessAdminLib.sol +396 -0
- package/contracts/authorization/AccessManagerCloneable.sol +146 -4
- package/contracts/authorization/Authorization.sol +159 -208
- package/contracts/authorization/IAccess.sol +25 -6
- package/contracts/authorization/IAccessAdmin.sol +87 -79
- package/contracts/authorization/IAuthorization.sol +9 -37
- package/contracts/authorization/IServiceAuthorization.sol +57 -17
- package/contracts/authorization/ServiceAuthorization.sol +255 -25
- package/contracts/distribution/BasicDistribution.sol +20 -17
- package/contracts/distribution/BasicDistributionAuthorization.sol +30 -10
- package/contracts/distribution/Distribution.sol +44 -92
- package/contracts/distribution/DistributionService.sol +243 -132
- package/contracts/distribution/DistributionServiceManager.sol +6 -6
- package/contracts/distribution/IDistributionComponent.sol +4 -11
- package/contracts/distribution/IDistributionService.sol +47 -29
- package/contracts/examples/fire/DamageLevel.sol +59 -0
- package/contracts/examples/fire/FirePool.sol +86 -0
- package/contracts/examples/fire/FirePoolAuthorization.sol +35 -0
- package/contracts/examples/fire/FireProduct.sol +433 -0
- package/contracts/examples/fire/FireProductAuthorization.sol +45 -0
- package/contracts/examples/fire/FireUSD.sol +26 -0
- package/contracts/examples/unpermissioned/SimpleDistribution.sol +81 -0
- package/contracts/examples/unpermissioned/SimpleDistributionAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleOracle.sol +133 -0
- package/contracts/examples/unpermissioned/SimplePool.sol +102 -0
- package/contracts/examples/unpermissioned/SimplePoolAuthorization.sol +28 -0
- package/contracts/examples/unpermissioned/SimpleProduct.sol +437 -0
- package/contracts/examples/unpermissioned/SimpleProductAuthorization.sol +28 -0
- package/contracts/instance/BaseStore.sol +97 -0
- package/contracts/instance/BundleSet.sol +42 -38
- package/contracts/instance/IBaseStore.sol +43 -0
- package/contracts/instance/IInstance.sol +113 -43
- package/contracts/instance/IInstanceService.sol +61 -34
- package/contracts/instance/Instance.sol +208 -104
- package/contracts/instance/InstanceAdmin.sol +275 -162
- package/contracts/instance/InstanceAuthorizationV3.sol +142 -71
- package/contracts/instance/InstanceReader.sol +478 -257
- package/contracts/instance/InstanceService.sol +333 -262
- package/contracts/instance/InstanceServiceManager.sol +6 -7
- package/contracts/instance/InstanceStore.sol +20 -26
- package/contracts/instance/ProductStore.sol +110 -0
- package/contracts/instance/RiskSet.sol +126 -0
- package/contracts/instance/TargetNames.sol +10 -0
- package/contracts/instance/base/BalanceStore.sol +4 -6
- package/contracts/instance/base/ObjectCounter.sol +1 -2
- package/contracts/instance/base/ObjectLifecycle.sol +13 -10
- package/contracts/instance/base/ObjectSet.sol +31 -33
- package/contracts/instance/base/ObjectSetHelperLib.sol +30 -0
- package/contracts/instance/module/IBundle.sol +6 -5
- package/contracts/instance/module/IComponents.sol +30 -15
- package/contracts/instance/module/IDistribution.sol +21 -8
- package/contracts/instance/module/IPolicy.sol +50 -29
- package/contracts/instance/module/IRisk.sol +5 -0
- package/contracts/oracle/BasicOracle.sol +2 -5
- package/contracts/oracle/BasicOracleAuthorization.sol +15 -8
- package/contracts/oracle/IOracle.sol +9 -4
- package/contracts/oracle/IOracleService.sol +2 -1
- package/contracts/oracle/Oracle.sol +9 -21
- package/contracts/oracle/OracleService.sol +119 -87
- package/contracts/oracle/OracleServiceManager.sol +6 -6
- package/contracts/pool/BasicPool.sol +34 -38
- package/contracts/pool/BasicPoolAuthorization.sol +35 -12
- package/contracts/pool/BundleService.sol +123 -188
- package/contracts/pool/BundleServiceManager.sol +6 -6
- package/contracts/pool/IBundleService.sol +31 -48
- package/contracts/pool/IPoolComponent.sol +19 -15
- package/contracts/pool/IPoolService.sol +97 -76
- package/contracts/pool/Pool.sol +142 -137
- package/contracts/pool/PoolLib.sol +341 -0
- package/contracts/pool/PoolService.sol +388 -324
- package/contracts/pool/PoolServiceManager.sol +4 -4
- package/contracts/product/ApplicationService.sol +144 -47
- package/contracts/product/ApplicationServiceManager.sol +4 -4
- package/contracts/product/BasicProduct.sol +11 -14
- package/contracts/product/BasicProductAuthorization.sol +32 -12
- package/contracts/product/ClaimService.sol +394 -185
- package/contracts/product/ClaimServiceManager.sol +4 -4
- package/contracts/product/IApplicationService.sol +29 -3
- package/contracts/product/IClaimService.sol +48 -11
- package/contracts/product/IPolicyService.sol +61 -43
- package/contracts/product/IPricingService.sol +11 -10
- package/contracts/product/IProductComponent.sol +27 -5
- package/contracts/product/IRiskService.sol +48 -0
- package/contracts/product/PolicyService.sol +426 -310
- package/contracts/product/PolicyServiceLib.sol +139 -0
- package/contracts/product/PolicyServiceManager.sol +4 -4
- package/contracts/product/PricingService.sol +90 -84
- package/contracts/product/PricingServiceManager.sol +4 -4
- package/contracts/product/Product.sol +188 -106
- package/contracts/product/RiskService.sol +190 -0
- package/contracts/product/RiskServiceManager.sol +39 -0
- package/contracts/registry/ChainNft.sol +72 -40
- package/contracts/registry/IRegistry.sol +70 -32
- package/contracts/registry/IRegistryService.sol +5 -12
- package/contracts/registry/IRelease.sol +29 -0
- package/contracts/registry/ITransferInterceptor.sol +1 -2
- package/contracts/registry/Registry.sol +367 -207
- package/contracts/registry/RegistryAdmin.sol +114 -288
- package/contracts/registry/RegistryAuthorization.sol +336 -0
- package/contracts/registry/RegistryService.sol +38 -49
- package/contracts/registry/RegistryServiceManager.sol +3 -3
- package/contracts/registry/ReleaseAdmin.sol +195 -0
- package/contracts/registry/ReleaseLifecycle.sol +8 -3
- package/contracts/registry/ReleaseRegistry.sol +279 -239
- package/contracts/registry/ServiceAuthorizationV3.sol +205 -63
- package/contracts/registry/TokenRegistry.sol +61 -59
- package/contracts/shared/Component.sol +70 -136
- package/contracts/shared/ComponentService.sol +423 -387
- package/contracts/shared/ComponentServiceManager.sol +8 -5
- package/contracts/shared/ContractLib.sol +312 -0
- package/contracts/shared/IComponent.sol +6 -18
- package/contracts/shared/IComponentService.sol +43 -40
- package/contracts/shared/IInstanceLinkedComponent.sol +6 -32
- package/contracts/shared/IKeyValueStore.sol +9 -1
- package/contracts/shared/ILifecycle.sol +3 -1
- package/contracts/shared/INftOwnable.sol +4 -0
- package/contracts/shared/IPolicyHolder.sol +12 -22
- package/contracts/shared/IRegisterable.sol +22 -1
- package/contracts/shared/IService.sol +3 -5
- package/contracts/shared/InitializableERC165.sol +10 -2
- package/contracts/shared/InstanceLinkedComponent.sol +73 -51
- package/contracts/shared/KeyValueStore.sol +4 -4
- package/contracts/shared/Lifecycle.sol +15 -4
- package/contracts/shared/NftOwnable.sol +31 -9
- package/contracts/shared/PolicyHolder.sol +18 -54
- package/contracts/shared/Registerable.sol +52 -21
- package/contracts/shared/RegistryLinked.sol +9 -14
- package/contracts/shared/Service.sol +20 -35
- package/contracts/shared/TokenHandler.sol +310 -26
- package/contracts/shared/TokenHandlerDeployerLib.sol +20 -0
- package/contracts/staking/IStaking.sol +271 -71
- package/contracts/staking/IStakingService.sol +45 -78
- package/contracts/staking/ITargetLimitHandler.sol +17 -0
- package/contracts/staking/Staking.sol +525 -243
- package/contracts/staking/StakingLib.sol +195 -0
- package/contracts/staking/StakingManager.sol +12 -9
- package/contracts/staking/StakingReader.sol +70 -82
- package/contracts/staking/StakingService.sol +62 -152
- package/contracts/staking/StakingServiceManager.sol +7 -5
- package/contracts/staking/StakingStore.sol +1093 -330
- package/contracts/staking/TargetHandler.sol +132 -0
- package/contracts/staking/TargetManagerLib.sol +73 -46
- package/contracts/type/Amount.sol +19 -0
- package/contracts/type/Blocknumber.sol +15 -15
- package/contracts/type/ChainId.sol +101 -0
- package/contracts/type/ClaimId.sol +6 -1
- package/contracts/type/Fee.sol +8 -8
- package/contracts/type/Key32.sol +2 -2
- package/contracts/type/Key32Set.sol +62 -0
- package/contracts/type/NftId.sol +7 -0
- package/contracts/type/ObjectType.sol +73 -37
- package/contracts/type/PayoutId.sol +10 -10
- package/contracts/type/RiskId.sol +38 -6
- package/contracts/type/RoleId.sol +61 -55
- package/contracts/type/Seconds.sol +27 -0
- package/contracts/type/Selector.sol +5 -0
- package/contracts/type/StateId.sol +15 -1
- package/contracts/type/String.sol +12 -0
- package/contracts/type/Timestamp.sol +4 -7
- package/contracts/type/UFixed.sol +38 -126
- package/contracts/type/Version.sol +54 -5
- package/contracts/upgradeability/IVersionable.sol +3 -0
- package/contracts/upgradeability/ProxyManager.sol +93 -45
- package/contracts/upgradeability/UpgradableProxyWithAdmin.sol +12 -2
- package/contracts/upgradeability/Versionable.sol +8 -5
- package/package.json +5 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/IModuleAuthorization.sol/IModuleAuthorization.json +0 -290
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.dbg.json +0 -4
- package/artifacts/contracts/authorization/ModuleAuthorization.sol/ModuleAuthorization.json +0 -390
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +0 -4
- package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +0 -129
- package/artifacts/contracts/product/IProductService.sol/IProductService.dbg.json +0 -4
- package/artifacts/contracts/product/IProductService.sol/IProductService.json +0 -400
- package/artifacts/contracts/product/ProductService.sol/ProductService.dbg.json +0 -4
- package/artifacts/contracts/product/ProductService.sol/ProductService.json +0 -708
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.dbg.json +0 -4
- package/artifacts/contracts/product/ProductServiceManager.sol/ProductServiceManager.json +0 -702
- package/artifacts/contracts/shared/ComponentVerifyingService.sol/ComponentVerifyingService.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.dbg.json +0 -4
- package/artifacts/contracts/shared/InitializableCustom.sol/InitializableCustom.json +0 -39
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.dbg.json +0 -4
- package/artifacts/contracts/staking/StakeManagerLib.sol/StakeManagerLib.json +0 -470
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.dbg.json +0 -4
- package/artifacts/contracts/staking/StakingLifecycle.sol/StakingLifecycle.json +0 -164
- package/artifacts/contracts/type/UFixed.sol/MathLib.dbg.json +0 -4
- package/artifacts/contracts/type/UFixed.sol/MathLib.json +0 -16
- package/contracts/authorization/IModuleAuthorization.sol +0 -21
- package/contracts/authorization/ModuleAuthorization.sol +0 -78
- package/contracts/instance/module/IAccess.sol +0 -46
- package/contracts/product/IProductService.sol +0 -33
- package/contracts/product/ProductService.sol +0 -99
- package/contracts/product/ProductServiceManager.sol +0 -39
- package/contracts/shared/ComponentVerifyingService.sol +0 -117
- package/contracts/shared/InitializableCustom.sol +0 -177
- package/contracts/staking/StakeManagerLib.sol +0 -231
- package/contracts/staking/StakingLifecycle.sol +0 -23
@@ -1,11 +1,11 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
5
|
-
import {
|
6
|
-
import {Instance} from "./Instance.sol";
|
7
|
-
import {IInstanceLinkedComponent} from "../shared/IInstanceLinkedComponent.sol";
|
4
|
+
import {IAccess} from "../authorization/IAccess.sol";
|
5
|
+
import {IInstance} from "./IInstance.sol";
|
8
6
|
import {IService} from "../shared/IService.sol";
|
7
|
+
|
8
|
+
import {Amount} from "../type/Amount.sol";
|
9
9
|
import {NftId} from "../type/NftId.sol";
|
10
10
|
import {ObjectType} from "../type/ObjectType.sol";
|
11
11
|
import {RoleId} from "../type/RoleId.sol";
|
@@ -18,13 +18,14 @@ interface IInstanceService is IService {
|
|
18
18
|
// onlyInstance
|
19
19
|
error ErrorInstanceServiceNotRegistered(address instance);
|
20
20
|
error ErrorInstanceServiceNotInstance(address instance, ObjectType objectType);
|
21
|
-
error ErrorInstanceServiceInstanceVersionMismatch(
|
21
|
+
error ErrorInstanceServiceInstanceVersionMismatch(NftId instanceNftId, VersionPart expectedRelease, VersionPart instanceRelease);
|
22
22
|
|
23
23
|
error ErrorInstanceServiceComponentNotInstanceLinked(address component);
|
24
24
|
|
25
25
|
error ErrorInstanceServiceMasterInstanceAlreadySet();
|
26
26
|
error ErrorInstanceServiceMasterInstanceAdminAlreadySet();
|
27
27
|
error ErrorInstanceServiceMasterBundleSetAlreadySet();
|
28
|
+
error ErrorInstanceServiceMasterRiskSetAlreadySet();
|
28
29
|
error ErrorInstanceServiceInstanceAddressZero();
|
29
30
|
|
30
31
|
error ErrorInstanceServiceMasterInstanceReaderNotSet();
|
@@ -36,13 +37,18 @@ interface IInstanceService is IService {
|
|
36
37
|
error ErrorInstanceServiceInstanceAdminZero();
|
37
38
|
error ErrorInstanceServiceInstanceReaderZero();
|
38
39
|
error ErrorInstanceServiceBundleSetZero();
|
40
|
+
error ErrorInstanceServiceRiskSetZero();
|
39
41
|
error ErrorInstanceServiceInstanceStoreZero();
|
42
|
+
error ErrorInstanceServiceProductStoreZero();
|
40
43
|
|
41
44
|
error ErrorInstanceServiceInstanceAuthorityMismatch();
|
42
45
|
error ErrorInstanceServiceBundleSetAuthorityMismatch();
|
46
|
+
error ErrorInstanceServiceRiskSetAuthorityMismatch();
|
43
47
|
error ErrorInstanceServiceInstanceReaderInstanceMismatch2();
|
44
|
-
error
|
48
|
+
error ErrorInstanceServiceBundleSetInstanceMismatch();
|
49
|
+
error ErrorInstanceServiceRiskSetInstanceMismatch();
|
45
50
|
error ErrorInstanceServiceInstanceStoreAuthorityMismatch();
|
51
|
+
error ErrorInstanceServiceProductStoreAuthorityMismatch();
|
46
52
|
|
47
53
|
error ErrorInstanceServiceRequestUnauhorized(address caller);
|
48
54
|
error ErrorInstanceServiceNotInstanceNftId(NftId nftId);
|
@@ -50,43 +56,64 @@ interface IInstanceService is IService {
|
|
50
56
|
error ErrorInstanceServiceInstanceComponentMismatch(NftId instanceNftId, NftId componentNftId);
|
51
57
|
error ErrorInstanceServiceInvalidComponentType(address componentAddress, ObjectType expectedType, ObjectType componentType);
|
52
58
|
|
53
|
-
event
|
59
|
+
event LogInstanceServiceInstanceLocked(NftId instanceNftId, bool locked);
|
60
|
+
event LogInstanceServiceInstanceCreated(NftId instanceNftId, address instance);
|
61
|
+
event LogInstanceServiceMasterInstanceReaderUpgraded(NftId instanceNfId, address newInstanceReader);
|
62
|
+
event LogInstanceServiceInstanceReaderUpgraded(NftId instanceNfId, address newInstanceReader);
|
63
|
+
|
64
|
+
/// @dev Creates a new custom role for the calling instance.
|
65
|
+
function createRole(string memory roleName, RoleId adminRoleId, uint32 maxMemberCount) external returns (RoleId roleId);
|
66
|
+
|
67
|
+
/// @dev Sets the specified custom role as active or inactive for the calling instance.
|
68
|
+
function setRoleActive(RoleId roleId, bool active) external;
|
69
|
+
|
70
|
+
/// @dev Grants the specified custom role to the specified account for the calling instance.
|
71
|
+
function grantRole(RoleId roleId, address account) external;
|
72
|
+
|
73
|
+
/// @dev Revokes the specified custom role from the specified account for the calling instance.
|
74
|
+
function revokeRole(RoleId roleId, address account) external;
|
54
75
|
|
55
|
-
|
76
|
+
/// @dev Creates a new custom target for the calling instance.
|
77
|
+
/// All custom trargets are created with a corresponding contract role.
|
78
|
+
function createTarget(address target, string memory name) external returns (RoleId contractRoleId);
|
79
|
+
|
80
|
+
/// @dev Authorizes the specified functions for the specified target.
|
81
|
+
function authorizeFunctions(address target, RoleId roleId, IAccess.FunctionInfo[] memory functions) external;
|
82
|
+
|
83
|
+
/// @dev Removes any role authorization for the specified functions.
|
84
|
+
function unauthorizeFunctions(address target, IAccess.FunctionInfo[] memory functions) external;
|
85
|
+
|
86
|
+
/// @dev Locks/unlocks the specified target constrolled by the corresponding instance admin.
|
87
|
+
function setTargetLocked(address target, bool locked) external;
|
88
|
+
|
89
|
+
/// @dev Locks the complete instance, including all its components.
|
90
|
+
function setInstanceLocked(bool locked) external;
|
91
|
+
|
92
|
+
/// @dev Creates a new instance.
|
93
|
+
/// The caller becomes the owner of the new instance.
|
94
|
+
/// Creation of a new instance is achieved by this service through the creation and registration
|
95
|
+
/// of a new clone of the master instance and then setting up the initial wiring and authorization
|
96
|
+
/// of the necessary components.
|
97
|
+
/// @param allowAnyToken specifies whether the new instance is allowed to use any token or
|
98
|
+
/// only tokens that are registered in the `TokenRegistry`. Use of tokens **not** registered in the
|
99
|
+
/// `TokenRegistry` may result in problems with token handline and is therefor not recommended. The
|
100
|
+
/// use of such instances **is not supported** by Etherisc.
|
101
|
+
function createInstance(bool allowAnyToken)
|
56
102
|
external
|
57
103
|
returns (
|
58
|
-
|
59
|
-
Instance clonedInstance,
|
104
|
+
IInstance instance,
|
60
105
|
NftId instanceNftId
|
61
106
|
);
|
62
107
|
|
108
|
+
function upgradeInstanceReader() external;
|
109
|
+
function upgradeMasterInstanceReader(address instanceReaderAddress) external;
|
63
110
|
|
64
111
|
function setStakingLockingPeriod(Seconds stakeLockingPeriod) external;
|
65
112
|
function setStakingRewardRate(UFixed rewardRate) external;
|
66
|
-
function
|
113
|
+
function setStakingMaxAmount(Amount maxStakedAmount) external;
|
114
|
+
|
115
|
+
function refillInstanceRewardReserves(address rewardProvider, Amount dipAmount) external returns (Amount newBalance);
|
67
116
|
|
68
117
|
/// @dev Defunds the staking reward reserves for the specified target.
|
69
|
-
function
|
70
|
-
|
71
|
-
/// @dev Sets up the component authorization for the specified instance.
|
72
|
-
/// The authorization is based on the authz specification provided by the component via getAuthorization.
|
73
|
-
function initializeAuthorization(NftId instanceNftId, IInstanceLinkedComponent component) external;
|
74
|
-
|
75
|
-
function createComponentTarget(
|
76
|
-
NftId instanceNftId,
|
77
|
-
address targetAddress,
|
78
|
-
string memory targetName,
|
79
|
-
bytes4[][] memory selectors,
|
80
|
-
RoleId[] memory roles
|
81
|
-
) external;
|
82
|
-
|
83
|
-
function createGifTarget(
|
84
|
-
NftId instanceNftId,
|
85
|
-
address targetAddress,
|
86
|
-
string memory targetName,
|
87
|
-
bytes4[][] memory selectors,
|
88
|
-
RoleId[] memory roles
|
89
|
-
) external;
|
90
|
-
|
91
|
-
function setComponentLocked(bool locked) external;
|
118
|
+
function withdrawInstanceRewardReserves(Amount dipAmount) external returns (Amount newBalance);
|
92
119
|
}
|
@@ -1,122 +1,160 @@
|
|
1
1
|
// SPDX-License-Identifier: Apache-2.0
|
2
2
|
pragma solidity ^0.8.20;
|
3
3
|
|
4
|
-
import {
|
4
|
+
import {IAccess} from "../authorization/IAccess.sol";
|
5
|
+
import {IInstance} from "./IInstance.sol";
|
6
|
+
import {IComponentService} from "../shared/IComponentService.sol";
|
7
|
+
import {IInstanceService} from "./IInstanceService.sol";
|
8
|
+
import {IRegistry} from "../registry/IRegistry.sol";
|
5
9
|
|
6
10
|
import {Amount} from "../type/Amount.sol";
|
7
|
-
import {
|
11
|
+
import {BundleSet} from "./BundleSet.sol";
|
12
|
+
import {RiskSet} from "./RiskSet.sol";
|
13
|
+
import {COMPONENT, INSTANCE} from "../type/ObjectType.sol";
|
14
|
+
import {InstanceReader} from "./InstanceReader.sol";
|
15
|
+
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
16
|
+
import {InstanceStore} from "./InstanceStore.sol";
|
8
17
|
import {NftId} from "../type/NftId.sol";
|
9
|
-
import {
|
10
|
-
import {
|
18
|
+
import {ProductStore} from "./ProductStore.sol";
|
19
|
+
import {Registerable} from "../shared/Registerable.sol";
|
11
20
|
import {RoleId} from "../type/RoleId.sol";
|
12
|
-
import {ClaimId} from "../type/ClaimId.sol";
|
13
|
-
import {ReferralId} from "../type/Referral.sol";
|
14
|
-
import {PayoutId} from "../type/PayoutId.sol";
|
15
|
-
import {DistributorType} from "../type/DistributorType.sol";
|
16
21
|
import {Seconds} from "../type/Seconds.sol";
|
17
22
|
import {UFixed} from "../type/UFixed.sol";
|
18
|
-
import {VersionPart
|
19
|
-
|
20
|
-
import {Registerable} from "../shared/Registerable.sol";
|
21
|
-
import {TokenHandler} from "../shared/TokenHandler.sol";
|
22
|
-
|
23
|
-
import {IRegistry} from "../registry/IRegistry.sol";
|
24
|
-
|
25
|
-
import {IInstance} from "./IInstance.sol";
|
26
|
-
import {IInstanceService} from "./IInstanceService.sol";
|
27
|
-
import {InstanceReader} from "./InstanceReader.sol";
|
28
|
-
import {InstanceAdmin} from "./InstanceAdmin.sol";
|
29
|
-
import {BundleSet} from "./BundleSet.sol";
|
30
|
-
import {InstanceStore} from "./InstanceStore.sol";
|
31
|
-
|
32
|
-
import {KeyValueStore} from "../shared/KeyValueStore.sol";
|
33
|
-
|
34
|
-
import {IBundle} from "./module/IBundle.sol";
|
35
|
-
import {IComponents} from "./module/IComponents.sol";
|
36
|
-
import {IDistribution} from "./module/IDistribution.sol";
|
37
|
-
import {IPolicy} from "./module/IPolicy.sol";
|
38
|
-
import {IRisk} from "./module/IRisk.sol";
|
39
|
-
|
40
|
-
import {IDistributionService} from "../distribution/IDistributionService.sol";
|
41
|
-
import {IPoolService} from "../pool/IPoolService.sol";
|
42
|
-
import {IProductService} from "../product/IProductService.sol";
|
43
|
-
import {IPolicyService} from "../product/IPolicyService.sol";
|
44
|
-
import {IBundleService} from "../pool/IBundleService.sol";
|
23
|
+
import {VersionPart} from "../type/Version.sol";
|
45
24
|
|
46
25
|
contract Instance is
|
47
26
|
IInstance,
|
48
|
-
AccessManagedUpgradeable,
|
49
27
|
Registerable
|
50
28
|
{
|
51
|
-
uint256 public constant GIF_MAJOR_VERSION = 3;
|
52
|
-
|
53
29
|
bool private _initialized;
|
54
30
|
|
31
|
+
IComponentService internal _componentService;
|
55
32
|
IInstanceService internal _instanceService;
|
33
|
+
|
56
34
|
InstanceAdmin internal _instanceAdmin;
|
57
35
|
InstanceReader internal _instanceReader;
|
58
|
-
BundleSet internal
|
36
|
+
BundleSet internal _bundleSet;
|
37
|
+
RiskSet internal _riskSet;
|
59
38
|
InstanceStore internal _instanceStore;
|
39
|
+
ProductStore internal _productStore;
|
40
|
+
NftId [] internal _products;
|
41
|
+
bool internal _tokenRegistryDisabled;
|
42
|
+
|
60
43
|
|
61
|
-
modifier
|
62
|
-
if
|
63
|
-
revert();
|
44
|
+
modifier onlyCustomRoleAdmin(RoleId roleId) {
|
45
|
+
if (!_instanceAdmin.isRoleCustom(roleId)) {
|
46
|
+
revert ErrorInstanceNotCustomRole(roleId);
|
47
|
+
}
|
48
|
+
|
49
|
+
// instance owner can always act as role admin
|
50
|
+
address account = msg.sender;
|
51
|
+
if (account != getOwner()) {
|
52
|
+
if (!_instanceAdmin.isRoleAdmin(roleId, account)) {
|
53
|
+
revert ErrorInstanceNotRoleAdmin(roleId, account);
|
54
|
+
}
|
64
55
|
}
|
65
56
|
_;
|
66
57
|
}
|
67
58
|
|
59
|
+
|
68
60
|
function initialize(
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
61
|
+
// TODO: remove
|
62
|
+
// InstanceAdmin instanceAdmin,
|
63
|
+
// InstanceStore instanceStore,
|
64
|
+
// ProductStore productStore,
|
65
|
+
// BundleSet bundleSet,
|
66
|
+
// RiskSet riskSet,
|
67
|
+
// InstanceReader instanceReader,
|
68
|
+
InstanceContracts memory instanceContracts,
|
73
69
|
IRegistry registry,
|
74
|
-
|
70
|
+
VersionPart release,
|
71
|
+
address initialOwner,
|
72
|
+
bool tokenRegistryDisabled // only disable for testing
|
75
73
|
)
|
76
74
|
external
|
77
75
|
initializer()
|
78
76
|
{
|
79
|
-
|
80
|
-
if(_instanceAdmin.authority() == address(0)) {
|
81
|
-
// TODO rename error
|
77
|
+
if(address(instanceContracts.instanceAdmin) == address(0)) {
|
82
78
|
revert ErrorInstanceInstanceAdminZero();
|
83
79
|
}
|
84
80
|
|
85
|
-
|
86
|
-
__AccessManaged_init(_instanceAdmin.authority());
|
81
|
+
_instanceAdmin = instanceContracts.instanceAdmin;
|
87
82
|
|
88
83
|
// setup instance object info
|
89
|
-
|
90
|
-
|
91
|
-
registry
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
84
|
+
__Registerable_init({
|
85
|
+
authority: instanceContracts.instanceAdmin.authority(),
|
86
|
+
registry: address(registry),
|
87
|
+
parentNftId: registry.getNftId(),
|
88
|
+
objectType: INSTANCE(),
|
89
|
+
isInterceptor: false,
|
90
|
+
initialOwner: initialOwner,
|
91
|
+
data: ""});
|
96
92
|
|
97
93
|
// store instance supporting contracts
|
98
|
-
_instanceStore = instanceStore;
|
99
|
-
|
100
|
-
|
94
|
+
_instanceStore = instanceContracts.instanceStore;
|
95
|
+
_productStore = instanceContracts.productStore;
|
96
|
+
_bundleSet = instanceContracts.bundleSet;
|
97
|
+
_riskSet = instanceContracts.riskSet;
|
98
|
+
_instanceReader = instanceContracts.instanceReader;
|
101
99
|
|
102
100
|
// initialize instance supporting contracts
|
103
101
|
_instanceStore.initialize();
|
104
|
-
|
102
|
+
_productStore.initialize();
|
103
|
+
_bundleSet.initialize(instanceContracts.instanceAdmin.authority(), address(registry));
|
104
|
+
_riskSet.initialize(instanceContracts.instanceAdmin.authority(), address(registry));
|
105
105
|
_instanceReader.initialize();
|
106
106
|
|
107
|
+
_componentService = IComponentService(
|
108
|
+
getRegistry().getServiceAddress(
|
109
|
+
COMPONENT(),
|
110
|
+
release));
|
111
|
+
|
107
112
|
_instanceService = IInstanceService(
|
108
113
|
getRegistry().getServiceAddress(
|
109
114
|
INSTANCE(),
|
110
|
-
|
115
|
+
release));
|
116
|
+
|
117
|
+
_tokenRegistryDisabled = tokenRegistryDisabled;
|
111
118
|
|
112
|
-
|
119
|
+
_registerInterface(type(IInstance).interfaceId);
|
120
|
+
}
|
121
|
+
|
122
|
+
|
123
|
+
function setInstanceLocked(bool locked)
|
124
|
+
external
|
125
|
+
// not restricted(): need to be able to unlock a locked instance
|
126
|
+
onlyOwner()
|
127
|
+
{
|
128
|
+
_instanceService.setInstanceLocked(locked);
|
129
|
+
}
|
130
|
+
|
131
|
+
|
132
|
+
function upgradeInstanceReader()
|
133
|
+
external
|
134
|
+
restricted()
|
135
|
+
onlyOwner()
|
136
|
+
{
|
137
|
+
_instanceService.upgradeInstanceReader();
|
138
|
+
}
|
139
|
+
|
140
|
+
|
141
|
+
//--- ProductRegistration ----------------------------------------------//
|
142
|
+
|
143
|
+
function registerProduct(address product, address token)
|
144
|
+
external
|
145
|
+
restricted()
|
146
|
+
onlyOwner()
|
147
|
+
returns (NftId productNftId)
|
148
|
+
{
|
149
|
+
productNftId = _componentService.registerProduct(product, token);
|
150
|
+
_products.push(productNftId);
|
113
151
|
}
|
114
152
|
|
115
153
|
//--- Staking ----------------------------------------------------------//
|
116
154
|
|
117
155
|
function setStakingLockingPeriod(Seconds stakeLockingPeriod)
|
118
156
|
external
|
119
|
-
|
157
|
+
restricted()
|
120
158
|
onlyOwner()
|
121
159
|
{
|
122
160
|
_instanceService.setStakingLockingPeriod(stakeLockingPeriod);
|
@@ -124,94 +162,138 @@ contract Instance is
|
|
124
162
|
|
125
163
|
function setStakingRewardRate(UFixed rewardRate)
|
126
164
|
external
|
165
|
+
restricted()
|
127
166
|
onlyOwner()
|
128
167
|
{
|
129
168
|
_instanceService.setStakingRewardRate(rewardRate);
|
130
169
|
}
|
131
170
|
|
171
|
+
function setStakingMaxAmount(Amount maxStakedAmount)
|
172
|
+
external
|
173
|
+
restricted()
|
174
|
+
onlyOwner()
|
175
|
+
{
|
176
|
+
_instanceService.setStakingMaxAmount(maxStakedAmount);
|
177
|
+
}
|
178
|
+
|
132
179
|
function refillStakingRewardReserves(Amount dipAmount)
|
133
180
|
external
|
181
|
+
restricted()
|
134
182
|
onlyOwner()
|
183
|
+
returns (Amount newRewardReserveBalance)
|
135
184
|
{
|
136
185
|
address instanceOwner = msg.sender;
|
137
|
-
_instanceService.
|
186
|
+
return _instanceService.refillInstanceRewardReserves(instanceOwner, dipAmount);
|
138
187
|
}
|
139
188
|
|
140
189
|
function withdrawStakingRewardReserves(Amount dipAmount)
|
141
190
|
external
|
191
|
+
restricted()
|
142
192
|
onlyOwner()
|
143
|
-
returns (Amount
|
193
|
+
returns (Amount newRewardReserveBalance)
|
144
194
|
{
|
145
|
-
return _instanceService.
|
195
|
+
return _instanceService.withdrawInstanceRewardReserves(dipAmount);
|
146
196
|
}
|
147
197
|
|
148
198
|
//--- Roles ------------------------------------------------------------//
|
149
199
|
|
150
|
-
|
200
|
+
/// @inheritdoc IInstance
|
201
|
+
function createRole(
|
202
|
+
string memory roleName,
|
203
|
+
RoleId adminRoleId,
|
204
|
+
uint32 maxMemberCount
|
205
|
+
)
|
151
206
|
external
|
207
|
+
restricted()
|
152
208
|
onlyOwner()
|
153
|
-
returns (RoleId roleId
|
209
|
+
returns (RoleId roleId)
|
210
|
+
{
|
211
|
+
roleId = _instanceService.createRole(roleName, adminRoleId, maxMemberCount);
|
212
|
+
emit LogInstanceCustomRoleCreated(roleId, roleName, adminRoleId, maxMemberCount);
|
213
|
+
}
|
214
|
+
|
215
|
+
|
216
|
+
/// @inheritdoc IInstance
|
217
|
+
function setRoleActive(RoleId roleId, bool active)
|
218
|
+
external
|
219
|
+
restricted()
|
220
|
+
onlyCustomRoleAdmin(roleId)
|
154
221
|
{
|
155
|
-
|
156
|
-
|
222
|
+
_instanceService.setRoleActive(roleId, active);
|
223
|
+
emit LogInstanceCustomRoleActiveSet(roleId, active, msg.sender);
|
157
224
|
}
|
158
225
|
|
226
|
+
|
227
|
+
/// @inheritdoc IInstance
|
159
228
|
function grantRole(RoleId roleId, address account)
|
160
229
|
external
|
161
|
-
|
230
|
+
restricted()
|
231
|
+
onlyCustomRoleAdmin(roleId)
|
162
232
|
{
|
163
|
-
|
233
|
+
_instanceService.grantRole(roleId, account);
|
234
|
+
emit LogInstanceCustomRoleGranted(roleId, account, msg.sender);
|
164
235
|
}
|
165
236
|
|
237
|
+
|
238
|
+
/// @inheritdoc IInstance
|
166
239
|
function revokeRole(RoleId roleId, address account)
|
167
240
|
external
|
168
|
-
|
241
|
+
restricted()
|
242
|
+
onlyCustomRoleAdmin(roleId)
|
169
243
|
{
|
170
|
-
|
171
|
-
|
244
|
+
_instanceService.revokeRole(roleId, account);
|
245
|
+
emit LogInstanceCustomRoleRevoked(roleId, account, msg.sender);
|
172
246
|
}
|
173
247
|
|
174
248
|
//--- Targets ------------------------------------------------------------//
|
175
249
|
|
250
|
+
/// @inheritdoc IInstance
|
176
251
|
function createTarget(address target, string memory name)
|
177
252
|
external
|
253
|
+
restricted()
|
178
254
|
onlyOwner()
|
255
|
+
returns (RoleId targetRoleId)
|
179
256
|
{
|
180
|
-
|
181
|
-
|
257
|
+
targetRoleId = _instanceService.createTarget(target, name);
|
258
|
+
emit LogInstanceCustomTargetCreated(target, targetRoleId, name);
|
182
259
|
}
|
183
260
|
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
RoleId roleId
|
188
|
-
)
|
261
|
+
|
262
|
+
/// @inheritdoc IInstance
|
263
|
+
function setTargetLocked(address target, bool locked)
|
189
264
|
external
|
265
|
+
// not restricted(): instance owner may need to be able to unlock targets on an locked instance
|
190
266
|
onlyOwner()
|
191
267
|
{
|
192
|
-
|
193
|
-
|
268
|
+
_instanceService.setTargetLocked(target, locked);
|
269
|
+
emit LogInstanceTargetLocked(target, locked);
|
194
270
|
}
|
195
271
|
|
196
|
-
|
272
|
+
|
273
|
+
/// @inheritdoc IInstance
|
274
|
+
function authorizeFunctions(
|
275
|
+
address target,
|
276
|
+
RoleId roleId,
|
277
|
+
IAccess.FunctionInfo[] memory functions
|
278
|
+
)
|
197
279
|
external
|
280
|
+
restricted()
|
198
281
|
onlyOwner()
|
199
282
|
{
|
200
|
-
|
201
|
-
// _instanceAdmin.setTargetLockedByInstance(target, locked);
|
283
|
+
_instanceService.authorizeFunctions(target, roleId, functions);
|
202
284
|
}
|
203
285
|
|
204
|
-
//--- ITransferInterceptor ----------------------------------------------//
|
205
|
-
|
206
|
-
// TODO interception of child components nfts
|
207
|
-
function nftMint(address to, uint256 tokenId) external onlyChainNft {
|
208
|
-
// TODO refactor
|
209
|
-
// _instanceAdmin.transferInstanceOwnerRole(address(0), to);
|
210
|
-
}
|
211
286
|
|
212
|
-
|
213
|
-
|
214
|
-
|
287
|
+
/// @inheritdoc IInstance
|
288
|
+
function unauthorizeFunctions(
|
289
|
+
address target,
|
290
|
+
IAccess.FunctionInfo[] memory functions
|
291
|
+
)
|
292
|
+
external
|
293
|
+
restricted()
|
294
|
+
onlyOwner()
|
295
|
+
{
|
296
|
+
_instanceService.unauthorizeFunctions(target, functions);
|
215
297
|
}
|
216
298
|
|
217
299
|
//--- initial setup functions -------------------------------------------//
|
@@ -230,12 +312,32 @@ contract Instance is
|
|
230
312
|
|
231
313
|
//--- external view functions -------------------------------------------//
|
232
314
|
|
315
|
+
function isInstanceLocked() external view returns (bool) {
|
316
|
+
return _instanceAdmin.isLocked();
|
317
|
+
}
|
318
|
+
|
319
|
+
function isTargetLocked(address target) external view returns (bool) {
|
320
|
+
return _instanceAdmin.isTargetLocked(target);
|
321
|
+
}
|
322
|
+
|
323
|
+
function products() external view returns (uint256 productCount) {
|
324
|
+
return _products.length;
|
325
|
+
}
|
326
|
+
|
327
|
+
function getProductNftId(uint256 idx) external view returns (NftId productNftId) {
|
328
|
+
return _products[idx];
|
329
|
+
}
|
330
|
+
|
233
331
|
function getInstanceReader() external view returns (InstanceReader) {
|
234
332
|
return _instanceReader;
|
235
333
|
}
|
236
334
|
|
237
335
|
function getBundleSet() external view returns (BundleSet) {
|
238
|
-
return
|
336
|
+
return _bundleSet;
|
337
|
+
}
|
338
|
+
|
339
|
+
function getRiskSet() external view returns (RiskSet) {
|
340
|
+
return _riskSet;
|
239
341
|
}
|
240
342
|
|
241
343
|
function getInstanceAdmin() external view returns (InstanceAdmin) {
|
@@ -246,9 +348,11 @@ contract Instance is
|
|
246
348
|
return _instanceStore;
|
247
349
|
}
|
248
350
|
|
249
|
-
function
|
250
|
-
return
|
351
|
+
function getProductStore() external view returns (ProductStore) {
|
352
|
+
return _productStore;
|
251
353
|
}
|
252
354
|
|
253
|
-
|
355
|
+
function isTokenRegistryDisabled() external view returns (bool) {
|
356
|
+
return _tokenRegistryDisabled;
|
357
|
+
}
|
254
358
|
}
|