1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
use crate::error;
use crate::params::{DatabaseParams, SharedParams};
use crate::CliConfiguration;
use sc_service::DatabaseConfig;
use std::fmt::Debug;
use std::fs;
use std::io::{self, Write};
use structopt::StructOpt;
#[derive(Debug, StructOpt)]
pub struct PurgeChainCmd {
	
	#[structopt(short = "y")]
	pub yes: bool,
	#[allow(missing_docs)]
	#[structopt(flatten)]
	pub shared_params: SharedParams,
	#[allow(missing_docs)]
	#[structopt(flatten)]
	pub database_params: DatabaseParams,
}
impl PurgeChainCmd {
	
	pub fn run(&self, database_config: DatabaseConfig) -> error::Result<()> {
		let db_path = database_config.path()
			.ok_or_else(||
				error::Error::Input("Cannot purge custom database implementation".into())
		)?;
		if !self.yes {
			print!("Are you sure to remove {:?}? [y/N]: ", &db_path);
			io::stdout().flush().expect("failed to flush stdout");
			let mut input = String::new();
			io::stdin().read_line(&mut input)?;
			let input = input.trim();
			match input.chars().nth(0) {
				Some('y') | Some('Y') => {},
				_ => {
					println!("Aborted");
					return Ok(());
				},
			}
		}
		match fs::remove_dir_all(&db_path) {
			Ok(_) => {
				println!("{:?} removed.", &db_path);
				Ok(())
			},
			Err(ref err) if err.kind() == io::ErrorKind::NotFound => {
				eprintln!("{:?} did not exist.", &db_path);
				Ok(())
			},
			Err(err) => Result::Err(err.into()),
		}
	}
}
impl CliConfiguration for PurgeChainCmd {
	fn shared_params(&self) -> &SharedParams {
		&self.shared_params
	}
	fn database_params(&self) -> Option<&DatabaseParams> {
		Some(&self.database_params)
	}
}