There are three steps in user state transition (see user state transition proof), and they should be performed in order.
Start user state transition
/**
* @dev User submit a start user state transition proof
* publicSignals[0] = [ blindedUserState ]
* publicSignals[1] = [ blindedHashChain ]
* publicSignals[2] = [ globalStateTree ]
* @param publicSignals The public signals of the start user state transition proof
* @param proof The The proof of the start user state transition proof
*/
function startUserStateTransition(
uint256[] memory publicSignals,
uint256[8] memory proof
) external
After start user state transition proof event is emitted, the proof will be assign a proof index, which will be attached to updateUserStateRoot function.
The proof index can be queried by proof hash. And the proof hash can be computed by
The proofIndexRecords is the proof indexes of all startTransitionProof and processAttestationsProof that are submitted sequentially. See Start user state transition and Process attestations.