mirror of
https://github.com/0glabs/0g-storage-node.git
synced 2025-01-24 05:55:17 +00:00
ef82f64393
* Implement Pruner. * Put pruner in a crate. * Fix clippy. * Add rpc zgs_getShardConfig. * Fix. * Increase wait time. * Add pruner_test and use max_num_chunks instead of size_limit. * Add back shard config and fix test. * fix: serde format * Remove unneeded PORA_CHUNK_SIZE. * Fix tests. --------- Co-authored-by: MiniFrenchBread <103425574+MiniFrenchBread@users.noreply.github.com>
72 lines
1.9 KiB
Rust
72 lines
1.9 KiB
Rust
use crate::miner_id::check_and_request_miner_id;
|
|
use crate::sealer::Sealer;
|
|
use crate::submitter::Submitter;
|
|
use crate::{config::MinerConfig, mine::PoraService, watcher::MineContextWatcher};
|
|
use network::NetworkMessage;
|
|
use std::sync::Arc;
|
|
use storage::config::ShardConfig;
|
|
use storage::log_store::Store;
|
|
use tokio::sync::mpsc;
|
|
use tokio::sync::{broadcast, RwLock};
|
|
|
|
#[derive(Clone, Debug)]
|
|
pub enum MinerMessage {
|
|
/// Enable / Disable Mining
|
|
ToggleMining(bool),
|
|
|
|
/// Change mining range
|
|
SetStartPosition(Option<u64>),
|
|
SetEndPosition(Option<u64>),
|
|
|
|
/// Change shard config
|
|
SetShardConfig(ShardConfig),
|
|
}
|
|
|
|
pub struct MineService;
|
|
|
|
impl MineService {
|
|
pub async fn spawn(
|
|
executor: task_executor::TaskExecutor,
|
|
_network_send: mpsc::UnboundedSender<NetworkMessage>,
|
|
config: MinerConfig,
|
|
store: Arc<RwLock<dyn Store>>,
|
|
) -> Result<broadcast::Sender<MinerMessage>, String> {
|
|
let provider = Arc::new(config.make_provider().await?);
|
|
|
|
let (msg_send, msg_recv) = broadcast::channel(1024);
|
|
|
|
let miner_id = check_and_request_miner_id(&config, &store, &provider).await?;
|
|
debug!("miner id setting complete.");
|
|
|
|
let mine_context_receiver = MineContextWatcher::spawn(
|
|
executor.clone(),
|
|
msg_recv.resubscribe(),
|
|
provider.clone(),
|
|
&config,
|
|
);
|
|
|
|
let mine_answer_receiver = PoraService::spawn(
|
|
executor.clone(),
|
|
msg_recv.resubscribe(),
|
|
mine_context_receiver,
|
|
Arc::new(store.clone()),
|
|
&config,
|
|
miner_id,
|
|
);
|
|
|
|
Submitter::spawn(
|
|
executor.clone(),
|
|
mine_answer_receiver,
|
|
provider.clone(),
|
|
store.clone(),
|
|
&config,
|
|
);
|
|
|
|
Sealer::spawn(executor, provider, store, &config, miner_id);
|
|
|
|
debug!("Starting miner service");
|
|
|
|
Ok(msg_send)
|
|
}
|
|
}
|