summaryrefslogtreecommitdiffstats
path: root/ipfs-cli/src/command/diag.rs
blob: 7ce6c225af120331d35066b5b93671659423712d (plain)
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
// Copyright 2017 rust-ipfs-api Developers
//
// Licensed under the Apache License, Version 2.0, <LICENSE-APACHE or
// http://apache.org/licenses/LICENSE-2.0> or the MIT license <LICENSE-MIT or
// http://opensource.org/licenses/MIT>, at your option. This file may not be
// copied, modified, or distributed except according to those terms.
//

use clap::{App, Arg, ArgMatches, SubCommand};
use command::EXPECTED_API;
use ipfs_api::IpfsClient;
use tokio_core::reactor::Core;

pub fn signature<'a, 'b>() -> App<'a, 'b> {
    // The clap macro does not allow hyphenated command names,
    // so the `set-time` command has to be manually instantiated.
    //
    let set_time_command = SubCommand::with_name("set-time")
        .about("Set how long to keep inactive requests in the log")
        .arg(
            Arg::with_name("TIME")
                .required(true)
                .index(1)
                .help("Time to keep inactive requests in the log"),
        );

    clap_app!(
        @subcommand diag =>
            (@setting SubcommandRequiredElseHelp)
            (@subcommand cmds =>
                (@setting SubcommandRequiredElseHelp)
                (@subcommand clear =>
                    (about: "Clear inactive requests from the log")
                )
                (subcommand: set_time_command)
            )
            (@subcommand sys =>
                (about: "Print system diagnostic information")
            )
    )
}

pub fn handle(core: &mut Core, client: &IpfsClient, args: &ArgMatches) {
    match args.subcommand() {
        ("cmds", Some(args)) => match args.subcommand() {
            ("clear", _) => {
                core.run(client.diag_cmds_clear()).expect(EXPECTED_API);

                println!("");
                println!("  OK");
                println!("");
            }
            ("set-time", Some(args)) => {
                let time = args.value_of("TIME").unwrap();

                core.run(client.diag_cmds_set_time(&time))
                    .expect(EXPECTED_API);

                println!("");
                println!("  OK");
                println!("");
            }
            _ => unreachable!(),
        },
        ("sys", _) => {
            let sys = core.run(client.diag_sys()).expect(EXPECTED_API);

            println!();
            println!("  {}", sys);
            println!();
        }
        _ => unreachable!(),
    }
}