summaryrefslogtreecommitdiffstats
path: root/ipfs-cli/src/command/block.rs
blob: 09bc660673112f1f1a04401b2e40abe316e98b3e (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
75
76
77
78
79
80
81
82
83
84
85
// 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, ArgMatches};
use command::{verify_file, EXPECTED_API, EXPECTED_FILE};
use futures::stream::Stream;
use ipfs_api::IpfsClient;
use std::fs::File;
use std::io::{self, Write};
use tokio_core::reactor::Core;


pub fn signature<'a, 'b>() -> App<'a, 'b> {
    clap_app!(
        @subcommand block =>
            (@setting SubcommandRequiredElseHelp)
            (@subcommand get =>
                (about: "Get a raw IPFS block")
                (@arg KEY: +required "The base58 multihash of an existing block")
            )
            (@subcommand put =>
                (about: "Store a file as an IPFS block")
                (@arg INPUT: +required {verify_file} "The file to store as an IPFS block")
            )
            (@subcommand rm =>
                (about: "Removes an IPFS block")
                (@arg KEY: +required "The base58 multihash of a block to remove")
            )
            (@subcommand stat =>
                (about: "Get information about a raw IPFS block")
                (@arg KEY: +required "The base58 multihash of the block to retrieve")
            )
    )
}


pub fn handle(core: &mut Core, client: &IpfsClient, args: &ArgMatches) {
    match args.subcommand() {
        ("get", Some(args)) => {
            let key = args.value_of("KEY").unwrap();
            let req = client.block_get(key).for_each(|chunk| {
                io::stdout().write_all(&chunk).map_err(From::from)
            });

            core.run(req).expect(EXPECTED_API);
        }
        ("put", Some(args)) => {
            let path = args.value_of("INPUT").unwrap();
            let file = File::open(path).expect(EXPECTED_FILE);
            let block = core.run(client.block_put(file)).expect(EXPECTED_API);

            println!();
            println!("  key     : {}", block.key);
            println!("  size    : {}", block.size);
            println!();
        }
        ("rm", Some(args)) => {
            let key = args.value_of("KEY").unwrap();
            let rm = core.run(client.block_rm(key)).expect(EXPECTED_API);

            println!();
            println!("  hash    : {}", rm.hash);
            if let Some(error) = rm.error {
                println!("  error   : {}", error);
            }
            println!();
        }
        ("stat", Some(args)) => {
            let key = args.value_of("KEY").unwrap();
            let stat = core.run(client.block_stat(key)).expect(EXPECTED_API);

            println!();
            println!("  key     : {}", stat.key);
            println!("  size    : {}", stat.size);
            println!();
        }
        _ => unreachable!(),
    }

}