This contract provides a registry for appchains of Octopus Network. It contains the metadata of the appchains and manage their lifecycle in Octopus Network.
Contents:
owner
: The owner of this contract, which is the Octopus DAO.appchain anchor
: A NEAR contract which is deployed in a subaccount of the account of this contract. It is in charge of managing the necessary data of an appchain on NEAR protocol, providing security and interoperability for the appchain. The anchor contracts are controlled by theowner
(Octopus DAO) too, and the octopus-appchain-anchor is the standard implementation provided by Octopus Core Team.appchain owner
: The owner of an appchain, usually the developer or someone who represent the developer team.Octopus DAO
: The DAO contract for on-chain governance of Octopus Network.Octopus Council
: The council composed of a certain number of the users with the largest staking amount in Octopus Network.appchain state
: The state of an appchain, which is one of the following:registered
: The initial state of an appchain, after it is successfully registered.audited
: The state while the appchain had been audited.voting
: The state while the octopus council members can upvote in octopus DAO.booting
: The state while an appchain is booting. This state is managed byappchain anchor
.active
: The state while an appchain is active normally. This state is managed byappchain anchor
.closing
: The state which an appchain is closing for some technical or governance reasons. This state is managed byappchain anchor
.closed
: The state which the lifecycle of an appchain is end.
register deposit
: To prevent abuse of audit services, an appchain has to deposit a small amount of OCT token when register.registry settings
: A set of settings for this contract, which contains the following fields:minimum register deposit
: The minimum amount ofregister deposit
which is specified by Octopus DAO.
registry roles
: A set of roles for this contract, which contains the following fields:registry settings manager
: The account id that can perform actions to changeregistry settings
.appchain lifecycle manager
: The account id that can manage the lifecycle of appchains in registry.octopus council
: The account id representing the octopus council (in octopus DAO).
This contract has a set of functions to manage registry settings
. Each of these functions is for changing one field of the settings. Only the account that is set to role registry settings manager
can call these functions. (Refer to Registry roles.)
This contract has a set of functions to manage registry roles
. Each of these functions is for changing the account that acts as a certain role. (Refer to Registry roles.)
Anyone can register appchain in this contract by providing necessary information for the appchain with a certain amount of OCT token deposited to this contract. The amount should be not less than minimum register deposit
of registry settings
.
The
register deposit
will NOT be refunded in any condition. It is considered as auditing fee for registered appchain.
The account that successfully registered an appchain in this contract will automatically become the owner of the appchain
. This account can perform the following actions:
- Transfer the ownership of the certain appchain to another account.
- Withdraw the registration of the certain appchain.
This contract has a set of functions to manage the lifecycle of appchains registered in it. The general process of appchain lifecycle management are as the following:
Business action | Description | Contract function | Role/Account to perform action in contract | Appchain State after the action |
---|---|---|---|---|
Register appchain | Refer to Register appchain. | ft_on_transfer | any account / manually | Registered |
Audit appchain | Octopus network team will check necessary content to confirm whether the appchain can be proposed in octopus DAO to start booting. | pass_auditing_appchain | Appchain lifecycle manager / manually | Audited |
Sponsor appchain | Members of Octopus Council can sponsor a certain appchain to create a proposal in Octpus DAO for voting. | start_voting_appchain | Appchain lifecycle manager / manually | Voting |
Vote for appchain | Members of Octopus Council can vote for a certain appchain in Octopus DAO. | start_booting_appchain | Octopus DAO account / automatically | Booting |
Reject appchain | Octopus Network team can reject an appchain if it didn't pass auditing or it didn't pass voting in Octopus DAO. | reject_appchain | Appchain lifecycle manager / manually | Closed |
Boot appchain | Octopus Network team will prepare the necessary infrastructure for the appchain to go live. Refer to Octopus Appchain Anchor. | N/A | N/A | N/A |
Remove appchain | Octopus Network team can remove an appchain from this contract if it is dead. | remove_appchain | Appchain lifecycle manager / manually | N/A |
Besides the above actions, the Appchain lifecycle manager
can also update the metadata of any appchain.
The owner account of this contract can pause or resume asset transfer in this contract. The actions that will be limited should be:
- Transfer OCT token into this contract by function
ft_transfer_call
of OCT token contract, with a certain message attached (to register an appchain or upvote/downvote for an appchain). - Withdraw upvote/downvote deposit from this contract.
This contract has a set of view functions for anyone to get the status detail of this contract.
This contract has different roles to restrict access to certain functions.
Contract action | Contract owner | Registry settings manager | Appchain lifecycle manager | Octopus Council |
---|---|---|---|---|
change_appchain_lifecycle_manager | allowed | allowed | ||
change_registry_settings_manager | allowed | allowed | ||
change_octopus_council | allowed | |||
change_minimum_register_deposit | allowed | |||
update_appchain_metadata | allowed | |||
pass_auditing_appchain | allowed | |||
start_voting_appchain | allowed | |||
start_booting_appchain | allowed | |||
reject_appchain | allowed | |||
remove_appchain | allowed | |||
pause_asset_transfer | allowed | |||
resume_asset_transfer | allowed |
An account can NOT has different roles at the same time.
This contract (v1.1.0
) had been audited by Halborn. Here is the report.
Simply run .build.sh
to build the project. The script will create folder out
and res
.
Run ./build.sh test
to build and run all test code.