From 93de6fde62c1302f61236987e61d141a1d00e21a Mon Sep 17 00:00:00 2001 From: zzz Date: Wed, 21 Dec 2022 14:58:32 +0800 Subject: [PATCH] resolves #999 --- .../core/parentchain/light-client/src/io.rs | 10 +++ tee-worker/service/src/main.rs | 71 +++++++++++++++---- tee-worker/service/src/sidechain_setup.rs | 11 ++- 3 files changed, 74 insertions(+), 18 deletions(-) diff --git a/tee-worker/core/parentchain/light-client/src/io.rs b/tee-worker/core/parentchain/light-client/src/io.rs index c0e5d06642..51dfda2fb1 100644 --- a/tee-worker/core/parentchain/light-client/src/io.rs +++ b/tee-worker/core/parentchain/light-client/src/io.rs @@ -80,6 +80,11 @@ where if genesis_hash == params.genesis_header.hash() { validator.set_state(validation_state); + // The init_parachain_validator function clear the state every time, + // so we should write the state again. + LightClientStateSeal::>::seal_to_static_file( + validator.get_state(), + )?; info!("Found already initialized light client with Genesis Hash: {:?}", genesis_hash); } info!("light client state: {:?}", validator); @@ -107,6 +112,11 @@ where if genesis_hash == params.genesis_header.hash() { validator.set_state(validation_state); + // The init_parachain_validator function clear the state every time, + // so we should write the state again. + LightClientStateSeal::>::seal_to_static_file( + validator.get_state(), + )?; info!("Found already initialized light client with Genesis Hash: {:?}", genesis_hash); } info!("light client state: {:?}", validator); diff --git a/tee-worker/service/src/main.rs b/tee-worker/service/src/main.rs index 4f4d4cb891..2be8430485 100644 --- a/tee-worker/service/src/main.rs +++ b/tee-worker/service/src/main.rs @@ -85,8 +85,11 @@ use std::{ thread, time::Duration, }; -use substrate_api_client::{utils::FromHexString, Header as HeaderTrait, XtStatus}; -use teerex_primitives::ShardIdentifier; +use substrate_api_client::{ + utils::{storage_key, FromHexString}, + Header as HeaderTrait, StorageKey, XtStatus, +}; +use teerex_primitives::{Enclave as TeerexEnclave, ShardIdentifier}; extern crate config as rs_config; mod account_funding; @@ -506,15 +509,59 @@ fn start_worker( return } - println!("[>] Register the enclave (send the extrinsic)"); - let register_enclave_xt_hash = node_api.send_extrinsic(xthex, XtStatus::Finalized).unwrap(); - println!("[<] Extrinsic got finalized. Hash: {:?}\n", register_enclave_xt_hash); - - let register_enclave_xt_header = - node_api.get_header(register_enclave_xt_hash).unwrap().unwrap(); + let mut register_enclave_xt_header: Option
= None; + let mut we_are_primary_validateer: bool = false; + + // litentry, Check if the enclave is already registered + match node_api.get_keys(storage_key("Teerex", "EnclaveRegistry"), None) { + Ok(Some(keys)) => { + let trusted_url = trusted_url.as_bytes().to_vec(); + let mrenclave = mrenclave.to_vec(); + let mut found = false; + for key in keys { + let key = if key.starts_with("0x") { + let bytes = &key.as_bytes()[b"0x".len()..]; + hex::decode(bytes).unwrap() + } else { + hex::decode(key.as_bytes()).unwrap() + }; + match node_api.get_storage_by_key_hash::>>( + StorageKey(key.clone()), + None, + ) { + Ok(Some(value)) => { + if value.mr_enclave.to_vec() == mrenclave && value.url == trusted_url { + // After calling the perform_ra function, the nonce will be incremented by 1, + // so enclave is already registered, we should reset the nonce_cache + enclave + .set_nonce(nonce) + .expect("Could not set nonce of enclave. Returning here..."); + found = true; + info!("fond enclave: {:?}", value); + break + } + }, + Ok(None) => { + warn!("not found from key: {:?}", key); + }, + Err(_) => {}, + } + } + if !found { + println!("[>] Register the enclave (send the extrinsic)"); + let register_enclave_xt_hash = + node_api.send_extrinsic(xthex, XtStatus::Finalized).unwrap(); + println!("[<] Extrinsic got finalized. Hash: {:?}\n", register_enclave_xt_hash); + register_enclave_xt_header = node_api.get_header(register_enclave_xt_hash).unwrap(); + } + }, + _ => panic!("unknown error"), + } - let we_are_primary_validateer = - we_are_primary_validateer(&node_api, ®ister_enclave_xt_header).unwrap(); + if let Some(register_enclave_xt_header) = register_enclave_xt_header.clone() { + we_are_primary_validateer = + check_we_are_primary_validateer(&node_api, ®ister_enclave_xt_header).unwrap(); + } if we_are_primary_validateer { println!("[+] We are the primary validateer"); @@ -555,7 +602,7 @@ fn start_worker( if WorkerModeProvider::worker_mode() == WorkerMode::Sidechain { last_synced_header = sidechain_init_block_production( enclave, - ®ister_enclave_xt_header, + register_enclave_xt_header, we_are_primary_validateer, parentchain_handler.clone(), sidechain_storage, @@ -805,7 +852,7 @@ fn enclave_account(enclave_api: &E) -> AccountId32 { } /// Checks if we are the first validateer to register on the parentchain. -fn we_are_primary_validateer( +fn check_we_are_primary_validateer( node_api: &ParentchainApi, register_enclave_xt_header: &Header, ) -> Result { diff --git a/tee-worker/service/src/sidechain_setup.rs b/tee-worker/service/src/sidechain_setup.rs index 9827cd53a2..99c10e385f 100644 --- a/tee-worker/service/src/sidechain_setup.rs +++ b/tee-worker/service/src/sidechain_setup.rs @@ -56,7 +56,7 @@ pub(crate) fn sidechain_start_untrusted_rpc_server( pub(crate) fn sidechain_init_block_production( enclave: Arc, - register_enclave_xt_header: &Header, + register_enclave_xt_header: Option
, we_are_primary_validateer: bool, parentchain_handler: Arc, sidechain_storage: Arc, @@ -74,11 +74,10 @@ where info!( "We're the first validateer to be registered, syncing parentchain blocks until the one we have registered ourselves on." ); - updated_header = - Some(parentchain_handler.sync_and_import_parentchain_until( - last_synced_header, - register_enclave_xt_header, - )?); + updated_header = Some(parentchain_handler.sync_and_import_parentchain_until( + last_synced_header, + ®ister_enclave_xt_header.unwrap(), + )?); } // ------------------------------------------------------------------------