@etherisc/gif-next 0.0.2-e9148e0-933 → 0.0.2-e922e07-736
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 +136 -2
 - package/artifacts/contracts/components/Component.sol/Component.dbg.json +4 -0
 - package/artifacts/contracts/components/Component.sol/Component.json +774 -0
 - package/artifacts/contracts/components/Distribution.sol/Distribution.dbg.json +1 -1
 - package/artifacts/contracts/components/Distribution.sol/Distribution.json +879 -236
 - package/artifacts/contracts/components/IComponent.sol/IComponent.dbg.json +4 -0
 - package/artifacts/contracts/{shared/RegisterableUpgradable.sol/RegisterableUpgradable.json → components/IComponent.sol/IComponent.json} +164 -159
 - package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.dbg.json +1 -1
 - package/artifacts/contracts/components/IDistributionComponent.sol/IDistributionComponent.json +689 -30
 - package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.dbg.json +1 -1
 - package/artifacts/contracts/components/IPoolComponent.sol/IPoolComponent.json +838 -58
 - package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.dbg.json +1 -1
 - package/artifacts/contracts/components/IProductComponent.sol/IProductComponent.json +524 -9
 - package/artifacts/contracts/components/Pool.sol/Pool.dbg.json +1 -1
 - package/artifacts/contracts/components/Pool.sol/Pool.json +950 -281
 - package/artifacts/contracts/components/Product.sol/Product.dbg.json +1 -1
 - package/artifacts/contracts/components/Product.sol/Product.json +568 -188
 - package/artifacts/contracts/instance/BundleManager.sol/BundleManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/BundleManager.sol/BundleManager.json +764 -0
 - package/artifacts/contracts/instance/Cloneable.sol/Cloneable.dbg.json +4 -0
 - package/artifacts/contracts/instance/{AccessManagedSimple.sol/AccessManagedSimple.json → Cloneable.sol/Cloneable.json} +86 -2
 - package/artifacts/contracts/instance/IInstance.sol/IInstance.dbg.json +1 -1
 - package/artifacts/contracts/instance/IInstance.sol/IInstance.json +1912 -421
 - package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.dbg.json +1 -1
 - package/artifacts/contracts/instance/IInstanceService.sol/IInstanceService.json +194 -165
 - package/artifacts/contracts/instance/Instance.sol/Instance.dbg.json +1 -1
 - package/artifacts/contracts/instance/Instance.sol/Instance.json +901 -1127
 - package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.dbg.json +1 -1
 - package/artifacts/contracts/instance/InstanceAccessManager.sol/InstanceAccessManager.json +211 -144
 - package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.dbg.json +1 -1
 - package/artifacts/contracts/instance/InstanceReader.sol/InstanceReader.json +126 -159
 - package/artifacts/contracts/instance/InstanceService.sol/InstanceService.dbg.json +1 -1
 - package/artifacts/contracts/instance/InstanceService.sol/InstanceService.json +420 -305
 - package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.dbg.json +1 -1
 - package/artifacts/contracts/instance/InstanceServiceManager.sol/InstanceServiceManager.json +297 -112
 - package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/ObjectManager.sol/ObjectManager.json +261 -0
 - package/artifacts/contracts/instance/base/ComponentService.sol/ComponentService.dbg.json +4 -0
 - package/artifacts/contracts/instance/base/{ComponentServiceBase.sol/ComponentServiceBase.json → ComponentService.sol/ComponentService.json} +189 -177
 - package/artifacts/contracts/instance/base/IKeyValueStore.sol/IKeyValueStore.dbg.json +1 -1
 - package/artifacts/contracts/instance/base/ILifecycle.sol/ILifecycle.dbg.json +1 -1
 - package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.dbg.json +1 -1
 - package/artifacts/contracts/instance/base/KeyValueStore.sol/KeyValueStore.json +2 -2
 - package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.dbg.json +1 -1
 - package/artifacts/contracts/instance/base/Lifecycle.sol/Lifecycle.json +2 -2
 - package/artifacts/contracts/instance/module/IAccess.sol/IAccess.dbg.json +1 -1
 - package/artifacts/contracts/instance/module/IAccess.sol/IAccess.json +59 -16
 - package/artifacts/contracts/instance/module/IBundle.sol/IBundle.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/instance/module/ISetup.sol/ISetup.dbg.json +1 -1
 - package/artifacts/contracts/instance/module/ITreasury.sol/ITreasury.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/ApplicationService.sol/ApplicationService.json +968 -0
 - package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/ApplicationServiceManager.sol/ApplicationServiceManager.json +665 -0
 - package/artifacts/contracts/instance/service/BundleService.sol/BundleService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/BundleService.sol/BundleService.json +1096 -0
 - package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/BundleServiceManager.sol/BundleServiceManager.json +661 -0
 - package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/ClaimService.sol/ClaimService.json +754 -0
 - package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/ClaimServiceManager.sol/ClaimServiceManager.json +637 -0
 - package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/DistributionService.sol/DistributionService.json +1221 -213
 - package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/DistributionServiceManager.sol/DistributionServiceManager.json +436 -79
 - package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/IApplicationService.sol/IApplicationService.json +556 -0
 - package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/IBundleService.sol/IBundleService.json +633 -0
 - package/artifacts/contracts/instance/service/IClaimService.sol/IClaimService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/{IComponentOwnerService.sol/IComponentOwnerService.json → IClaimService.sol/IClaimService.json} +150 -207
 - package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/IDistributionService.sol/IDistributionService.json +727 -160
 - package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/IPolicyService.sol/IPolicyService.json +540 -0
 - package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/IPoolService.sol/IPoolService.json +37 -251
 - package/artifacts/contracts/instance/service/IProductService.sol/IProductService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/IProductService.sol/IProductService.json +47 -414
 - package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/PolicyService.sol/PolicyService.json +1021 -0
 - package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.dbg.json +4 -0
 - package/artifacts/contracts/instance/service/PolicyServiceManager.sol/PolicyServiceManager.json +689 -0
 - package/artifacts/contracts/instance/service/PoolService.sol/PoolService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/PoolService.sol/PoolService.json +209 -321
 - package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/PoolServiceManager.sol/PoolServiceManager.json +296 -95
 - package/artifacts/contracts/instance/service/ProductService.sol/ProductService.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/ProductService.sol/ProductService.json +218 -499
 - package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.dbg.json +1 -1
 - package/artifacts/contracts/instance/service/ProductServiceManager.sol/ProductServiceManager.json +299 -98
 - 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 +242 -131
 - package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.dbg.json +1 -1
 - package/artifacts/contracts/registry/IRegistryService.sol/IRegistryService.json +158 -215
 - 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 +256 -226
 - package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.dbg.json +4 -0
 - package/artifacts/contracts/registry/RegistryAccessManager.sol/RegistryAccessManager.json +285 -0
 - package/artifacts/contracts/registry/RegistryService.sol/RegistryService.dbg.json +1 -1
 - package/artifacts/contracts/registry/RegistryService.sol/RegistryService.json +202 -318
 - package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.dbg.json +1 -1
 - package/artifacts/contracts/registry/RegistryServiceManager.sol/RegistryServiceManager.json +298 -141
 - package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.dbg.json +4 -0
 - package/artifacts/contracts/registry/ReleaseManager.sol/ReleaseManager.json +547 -0
 - package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.dbg.json +1 -1
 - package/artifacts/contracts/registry/TokenRegistry.sol/TokenRegistry.json +141 -53
 - package/artifacts/contracts/shared/ContractDeployerLib.sol/ContractDeployerLib.dbg.json +1 -1
 - package/artifacts/contracts/shared/ERC165.sol/ERC165.dbg.json +1 -1
 - package/artifacts/contracts/shared/ERC165.sol/ERC165.json +41 -3
 - package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.dbg.json +1 -1
 - package/artifacts/contracts/shared/INftOwnable.sol/INftOwnable.json +40 -29
 - package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.dbg.json +4 -0
 - package/artifacts/contracts/shared/IPolicyHolder.sol/IPolicyHolder.json +129 -0
 - package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.dbg.json +1 -1
 - package/artifacts/contracts/shared/IRegisterable.sol/IRegisterable.json +21 -34
 - package/artifacts/contracts/shared/IRegistryLinked.sol/IRegistryLinked.dbg.json +4 -0
 - package/artifacts/contracts/{experiment/inheritance/IB.sol/IB.json → shared/IRegistryLinked.sol/IRegistryLinked.json} +18 -20
 - package/artifacts/contracts/shared/IService.sol/IService.dbg.json +1 -1
 - package/artifacts/contracts/shared/IService.sol/IService.json +31 -183
 - package/artifacts/contracts/shared/IVersionable.sol/IVersionable.dbg.json +1 -1
 - package/artifacts/contracts/shared/IVersionable.sol/IVersionable.json +2 -152
 - package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.dbg.json +1 -1
 - package/artifacts/contracts/shared/NftOwnable.sol/NftOwnable.json +120 -27
 - package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.dbg.json +4 -0
 - package/artifacts/contracts/shared/PolicyHolder.sol/PolicyHolder.json +248 -0
 - package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.dbg.json +1 -1
 - package/artifacts/contracts/shared/ProxyManager.sol/ProxyManager.json +294 -61
 - package/artifacts/contracts/shared/Registerable.sol/Registerable.dbg.json +1 -1
 - package/artifacts/contracts/shared/Registerable.sol/Registerable.json +129 -51
 - package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.dbg.json +4 -0
 - package/artifacts/contracts/shared/RegistryLinked.sol/RegistryLinked.json +84 -0
 - package/artifacts/contracts/shared/Service.sol/Service.dbg.json +1 -1
 - package/artifacts/contracts/shared/Service.sol/Service.json +127 -170
 - package/artifacts/contracts/shared/TokenHandler.sol/TokenHandler.dbg.json +1 -1
 - package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.dbg.json +1 -1
 - package/artifacts/contracts/shared/UpgradableProxyWithAdmin.sol/UpgradableProxyWithAdmin.json +2 -2
 - package/artifacts/contracts/shared/Versionable.sol/Versionable.dbg.json +1 -1
 - package/artifacts/contracts/shared/Versionable.sol/Versionable.json +2 -152
 - package/artifacts/contracts/test/TestFee.sol/TestFee.dbg.json +1 -1
 - package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.dbg.json +1 -1
 - package/artifacts/contracts/test/TestRegisterable.sol/TestRegisterable.json +129 -51
 - package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.dbg.json +1 -1
 - package/artifacts/contracts/test/TestRoleId.sol/TestRoleId.json +2 -2
 - package/artifacts/contracts/test/TestService.sol/TestService.dbg.json +1 -1
 - package/artifacts/contracts/test/TestService.sol/TestService.json +148 -227
 - package/artifacts/contracts/test/TestToken.sol/TestUsdc.dbg.json +1 -1
 - package/artifacts/contracts/test/TestVersion.sol/TestVersion.dbg.json +1 -1
 - package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.dbg.json +1 -1
 - package/artifacts/contracts/test/TestVersionable.sol/TestVersionable.json +8 -190
 - package/artifacts/contracts/test/Usdc.sol/USDC.dbg.json +1 -1
 - package/artifacts/contracts/types/AddressSet.sol/LibAddressSet.dbg.json +1 -1
 - package/artifacts/contracts/types/Blocknumber.sol/BlocknumberLib.dbg.json +1 -1
 - package/artifacts/contracts/types/ChainId.sol/ChainIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.dbg.json +4 -0
 - package/artifacts/contracts/types/ClaimId.sol/ClaimIdLib.json +100 -0
 - package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.dbg.json +1 -1
 - package/artifacts/contracts/types/DistributorType.sol/DistributorTypeLib.json +2 -2
 - package/artifacts/contracts/types/Fee.sol/FeeLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Key32.sol/Key32Lib.dbg.json +1 -1
 - package/artifacts/contracts/types/Key32.sol/Key32Lib.json +2 -2
 - package/artifacts/contracts/types/NftId.sol/NftIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/NftId.sol/NftIdLib.json +2 -2
 - package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.dbg.json +1 -1
 - package/artifacts/contracts/types/NftIdSet.sol/LibNftIdSet.json +26 -3
 - package/artifacts/contracts/types/NumberId.sol/NumberIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.dbg.json +1 -1
 - package/artifacts/contracts/types/ObjectType.sol/ObjectTypeLib.json +2 -2
 - package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.dbg.json +4 -0
 - package/artifacts/contracts/types/PayoutId.sol/PayoutIdLib.json +100 -0
 - package/artifacts/contracts/types/Referral.sol/ReferralLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Referral.sol/ReferralLib.json +23 -4
 - package/artifacts/contracts/types/RiskId.sol/RiskIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/RiskId.sol/RiskIdLib.json +2 -2
 - package/artifacts/contracts/types/RoleId.sol/RoleIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/RoleId.sol/RoleIdLib.json +2 -2
 - package/artifacts/contracts/types/Seconds.sol/SecondsLib.dbg.json +4 -0
 - package/artifacts/contracts/types/Seconds.sol/SecondsLib.json +124 -0
 - package/artifacts/contracts/types/StateId.sol/StateIdLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Timestamp.sol/TimestampLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Timestamp.sol/TimestampLib.json +25 -7
 - package/artifacts/contracts/types/UFixed.sol/MathLib.dbg.json +1 -1
 - package/artifacts/contracts/types/UFixed.sol/UFixedLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Version.sol/VersionLib.dbg.json +1 -1
 - package/artifacts/contracts/types/Version.sol/VersionPartLib.dbg.json +1 -1
 - package/contracts/components/Component.sol +221 -0
 - package/contracts/components/Distribution.sol +200 -79
 - package/contracts/components/IComponent.sol +68 -0
 - package/contracts/components/IDistributionComponent.sol +44 -17
 - package/contracts/components/IPoolComponent.sol +126 -37
 - package/contracts/components/IProductComponent.sol +10 -5
 - package/contracts/components/Pool.sol +288 -152
 - package/contracts/components/Product.sol +124 -119
 - package/contracts/instance/BundleManager.sol +125 -0
 - package/contracts/instance/Cloneable.sol +46 -0
 - package/contracts/instance/IInstance.sol +56 -5
 - package/contracts/instance/IInstanceService.sol +33 -4
 - package/contracts/instance/Instance.sol +109 -261
 - package/contracts/instance/InstanceAccessManager.sol +87 -78
 - package/contracts/instance/InstanceReader.sol +12 -25
 - package/contracts/instance/InstanceService.sol +401 -104
 - package/contracts/instance/InstanceServiceManager.sol +6 -9
 - package/contracts/instance/ObjectManager.sol +84 -0
 - package/contracts/instance/base/ComponentService.sol +134 -0
 - package/contracts/instance/module/IAccess.sol +27 -18
 - package/contracts/instance/module/IBundle.sol +2 -1
 - package/contracts/instance/module/IDistribution.sol +2 -0
 - package/contracts/instance/module/IPolicy.sol +30 -3
 - package/contracts/instance/module/ISetup.sol +12 -10
 - package/contracts/instance/service/ApplicationService.sol +349 -0
 - package/contracts/instance/service/ApplicationServiceManager.sol +35 -0
 - package/contracts/instance/service/BundleService.sol +299 -0
 - package/contracts/instance/service/BundleServiceManager.sol +51 -0
 - package/contracts/instance/service/ClaimService.sol +151 -0
 - package/contracts/instance/service/ClaimServiceManager.sol +35 -0
 - package/contracts/instance/service/DistributionService.sol +390 -28
 - package/contracts/instance/service/DistributionServiceManager.sol +7 -10
 - package/contracts/instance/service/IApplicationService.sol +82 -0
 - package/contracts/instance/service/IBundleService.sol +55 -0
 - package/contracts/instance/service/IClaimService.sol +61 -0
 - package/contracts/instance/service/IDistributionService.sol +86 -0
 - package/contracts/instance/service/IPolicyService.sol +72 -0
 - package/contracts/instance/service/IPoolService.sol +6 -23
 - package/contracts/instance/service/IProductService.sol +6 -73
 - package/contracts/instance/service/PolicyService.sol +394 -0
 - package/contracts/instance/service/PolicyServiceManager.sol +54 -0
 - package/contracts/instance/service/PoolService.sol +38 -123
 - package/contracts/instance/service/PoolServiceManager.sol +6 -9
 - package/contracts/instance/service/ProductService.sol +133 -448
 - package/contracts/instance/service/ProductServiceManager.sol +2 -2
 - package/contracts/registry/ChainNft.sol +1 -1
 - package/contracts/registry/IRegistry.sol +39 -19
 - package/contracts/registry/IRegistryService.sol +30 -13
 - package/contracts/registry/Registry.sol +236 -216
 - package/contracts/registry/RegistryAccessManager.sol +216 -0
 - package/contracts/registry/RegistryService.sol +96 -171
 - package/contracts/registry/RegistryServiceManager.sol +21 -39
 - package/contracts/registry/ReleaseManager.sol +322 -0
 - package/contracts/registry/TokenRegistry.sol +22 -17
 - package/contracts/shared/ERC165.sol +14 -12
 - package/contracts/shared/INftOwnable.sol +11 -10
 - package/contracts/shared/IPolicyHolder.sol +26 -0
 - package/contracts/shared/IRegisterable.sol +4 -6
 - package/contracts/shared/IRegistryLinked.sol +12 -0
 - package/contracts/shared/IService.sol +4 -1
 - package/contracts/shared/IVersionable.sol +4 -47
 - package/contracts/shared/NftOwnable.sol +66 -80
 - package/contracts/shared/PolicyHolder.sol +81 -0
 - package/contracts/shared/ProxyManager.sol +100 -25
 - package/contracts/shared/Registerable.sol +16 -32
 - package/contracts/shared/RegistryLinked.sol +48 -0
 - package/contracts/shared/Service.sol +25 -22
 - package/contracts/shared/Versionable.sol +4 -92
 - package/contracts/test/TestRegisterable.sol +1 -1
 - package/contracts/test/TestService.sol +4 -3
 - package/contracts/types/ClaimId.sol +52 -0
 - package/contracts/types/DistributorType.sol +2 -2
 - package/contracts/types/NftIdSet.sol +26 -24
 - package/contracts/types/ObjectType.sol +9 -5
 - package/contracts/types/PayoutId.sol +54 -0
 - package/contracts/types/Referral.sol +4 -0
 - package/contracts/types/RoleId.sol +19 -14
 - package/contracts/types/Seconds.sol +54 -0
 - package/contracts/types/Timestamp.sol +12 -13
 - package/package.json +3 -3
 - package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.dbg.json +0 -4
 - package/artifacts/contracts/components/BaseComponent.sol/BaseComponent.json +0 -327
 - package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.dbg.json +0 -4
 - package/artifacts/contracts/components/IBaseComponent.sol/IBaseComponent.json +0 -280
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.dbg.json +0 -4
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Cloner.json +0 -66
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.dbg.json +0 -4
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock1.json +0 -24
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.dbg.json +0 -4
 - package/artifacts/contracts/experiment/cloning/Cloner.sol/Mock2.json +0 -42
 - package/artifacts/contracts/experiment/errors/Require.sol/Require.dbg.json +0 -4
 - package/artifacts/contracts/experiment/errors/Require.sol/Require.json +0 -105
 - package/artifacts/contracts/experiment/errors/Revert.sol/Revert.dbg.json +0 -4
 - package/artifacts/contracts/experiment/errors/Revert.sol/Revert.json +0 -105
 - package/artifacts/contracts/experiment/inheritance/A.sol/A.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/A.sol/A.json +0 -128
 - package/artifacts/contracts/experiment/inheritance/A.sol/AShared.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/A.sol/AShared.json +0 -42
 - package/artifacts/contracts/experiment/inheritance/B.sol/B.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/B.sol/B.json +0 -76
 - package/artifacts/contracts/experiment/inheritance/C.sol/C.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/C.sol/C.json +0 -89
 - package/artifacts/contracts/experiment/inheritance/IA.sol/IA.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/IA.sol/IA.json +0 -128
 - package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/IA.sol/ISharedA.json +0 -37
 - package/artifacts/contracts/experiment/inheritance/IB.sol/IB.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/IC.sol/IC.dbg.json +0 -4
 - package/artifacts/contracts/experiment/inheritance/IC.sol/IC.json +0 -63
 - package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.dbg.json +0 -4
 - package/artifacts/contracts/experiment/statemachine/Dummy.sol/LifeCycleModule.json +0 -59
 - package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.dbg.json +0 -4
 - package/artifacts/contracts/experiment/statemachine/ISM.sol/ISM.json +0 -124
 - package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.dbg.json +0 -4
 - package/artifacts/contracts/experiment/statemachine/ISM.sol/ISMEE.json +0 -74
 - package/artifacts/contracts/experiment/statemachine/SM.sol/SM.dbg.json +0 -4
 - package/artifacts/contracts/experiment/statemachine/SM.sol/SM.json +0 -124
 - package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.dbg.json +0 -4
 - package/artifacts/contracts/experiment/statemachine/SimpleStateMachine.sol/SimpleStateMachine.json +0 -207
 - package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.dbg.json +0 -4
 - package/artifacts/contracts/experiment/types/TypeA.sol/TypeALib.json +0 -10
 - package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.dbg.json +0 -4
 - package/artifacts/contracts/experiment/types/TypeB.sol/TypeBLib.json +0 -10
 - package/artifacts/contracts/instance/AccessManagedSimple.sol/AccessManagedSimple.dbg.json +0 -4
 - package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.dbg.json +0 -4
 - package/artifacts/contracts/instance/AccessManagerSimple.sol/AccessManagerSimple.json +0 -1132
 - package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.dbg.json +0 -4
 - package/artifacts/contracts/instance/IAccessManagerSimple.sol/IAccessManagerSimple.json +0 -1082
 - package/artifacts/contracts/instance/base/ComponentServiceBase.sol/ComponentServiceBase.dbg.json +0 -4
 - package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.dbg.json +0 -4
 - package/artifacts/contracts/instance/base/IInstanceBase.sol/IInstanceBase.json +0 -113
 - package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.dbg.json +0 -4
 - package/artifacts/contracts/instance/service/ComponentOwnerService.sol/ComponentOwnerService.json +0 -827
 - package/artifacts/contracts/instance/service/IComponentOwnerService.sol/IComponentOwnerService.dbg.json +0 -4
 - package/artifacts/contracts/shared/RegisterableUpgradable.sol/RegisterableUpgradable.dbg.json +0 -4
 - package/contracts/components/BaseComponent.sol +0 -91
 - package/contracts/components/IBaseComponent.sol +0 -25
 - package/contracts/experiment/cloning/Cloner.sol +0 -47
 - package/contracts/experiment/errors/Require.sol +0 -38
 - package/contracts/experiment/errors/Revert.sol +0 -44
 - package/contracts/experiment/inheritance/A.sol +0 -53
 - package/contracts/experiment/inheritance/B.sol +0 -28
 - package/contracts/experiment/inheritance/C.sol +0 -34
 - package/contracts/experiment/inheritance/IA.sol +0 -13
 - package/contracts/experiment/inheritance/IB.sol +0 -10
 - package/contracts/experiment/inheritance/IC.sol +0 -12
 - package/contracts/experiment/statemachine/Dummy.sol +0 -27
 - package/contracts/experiment/statemachine/ISM.sol +0 -25
 - package/contracts/experiment/statemachine/SM.sol +0 -57
 - package/contracts/experiment/statemachine/SimpleStateMachine.sol +0 -31
 - package/contracts/experiment/types/TypeA.sol +0 -47
 - package/contracts/experiment/types/TypeB.sol +0 -29
 - package/contracts/instance/AccessManagedSimple.sol +0 -115
 - package/contracts/instance/AccessManagerSimple.sol +0 -692
 - package/contracts/instance/IAccessManagerSimple.sol +0 -391
 - package/contracts/instance/base/ComponentServiceBase.sol +0 -124
 - package/contracts/instance/base/IInstanceBase.sol +0 -23
 - package/contracts/instance/service/ComponentOwnerService.sol +0 -317
 - package/contracts/instance/service/IComponentOwnerService.sol +0 -20
 - package/contracts/shared/RegisterableUpgradable.sol +0 -16
 
| 
         @@ -1,95 +1,54 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            // SPDX-License-Identifier: Apache-2.0
         
     | 
| 
       2 
2 
     | 
    
         
             
            pragma solidity ^0.8.20;
         
     | 
| 
       3 
3 
     | 
    
         | 
| 
      
 4 
     | 
    
         
            +
            import {AccessManager} from "@openzeppelin/contracts/access/manager/AccessManager.sol";
         
     | 
| 
      
 5 
     | 
    
         
            +
            import {AccessManagedUpgradeable} from "@openzeppelin/contracts-upgradeable/access/manager/AccessManagedUpgradeable.sol";
         
     | 
| 
       4 
6 
     | 
    
         
             
            import {EnumerableSet} from "@openzeppelin/contracts/utils/structs/EnumerableSet.sol";
         
     | 
| 
       5 
7 
     | 
    
         
             
            import {ShortString, ShortStrings} from "@openzeppelin/contracts/utils/ShortStrings.sol";
         
     | 
| 
       6 
8 
     | 
    
         | 
| 
       7 
     | 
    
         
            -
            import { 
     | 
| 
       8 
     | 
    
         
            -
            import { 
     | 
| 
       9 
     | 
    
         
            -
            import { 
     | 
| 
       10 
     | 
    
         
            -
            import {IPolicy} from "./module/IPolicy.sol";
         
     | 
| 
       11 
     | 
    
         
            -
            import {IRisk} from "./module/IRisk.sol";
         
     | 
| 
       12 
     | 
    
         
            -
            import {ISetup} from "./module/ISetup.sol";
         
     | 
| 
       13 
     | 
    
         
            -
            import {Key32, KeyId, Key32Lib} from "../types/Key32.sol";
         
     | 
| 
       14 
     | 
    
         
            -
            import {KeyValueStore} from "./base/KeyValueStore.sol";
         
     | 
| 
       15 
     | 
    
         
            -
            import {NftId} from "../types/NftId.sol";
         
     | 
| 
       16 
     | 
    
         
            -
            import {NumberId} from "../types/NumberId.sol";
         
     | 
| 
       17 
     | 
    
         
            -
            import {ObjectType, BUNDLE, DISTRIBUTION, POLICY, POOL, ROLE, PRODUCT, TARGET} from "../types/ObjectType.sol";
         
     | 
| 
       18 
     | 
    
         
            -
            import {RiskId, RiskIdLib} from "../types/RiskId.sol";
         
     | 
| 
       19 
     | 
    
         
            -
            import {RoleId, RoleIdLib} from "../types/RoleId.sol";
         
     | 
| 
       20 
     | 
    
         
            -
            import {StateId, ACTIVE} from "../types/StateId.sol";
         
     | 
| 
       21 
     | 
    
         
            -
            import {Timestamp, TimestampLib} from "../types/Timestamp.sol";
         
     | 
| 
      
 9 
     | 
    
         
            +
            import {RoleId, RoleIdLib } from "../types/RoleId.sol";
         
     | 
| 
      
 10 
     | 
    
         
            +
            import {TimestampLib} from "../types/Timestamp.sol";
         
     | 
| 
      
 11 
     | 
    
         
            +
            import {IAccess} from "./module/IAccess.sol";
         
     | 
| 
       22 
12 
     | 
    
         | 
| 
       23 
13 
     | 
    
         
             
            contract InstanceAccessManager is
         
     | 
| 
       24 
     | 
    
         
            -
                 
     | 
| 
      
 14 
     | 
    
         
            +
                AccessManagedUpgradeable
         
     | 
| 
       25 
15 
     | 
    
         
             
            {
         
     | 
| 
      
 16 
     | 
    
         
            +
                using RoleIdLib for RoleId;
         
     | 
| 
      
 17 
     | 
    
         
            +
             
     | 
| 
       26 
18 
     | 
    
         
             
                string public constant ADMIN_ROLE_NAME = "AdminRole";
         
     | 
| 
       27 
19 
     | 
    
         
             
                string public constant PUBLIC_ROLE_NAME = "PublicRole";
         
     | 
| 
       28 
20 
     | 
    
         | 
| 
       29 
21 
     | 
    
         
             
                uint64 public constant CUSTOM_ROLE_ID_MIN = 10000;
         
     | 
| 
       30 
22 
     | 
    
         
             
                uint32 public constant EXECUTION_DELAY = 0;
         
     | 
| 
       31 
23 
     | 
    
         | 
| 
       32 
     | 
    
         
            -
                struct RoleInfo {
         
     | 
| 
       33 
     | 
    
         
            -
                    ShortString name;
         
     | 
| 
       34 
     | 
    
         
            -
                    bool isCustom;
         
     | 
| 
       35 
     | 
    
         
            -
                    bool isLocked;
         
     | 
| 
       36 
     | 
    
         
            -
                    Timestamp createdAt;
         
     | 
| 
       37 
     | 
    
         
            -
                    Timestamp updatedAt;
         
     | 
| 
       38 
     | 
    
         
            -
                }
         
     | 
| 
       39 
     | 
    
         
            -
             
     | 
| 
       40 
     | 
    
         
            -
                struct TargetInfo {
         
     | 
| 
       41 
     | 
    
         
            -
                    ShortString name;
         
     | 
| 
       42 
     | 
    
         
            -
                    bool isCustom;
         
     | 
| 
       43 
     | 
    
         
            -
                    bool isLocked;
         
     | 
| 
       44 
     | 
    
         
            -
                    Timestamp createdAt;
         
     | 
| 
       45 
     | 
    
         
            -
                    Timestamp updatedAt;
         
     | 
| 
       46 
     | 
    
         
            -
                }
         
     | 
| 
       47 
     | 
    
         
            -
             
     | 
| 
       48 
     | 
    
         
            -
                error ErrorRoleIdInvalid(RoleId roleId);
         
     | 
| 
       49 
     | 
    
         
            -
                error ErrorRoleIdTooBig(RoleId roleId);
         
     | 
| 
       50 
     | 
    
         
            -
                error ErrorRoleIdTooSmall(RoleId roleId);
         
     | 
| 
       51 
     | 
    
         
            -
                error ErrorRoleIdAlreadyExists(RoleId roleId, ShortString name);
         
     | 
| 
       52 
     | 
    
         
            -
                error ErrorRoleIdNotActive(RoleId roleId);
         
     | 
| 
       53 
     | 
    
         
            -
                error ErrorRoleNameEmpty(RoleId roleId);
         
     | 
| 
       54 
     | 
    
         
            -
                error ErrorRoleNameNotUnique(RoleId roleId, ShortString name);
         
     | 
| 
       55 
     | 
    
         
            -
                error ErrorRoleInvalidUpdate(RoleId roleId, bool isCustom);
         
     | 
| 
       56 
     | 
    
         
            -
                error ErrorRoleIsCustomIsImmutable(RoleId roleId, bool isCustom, bool isCustomExisting);
         
     | 
| 
       57 
     | 
    
         
            -
                error ErrorSetLockedForNonexstentRole(RoleId roleId);
         
     | 
| 
       58 
     | 
    
         
            -
                error ErrorGrantNonexstentRole(RoleId roleId);
         
     | 
| 
       59 
     | 
    
         
            -
                error ErrorRevokeNonexstentRole(RoleId roleId);
         
     | 
| 
       60 
     | 
    
         
            -
                error ErrorRenounceNonexstentRole(RoleId roleId);
         
     | 
| 
       61 
     | 
    
         
            -
             
     | 
| 
       62 
     | 
    
         
            -
                error ErrorTargetAddressZero();
         
     | 
| 
       63 
     | 
    
         
            -
                error ErrorTargetAlreadyExists(address target, ShortString name);
         
     | 
| 
       64 
     | 
    
         
            -
                error ErrorTargetNameEmpty(address target);
         
     | 
| 
       65 
     | 
    
         
            -
                error ErrorTargetNameExists(address target, address existingTarget, ShortString name);
         
     | 
| 
       66 
     | 
    
         
            -
                error ErrorSetLockedForNonexstentTarget(address target);
         
     | 
| 
       67 
     | 
    
         
            -
             
     | 
| 
       68 
24 
     | 
    
         
             
                // role specific state
         
     | 
| 
       69 
     | 
    
         
            -
                mapping(RoleId roleId => RoleInfo info) internal _role;
         
     | 
| 
      
 25 
     | 
    
         
            +
                mapping(RoleId roleId => IAccess.RoleInfo info) internal _role;
         
     | 
| 
       70 
26 
     | 
    
         
             
                mapping(RoleId roleId => EnumerableSet.AddressSet roleMembers) internal _roleMembers; 
         
     | 
| 
       71 
27 
     | 
    
         
             
                mapping(ShortString name => RoleId roleId) internal _roleForName;
         
     | 
| 
       72 
28 
     | 
    
         
             
                RoleId [] internal _roles;
         
     | 
| 
       73 
29 
     | 
    
         | 
| 
       74 
30 
     | 
    
         
             
                // target specific state
         
     | 
| 
       75 
     | 
    
         
            -
                mapping(address target => TargetInfo info) internal _target;
         
     | 
| 
      
 31 
     | 
    
         
            +
                mapping(address target => IAccess.TargetInfo info) internal _target;
         
     | 
| 
       76 
32 
     | 
    
         
             
                mapping(ShortString name => address target) internal _targetForName;
         
     | 
| 
       77 
33 
     | 
    
         
             
                address [] internal _targets;
         
     | 
| 
       78 
34 
     | 
    
         | 
| 
       79 
     | 
    
         
            -
                 
     | 
| 
      
 35 
     | 
    
         
            +
                AccessManager internal _accessManager;
         
     | 
| 
       80 
36 
     | 
    
         | 
| 
       81 
     | 
    
         
            -
                 
     | 
| 
      
 37 
     | 
    
         
            +
                function initialize(address initialAdmin) external initializer
         
     | 
| 
       82 
38 
     | 
    
         
             
                {
         
     | 
| 
       83 
     | 
    
         
            -
                     
     | 
| 
       84 
     | 
    
         
            -
                     
     | 
| 
      
 39 
     | 
    
         
            +
                    // if size of the contract gets too large, this can be externalized which will reduce the contract size considerably
         
     | 
| 
      
 40 
     | 
    
         
            +
                    _accessManager = new AccessManager(address(this));
         
     | 
| 
      
 41 
     | 
    
         
            +
                    // this service required admin rights to access manager to be able to grant/revoke roles
         
     | 
| 
      
 42 
     | 
    
         
            +
                    _accessManager.grantRole(_accessManager.ADMIN_ROLE(), initialAdmin, 0);
         
     | 
| 
      
 43 
     | 
    
         
            +
             
     | 
| 
      
 44 
     | 
    
         
            +
                    __AccessManaged_init(address(_accessManager));
         
     | 
| 
       85 
45 
     | 
    
         | 
| 
       86 
46 
     | 
    
         
             
                    _createRole(RoleIdLib.toRoleId(_accessManager.ADMIN_ROLE()), ADMIN_ROLE_NAME, false, false);
         
     | 
| 
       87 
47 
     | 
    
         
             
                    _createRole(RoleIdLib.toRoleId(_accessManager.PUBLIC_ROLE()), PUBLIC_ROLE_NAME, false, false);
         
     | 
| 
       88 
48 
     | 
    
         
             
                }
         
     | 
| 
       89 
49 
     | 
    
         | 
| 
       90 
50 
     | 
    
         
             
                //--- Role ------------------------------------------------------//
         
     | 
| 
       91 
     | 
    
         
            -
             
     | 
| 
       92 
     | 
    
         
            -
                function createDefaultRole(RoleId roleId, string memory name) external restricted() {
         
     | 
| 
      
 51 
     | 
    
         
            +
                function createGifRole(RoleId roleId, string memory name) external restricted() {
         
     | 
| 
       93 
52 
     | 
    
         
             
                    _createRole(roleId, name, false, true);
         
     | 
| 
       94 
53 
     | 
    
         
             
                }
         
     | 
| 
       95 
54 
     | 
    
         | 
| 
         @@ -99,7 +58,7 @@ contract InstanceAccessManager is 
     | 
|
| 
       99 
58 
     | 
    
         | 
| 
       100 
59 
     | 
    
         
             
                function setRoleLocked(RoleId roleId, bool locked) external restricted() {
         
     | 
| 
       101 
60 
     | 
    
         
             
                    if (!roleExists(roleId)) {
         
     | 
| 
       102 
     | 
    
         
            -
                        revert  
     | 
| 
      
 61 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
         
     | 
| 
       103 
62 
     | 
    
         
             
                    }
         
     | 
| 
       104 
63 
     | 
    
         | 
| 
       105 
64 
     | 
    
         
             
                    _role[roleId].isLocked = locked;
         
     | 
| 
         @@ -112,11 +71,11 @@ contract InstanceAccessManager is 
     | 
|
| 
       112 
71 
     | 
    
         | 
| 
       113 
72 
     | 
    
         
             
                function grantRole(RoleId roleId, address member) external restricted() returns (bool granted) {
         
     | 
| 
       114 
73 
     | 
    
         
             
                    if (!roleExists(roleId)) {
         
     | 
| 
       115 
     | 
    
         
            -
                        revert  
     | 
| 
      
 74 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
         
     | 
| 
       116 
75 
     | 
    
         
             
                    }
         
     | 
| 
       117 
76 
     | 
    
         | 
| 
       118 
77 
     | 
    
         
             
                    if (_role[roleId].isLocked) {
         
     | 
| 
       119 
     | 
    
         
            -
                        revert  
     | 
| 
      
 78 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdNotActive(roleId);
         
     | 
| 
       120 
79 
     | 
    
         
             
                    }
         
     | 
| 
       121 
80 
     | 
    
         | 
| 
       122 
81 
     | 
    
         
             
                    if (!EnumerableSet.contains(_roleMembers[roleId], member)) {
         
     | 
| 
         @@ -130,7 +89,7 @@ contract InstanceAccessManager is 
     | 
|
| 
       130 
89 
     | 
    
         | 
| 
       131 
90 
     | 
    
         
             
                function revokeRole(RoleId roleId, address member) external restricted() returns (bool revoked) {
         
     | 
| 
       132 
91 
     | 
    
         
             
                    if (!roleExists(roleId)) {
         
     | 
| 
       133 
     | 
    
         
            -
                        revert  
     | 
| 
      
 92 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRevokeNonexstentRole(roleId);
         
     | 
| 
       134 
93 
     | 
    
         
             
                    }
         
     | 
| 
       135 
94 
     | 
    
         | 
| 
       136 
95 
     | 
    
         
             
                    if (EnumerableSet.contains(_roleMembers[roleId], member)) {
         
     | 
| 
         @@ -148,7 +107,7 @@ contract InstanceAccessManager is 
     | 
|
| 
       148 
107 
     | 
    
         
             
                    address member = msg.sender;
         
     | 
| 
       149 
108 
     | 
    
         | 
| 
       150 
109 
     | 
    
         
             
                    if (!roleExists(roleId)) {
         
     | 
| 
       151 
     | 
    
         
            -
                        revert  
     | 
| 
      
 110 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRenounceNonexstentRole(roleId);
         
     | 
| 
       152 
111 
     | 
    
         
             
                    }
         
     | 
| 
       153 
112 
     | 
    
         | 
| 
       154 
113 
     | 
    
         
             
                    if (EnumerableSet.contains(_roleMembers[roleId], member)) {
         
     | 
| 
         @@ -173,7 +132,7 @@ contract InstanceAccessManager is 
     | 
|
| 
       173 
132 
     | 
    
         
             
                    return _roleForName[ShortStrings.toShortString(name)];
         
     | 
| 
       174 
133 
     | 
    
         
             
                }
         
     | 
| 
       175 
134 
     | 
    
         | 
| 
       176 
     | 
    
         
            -
                function getRole(RoleId roleId) external view returns (RoleInfo memory role) {
         
     | 
| 
      
 135 
     | 
    
         
            +
                function getRole(RoleId roleId) external view returns (IAccess.RoleInfo memory role) {
         
     | 
| 
       177 
136 
     | 
    
         
             
                    return _role[roleId];
         
     | 
| 
       178 
137 
     | 
    
         
             
                }
         
     | 
| 
       179 
138 
     | 
    
         | 
| 
         @@ -190,13 +149,19 @@ contract InstanceAccessManager is 
     | 
|
| 
       190 
149 
     | 
    
         
             
                }
         
     | 
| 
       191 
150 
     | 
    
         | 
| 
       192 
151 
     | 
    
         
             
                //--- Target ------------------------------------------------------//
         
     | 
| 
      
 152 
     | 
    
         
            +
                function createGifTarget(address target, string memory name) external restricted() {
         
     | 
| 
      
 153 
     | 
    
         
            +
                    _createTarget(target, name, false, true);
         
     | 
| 
      
 154 
     | 
    
         
            +
                }
         
     | 
| 
      
 155 
     | 
    
         
            +
             
     | 
| 
       193 
156 
     | 
    
         
             
                function createTarget(address target, string memory name) external restricted() {
         
     | 
| 
       194 
157 
     | 
    
         
             
                    _createTarget(target, name, true, true);
         
     | 
| 
       195 
158 
     | 
    
         
             
                }
         
     | 
| 
       196 
159 
     | 
    
         | 
| 
       197 
     | 
    
         
            -
                function setTargetLocked( 
     | 
| 
       198 
     | 
    
         
            -
                     
     | 
| 
       199 
     | 
    
         
            -
             
     | 
| 
      
 160 
     | 
    
         
            +
                function setTargetLocked(string memory targetName, bool locked) external restricted() {
         
     | 
| 
      
 161 
     | 
    
         
            +
                    address target = _targetForName[ShortStrings.toShortString(targetName)];
         
     | 
| 
      
 162 
     | 
    
         
            +
                    
         
     | 
| 
      
 163 
     | 
    
         
            +
                    if (target == address(0)) {
         
     | 
| 
      
 164 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessTargetDoesNotExist(ShortStrings.toShortString(targetName));
         
     | 
| 
       200 
165 
     | 
    
         
             
                    }
         
     | 
| 
       201 
166 
     | 
    
         | 
| 
       202 
167 
     | 
    
         
             
                    _target[target].isLocked = locked;
         
     | 
| 
         @@ -214,7 +179,7 @@ contract InstanceAccessManager is 
     | 
|
| 
       214 
179 
     | 
    
         
             
                        _validateRoleParameters(roleId, name, isCustom);
         
     | 
| 
       215 
180 
     | 
    
         
             
                    }
         
     | 
| 
       216 
181 
     | 
    
         | 
| 
       217 
     | 
    
         
            -
                    RoleInfo memory role = RoleInfo(
         
     | 
| 
      
 182 
     | 
    
         
            +
                    IAccess.RoleInfo memory role = IAccess.RoleInfo(
         
     | 
| 
       218 
183 
     | 
    
         
             
                        ShortStrings.toShortString(name), 
         
     | 
| 
       219 
184 
     | 
    
         
             
                        isCustom,
         
     | 
| 
       220 
185 
     | 
    
         
             
                        false, // role un-locked,
         
     | 
| 
         @@ -233,35 +198,35 @@ contract InstanceAccessManager is 
     | 
|
| 
       233 
198 
     | 
    
         
             
                )
         
     | 
| 
       234 
199 
     | 
    
         
             
                    internal
         
     | 
| 
       235 
200 
     | 
    
         
             
                    view 
         
     | 
| 
       236 
     | 
    
         
            -
                    returns (RoleInfo memory existingRole)
         
     | 
| 
      
 201 
     | 
    
         
            +
                    returns (IAccess.RoleInfo memory existingRole)
         
     | 
| 
       237 
202 
     | 
    
         
             
                {
         
     | 
| 
       238 
203 
     | 
    
         
             
                    // check role id
         
     | 
| 
       239 
204 
     | 
    
         
             
                    uint64 roleIdInt = RoleId.unwrap(roleId);
         
     | 
| 
       240 
205 
     | 
    
         
             
                    if(roleIdInt == _accessManager.ADMIN_ROLE() || roleIdInt == _accessManager.PUBLIC_ROLE()) {
         
     | 
| 
       241 
     | 
    
         
            -
                        revert  
     | 
| 
      
 206 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdInvalid(roleId); 
         
     | 
| 
       242 
207 
     | 
    
         
             
                    }
         
     | 
| 
       243 
208 
     | 
    
         | 
| 
       244 
209 
     | 
    
         
             
                    // prevent changing isCustom for existing roles
         
     | 
| 
       245 
210 
     | 
    
         
             
                    existingRole = _role[roleId];
         
     | 
| 
       246 
211 
     | 
    
         | 
| 
       247 
212 
     | 
    
         
             
                    if (existingRole.createdAt.gtz() && isCustom != existingRole.isCustom) {
         
     | 
| 
       248 
     | 
    
         
            -
                        revert  
     | 
| 
      
 213 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIsCustomIsImmutable(roleId, isCustom, existingRole.isCustom); 
         
     | 
| 
       249 
214 
     | 
    
         
             
                    }
         
     | 
| 
       250 
215 
     | 
    
         | 
| 
       251 
216 
     | 
    
         
             
                    if (isCustom && roleIdInt < CUSTOM_ROLE_ID_MIN) {
         
     | 
| 
       252 
     | 
    
         
            -
                        revert  
     | 
| 
      
 217 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdTooSmall(roleId); 
         
     | 
| 
       253 
218 
     | 
    
         
             
                    } else if (!isCustom && roleIdInt >= CUSTOM_ROLE_ID_MIN) {
         
     | 
| 
       254 
     | 
    
         
            -
                        revert  
     | 
| 
      
 219 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdTooBig(roleId); 
         
     | 
| 
       255 
220 
     | 
    
         
             
                    }
         
     | 
| 
       256 
221 
     | 
    
         | 
| 
       257 
222 
     | 
    
         
             
                    // role name checks
         
     | 
| 
       258 
223 
     | 
    
         
             
                    ShortString nameShort = ShortStrings.toShortString(name);
         
     | 
| 
       259 
224 
     | 
    
         
             
                    if (ShortStrings.byteLength(nameShort) == 0) {
         
     | 
| 
       260 
     | 
    
         
            -
                        revert  
     | 
| 
      
 225 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleNameEmpty(roleId);
         
     | 
| 
       261 
226 
     | 
    
         
             
                    }
         
     | 
| 
       262 
227 
     | 
    
         | 
| 
       263 
228 
     | 
    
         
             
                    if (_roleForName[nameShort] != RoleIdLib.zero() && _roleForName[nameShort] != roleId) {
         
     | 
| 
       264 
     | 
    
         
            -
                        revert  
     | 
| 
      
 229 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleNameNotUnique(_roleForName[nameShort], nameShort);
         
     | 
| 
       265 
230 
     | 
    
         
             
                    }
         
     | 
| 
       266 
231 
     | 
    
         
             
                }
         
     | 
| 
       267 
232 
     | 
    
         | 
| 
         @@ -270,7 +235,14 @@ contract InstanceAccessManager is 
     | 
|
| 
       270 
235 
     | 
    
         
             
                        _validateTargetParameters(target, name, isCustom);
         
     | 
| 
       271 
236 
     | 
    
         
             
                    }
         
     | 
| 
       272 
237 
     | 
    
         | 
| 
       273 
     | 
    
         
            -
                     
     | 
| 
      
 238 
     | 
    
         
            +
                    if (_target[target].createdAt.gtz()) {
         
     | 
| 
      
 239 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessTargetExists(target, _target[target].name);
         
     | 
| 
      
 240 
     | 
    
         
            +
                    }
         
     | 
| 
      
 241 
     | 
    
         
            +
                    if (_targetForName[ShortStrings.toShortString(name)] != address(0)) {
         
     | 
| 
      
 242 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessTargetNameExists(target, _targetForName[ShortStrings.toShortString(name)], ShortStrings.toShortString(name));
         
     | 
| 
      
 243 
     | 
    
         
            +
                    }
         
     | 
| 
      
 244 
     | 
    
         
            +
             
     | 
| 
      
 245 
     | 
    
         
            +
                    IAccess.TargetInfo memory info = IAccess.TargetInfo(
         
     | 
| 
       274 
246 
     | 
    
         
             
                        ShortStrings.toShortString(name), 
         
     | 
| 
       275 
247 
     | 
    
         
             
                        isCustom,
         
     | 
| 
       276 
248 
     | 
    
         
             
                        _accessManager.isTargetClosed(target), // sync with state in access manager
         
     | 
| 
         @@ -283,6 +255,43 @@ contract InstanceAccessManager is 
     | 
|
| 
       283 
255 
     | 
    
         
             
                }
         
     | 
| 
       284 
256 
     | 
    
         | 
| 
       285 
257 
     | 
    
         
             
                function _validateTargetParameters(address target, string memory name, bool isCustom) internal view {
         
     | 
| 
      
 258 
     | 
    
         
            +
                    // TODO: implement
         
     | 
| 
      
 259 
     | 
    
         
            +
                }
         
     | 
| 
      
 260 
     | 
    
         
            +
             
     | 
| 
      
 261 
     | 
    
         
            +
                function setTargetFunctionRole(
         
     | 
| 
      
 262 
     | 
    
         
            +
                    string memory targetName,
         
     | 
| 
      
 263 
     | 
    
         
            +
                    bytes4[] calldata selectors,
         
     | 
| 
      
 264 
     | 
    
         
            +
                    RoleId roleId
         
     | 
| 
      
 265 
     | 
    
         
            +
                ) public virtual restricted() {
         
     | 
| 
      
 266 
     | 
    
         
            +
                    address target = _targetForName[ShortStrings.toShortString(targetName)];
         
     | 
| 
      
 267 
     | 
    
         
            +
                    
         
     | 
| 
      
 268 
     | 
    
         
            +
                    if (target == address(0)) {
         
     | 
| 
      
 269 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessTargetDoesNotExist(ShortStrings.toShortString(targetName));
         
     | 
| 
      
 270 
     | 
    
         
            +
                    }
         
     | 
| 
      
 271 
     | 
    
         
            +
                    if (! roleExists(roleId)) {
         
     | 
| 
      
 272 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessRoleIdInvalid(roleId);
         
     | 
| 
      
 273 
     | 
    
         
            +
                    }
         
     | 
| 
      
 274 
     | 
    
         
            +
                    uint64 roleIdInt = RoleId.unwrap(roleId);
         
     | 
| 
      
 275 
     | 
    
         
            +
                    _accessManager.setTargetFunctionRole(target, selectors, roleIdInt);
         
     | 
| 
      
 276 
     | 
    
         
            +
                }
         
     | 
| 
      
 277 
     | 
    
         
            +
             
     | 
| 
      
 278 
     | 
    
         
            +
                function setTargetClosed(string memory targetName, bool closed) public restricted() {
         
     | 
| 
      
 279 
     | 
    
         
            +
                    address target = _targetForName[ShortStrings.toShortString(targetName)];
         
     | 
| 
      
 280 
     | 
    
         
            +
                    if (target == address(0)) {
         
     | 
| 
      
 281 
     | 
    
         
            +
                        revert IAccess.ErrorIAccessTargetDoesNotExist(ShortStrings.toShortString(targetName));
         
     | 
| 
      
 282 
     | 
    
         
            +
                    }
         
     | 
| 
      
 283 
     | 
    
         
            +
                    _accessManager.setTargetClosed(target, closed);
         
     | 
| 
      
 284 
     | 
    
         
            +
                }
         
     | 
| 
      
 285 
     | 
    
         
            +
             
     | 
| 
      
 286 
     | 
    
         
            +
                function isTargetLocked(address target) public view returns (bool locked) {
         
     | 
| 
      
 287 
     | 
    
         
            +
                    return _accessManager.isTargetClosed(target);
         
     | 
| 
      
 288 
     | 
    
         
            +
                }
         
     | 
| 
       286 
289 
     | 
    
         | 
| 
      
 290 
     | 
    
         
            +
                function canCall(
         
     | 
| 
      
 291 
     | 
    
         
            +
                    address caller,
         
     | 
| 
      
 292 
     | 
    
         
            +
                    address target,
         
     | 
| 
      
 293 
     | 
    
         
            +
                    bytes4 selector
         
     | 
| 
      
 294 
     | 
    
         
            +
                ) public view virtual returns (bool immediate, uint32 delay) {
         
     | 
| 
      
 295 
     | 
    
         
            +
                    return _accessManager.canCall(caller, target, selector);
         
     | 
| 
       287 
296 
     | 
    
         
             
                }
         
     | 
| 
       288 
297 
     | 
    
         
             
            }
         
     | 
| 
         @@ -13,6 +13,7 @@ import {Registerable} from "../shared/Registerable.sol"; 
     | 
|
| 
       13 
13 
     | 
    
         
             
            import {RiskId} from "../types/RiskId.sol";
         
     | 
| 
       14 
14 
     | 
    
         
             
            import {UFixed, MathLib, UFixedLib} from "../types/UFixed.sol";
         
     | 
| 
       15 
15 
     | 
    
         
             
            import {Version} from "../types/Version.sol";
         
     | 
| 
      
 16 
     | 
    
         
            +
            import {StateId} from "../types/StateId.sol";
         
     | 
| 
       16 
17 
     | 
    
         | 
| 
       17 
18 
     | 
    
         
             
            import {IRegistry} from "../registry/IRegistry.sol";
         
     | 
| 
       18 
19 
     | 
    
         
             
            import {IBundle} from "../instance/module/IBundle.sol";
         
     | 
| 
         @@ -30,39 +31,21 @@ contract InstanceReader { 
     | 
|
| 
       30 
31 
     | 
    
         
             
                bool private _initialized;
         
     | 
| 
       31 
32 
     | 
    
         | 
| 
       32 
33 
     | 
    
         
             
                IRegistry internal _registry;
         
     | 
| 
       33 
     | 
    
         
            -
                NftId internal _instanceNftId;
         
     | 
| 
       34 
34 
     | 
    
         
             
                IInstance internal _instance;
         
     | 
| 
       35 
35 
     | 
    
         
             
                IKeyValueStore internal _store;
         
     | 
| 
       36 
36 
     | 
    
         | 
| 
       37 
     | 
    
         
            -
                 
     | 
| 
       38 
     | 
    
         
            -
                    address registry, 
         
     | 
| 
       39 
     | 
    
         
            -
                    NftId instanceNftId
         
     | 
| 
       40 
     | 
    
         
            -
                )
         
     | 
| 
       41 
     | 
    
         
            -
                {
         
     | 
| 
       42 
     | 
    
         
            -
                    initialize(registry, instanceNftId);
         
     | 
| 
       43 
     | 
    
         
            -
                }
         
     | 
| 
       44 
     | 
    
         
            -
             
     | 
| 
       45 
     | 
    
         
            -
                function initialize(address registry, NftId instanceNftId) public {
         
     | 
| 
      
 37 
     | 
    
         
            +
                function initialize(address registry, address instance) public {
         
     | 
| 
       46 
38 
     | 
    
         
             
                    require(!_initialized, "ERROR:CRD-000:ALREADY_INITIALIZED");
         
     | 
| 
       47 
39 
     | 
    
         | 
| 
       48 
40 
     | 
    
         
             
                    require(
         
     | 
| 
       49 
41 
     | 
    
         
             
                        address(registry) != address(0),
         
     | 
| 
       50 
42 
     | 
    
         
             
                        "ERROR:CRD-001:REGISTRY_ZERO");
         
     | 
| 
       51 
43 
     | 
    
         | 
| 
       52 
     | 
    
         
            -
                    require(
         
     | 
| 
       53 
     | 
    
         
            -
                        instanceNftId.gtz(),
         
     | 
| 
       54 
     | 
    
         
            -
                        "ERROR:CRD-002:NFT_ID_ZERO");
         
     | 
| 
       55 
44 
     | 
    
         | 
| 
       56 
45 
     | 
    
         
             
                    _registry = IRegistry(registry);
         
     | 
| 
       57 
     | 
    
         
            -
                    _instanceNftId = instanceNftId;
         
     | 
| 
       58 
     | 
    
         
            -
                    IRegistry.ObjectInfo memory instanceInfo = _registry.getObjectInfo(_instanceNftId);
         
     | 
| 
       59 
     | 
    
         
            -
             
     | 
| 
       60 
     | 
    
         
            -
                    require(
         
     | 
| 
       61 
     | 
    
         
            -
                        instanceInfo.objectType == INSTANCE(), 
         
     | 
| 
       62 
     | 
    
         
            -
                        "ERROR:CRD-003:PARENT_NOT_INSTANCE");
         
     | 
| 
       63 
46 
     | 
    
         | 
| 
       64 
     | 
    
         
            -
                    _instance = IInstance( 
     | 
| 
       65 
     | 
    
         
            -
                    _store = IKeyValueStore( 
     | 
| 
      
 47 
     | 
    
         
            +
                    _instance = IInstance(instance);
         
     | 
| 
      
 48 
     | 
    
         
            +
                    _store = IKeyValueStore(instance);
         
     | 
| 
       66 
49 
     | 
    
         | 
| 
       67 
50 
     | 
    
         
             
                    _initialized = true;
         
     | 
| 
       68 
51 
     | 
    
         
             
                }
         
     | 
| 
         @@ -81,6 +64,14 @@ contract InstanceReader { 
     | 
|
| 
       81 
64 
     | 
    
         
             
                    }
         
     | 
| 
       82 
65 
     | 
    
         
             
                }
         
     | 
| 
       83 
66 
     | 
    
         | 
| 
      
 67 
     | 
    
         
            +
                function getPolicyState(NftId policyNftId)
         
     | 
| 
      
 68 
     | 
    
         
            +
                    public
         
     | 
| 
      
 69 
     | 
    
         
            +
                    view
         
     | 
| 
      
 70 
     | 
    
         
            +
                    returns (StateId state)
         
     | 
| 
      
 71 
     | 
    
         
            +
                {
         
     | 
| 
      
 72 
     | 
    
         
            +
                    return _instance.getState(toPolicyKey(policyNftId));
         
     | 
| 
      
 73 
     | 
    
         
            +
                }
         
     | 
| 
      
 74 
     | 
    
         
            +
             
     | 
| 
       84 
75 
     | 
    
         
             
                function getRiskInfo(RiskId riskId)
         
     | 
| 
       85 
76 
     | 
    
         
             
                    public 
         
     | 
| 
       86 
77 
     | 
    
         
             
                    view 
         
     | 
| 
         @@ -292,10 +283,6 @@ contract InstanceReader { 
     | 
|
| 
       292 
283 
     | 
    
         
             
                    return _store;
         
     | 
| 
       293 
284 
     | 
    
         
             
                }
         
     | 
| 
       294 
285 
     | 
    
         | 
| 
       295 
     | 
    
         
            -
                function getInstanceNftId() external view returns (NftId nftId) {
         
     | 
| 
       296 
     | 
    
         
            -
                    return _instanceNftId;
         
     | 
| 
       297 
     | 
    
         
            -
                }
         
     | 
| 
       298 
     | 
    
         
            -
             
     | 
| 
       299 
286 
     | 
    
         
             
                function toUFixed(uint256 value, int8 exp) public pure returns (UFixed) {
         
     | 
| 
       300 
287 
     | 
    
         
             
                    return UFixedLib.toUFixed(value, exp);
         
     | 
| 
       301 
288 
     | 
    
         
             
                }
         
     |