๐งจLaunch Process
Outlining the launch phases for the Carthage testnet and mainnet.
Introduction
Launching a new blockchain secured by a new PoS validator set, which comes to consensus using a time sensitive BFT protocol, is a vulnerable process which easily can end up with liveness failure as a result of networking or operational malfunctioning. For this reason, it should be happen in a gradual process, starting very centralised and small, and opening up to a broader set of stakeholders while block production is monitored. It also has to be a fair process which does not bias in favor of early or arbitrary participants. Lastly, there must be some room for small scale coordination to handle any unforunforeseenseen catastrophic errors which may occur early, and with minimal if any side-effects. The process for launching the Joystream blockchain was designed based on these requirements.
Carthage and Mainnet
This process will be used for the upcoming launch of the Carthage
network, where runtime is feature frozen - and genesis block is largely locked in, and only unforseen circumstances will result in further changes to the process described herein.
Overview
The launch of the final joystream testnet - Carthage
, intended as the final test of the runtime and our intended deployment plan for the Joystream mainnet, will be rolled out as outlined in the table below:
Frozen
~24h
Yes (Single Key)
PoA
sudo,
staking,
session,
multisig*
Bootstrap -> Thawn
No
9-12
Thawn
~6days
Yes (Multisig)
PoS
sudo,
staking,
session,
multisig*
Set #Validators -> Supervised
Yes
12-24
Supervised
Weeks
Yes (Multisig)
PoS
Everything**
Set #Validators -> Liberated
Yes
24-?
Liberated
NA
No
PoS
Everything**
NA
Yes
council decides
*
All transaction related to thesudo
,staking
,session
andmultisig
modules will not be filtered, regardless of origin. This means:Prospective validators and nominators can prepare and configure their validator (on chain), and/or nominate. There will be no changes to the actual set however during the
Frozen
stage.Any
multisig
transactions can be initiated and approved, but the actual call will be filtered unless the call is:sudo.*
staking.*
session.*
Although any
sudo.*
will get through the filter, unless the caller of the extrinsic is actuallysudo
, the transaction will, of course, still fail.
**
Some filters will still apply, but they are only applied to certain features that are in the runtime, but not properly integrated. The main example being thebounty
module.
Frozen Phase
Overview
Duration:
~24hours
Consensus:
PoA
Purpose: bootstrapping of
memberships
Actors:
Jsgenesis (as
sudo
)Prospective validators and nominators
Filter: everything except
staking
session
sudo
multisig
Purpose
The main reason the chain is deployed with a PoA
consensus algorithm is to allow a safer deployment, without having to restrict access to the chain spec.
Community Actions
As soon as the first block is created, anyone (with tokens to cover the fees) can make any transaction they want. However, as stated previously, only transaction to the staking
or session
module will be executed. Note that any other action will still incur fees.
Validators
Go here for a step by step guide to become a validator or nominator.
Jsgenesis Actions
The actions and transactions to be made by Jsgenesis can be found, in sequence, below.
Bootstrapping
As soon as the chain has been deployment, Jsgenesis will run a script that creates all members on the platform as they were at the time of the migration snapshot, meaning:
rootAccount
controllerAccount
memberHandle
metadata
The extra data held by the query node
isFoundingMember
As all members are created in sequence, so that members will keep their memberId
.
Set new sudo
key
sudo
keyAs the script that handles the bootstrapping requires sudo
to bypass the filter, the next step is to change the sudo
key to a multisig key. The signer keys are stored offline, reducing the risk of loss, hacking and social engineering.
Set the validatorCount
validatorCount
By default, the chain sets the "ideal" number of validators, namely the staking.validatorCount
equal to the amount of authorities - which is 9. The (new) sudo
key will change this to 12.
Move to Thawn
Thawn
Once ~24 hours have passed, giving everyone equal opportunity to deploy their nodes and configure their validator keys on chain, sudo
will make the staking.forceNewEra()
call, effectively changing the consensus system from PoA to PoS.
Thawn Phase
Overview
Duration:
~6days
Consensus:
PoS
Purpose: Ensure a safe transition from
PoA
toPoS
Actors:
Jsgenesis (as
sudo
)Validators and nominators
Filter: everything except
staking
session
sudo
multisig
Purpose
To ensure a safe transition from PoA
to PoS
, Jsgenesis will gradually increase the size validator set (ie. the maximum amount of validators in each era
).
The benefits of doing relatively small increases of the size:
Higher competition for slots -> higher stakes required -> actors will be more careful and diligent
Lower chances of a single bad faith actor occupying a critical amount of slots
Easier to reach, assist and recover in case of issues
Community Actions
With the filter still intact, the main action the community can do is to get involved with validation and nomination.
Validators
During this stage, validators and nominators can come and go as they like. They will earn rewards, but are also at the risk of being slashed.
Jsgenesis Actions
The actions and transactions to be made by Jsgenesis can be found, in sequence, below.
Set the validatorCount
validatorCount
As we see more and more competition for slots, and that the current validator set are performing well, Jsgenesis will increase the amount of slots allowing new actors to join.
More specifically, some of the metrics we will look at are:
Are all validators online, and producing blocks when called upon
Are all validators contributing to finalization
Are validators well connected to each other, maintaining acceptable latency and the blocktime stays at ~6s.
Is there a sufficiently "deep" bench to ensure the stake requirements are "acceptable", and that there will still be a queue afterwards.
How many times this will be done depends on the above.
Move to Supervised
Supervised
Once ~6 days have passed, and we are now assuming that the validators are performing well, Jsgenesis will do a runtime upgrade to the Supervised
stage, that effectively removes the transaction filter.
Supervised Phase
Overview
Duration:
unknown
Consensus:
PoS
Purpose:
Remove the transaction filter, thus opening for "normal" operations and governance.
Maintain
sudo
power for potential emergencies
Actors:
Jsgenesis (as
sudo
)Everyone
Filter: nothing except
bounty
a few calls in proposals and content directory
Purpose
Although "no" transactions will be blocked by the filter, the first 8 days of the Supervised
stage will still be rather limited.
New members can register and anyone can transfer tokens, but nothing interesting can happen before the council is set and Leads are hired. Together, they are required to "open" up:
proposals
the forum
content creation, storage and distribution
hiring of workers
etc.
Once election, the council can do whatever they want, but Jsgenesis will retain sudo
power for the time being.
Community Actions
Pretty much everything!
The "required" actions are listed below:
Elect a council
Establish working groups
Set budgets
Create openings
Hire Leads
Storage/content Leads enables content creation
Distributor Lead enables content distribution
Forum Lead enables the forum
Hire Workers
After a couple days, we should be in a place where everyone can participate by creating content, build, host infrastructure and earn a little $JOY before mainnet.
Jsgenesis Actions
The actions and transactions to be made by Jsgenesis can be found, in sequence, below.
Set the validatorCount
validatorCount
Although the council will, and shall, take over this role fairly soon, it will take at least 3 councils due to the constitutionality.
In the meantime, Jsgenesis have the option to increase or decrease the number based on the metrics listed for Thawn
.
Move to Liberated
Liberated
Although the exact timeline is not clear, on the Carthage
network Jsgenesis will make their final transaction with sudo
before the second council is elected. The only change will be to remove sudo
, thus giving full control to the council.
Hopefully, nothing else will be required.
Liberated Phase
Overview
Duration:
forever
Consensus:
PoS
Purpose:
Video platform DAO
Actors: Everyone
Filter: Same as prior
Last updated