summaryrefslogtreecommitdiffstats
path: root/ipfs-cli/src/command/block.rs
diff options
context:
space:
mode:
Diffstat (limited to 'ipfs-cli/src/command/block.rs')
-rw-r--r--ipfs-cli/src/command/block.rs128
1 files changed, 69 insertions, 59 deletions
diff --git a/ipfs-cli/src/command/block.rs b/ipfs-cli/src/command/block.rs
index 7cccb5b..b4ca887 100644
--- a/ipfs-cli/src/command/block.rs
+++ b/ipfs-cli/src/command/block.rs
@@ -6,77 +6,87 @@
// 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 clap::App;
+use command::{verify_file, CliCommand, EXPECTED_FILE};
+use futures::{Future, Stream};
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 struct Command;
+
+impl CliCommand for Command {
+ const NAME: &'static str = "block";
-pub fn handle(core: &mut Core, client: &IpfsClient, args: &ArgMatches) {
- match args.subcommand() {
- ("get", Some(args)) => {
+ 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")
+ )
+ )
+ }
+
+ handle!(
+ client;
+ ("get", 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)) => {
+ client
+ .block_get(key)
+ .for_each(|chunk| io::stdout().write_all(&chunk).map_err(From::from))
+ },
+ ("put", 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)) => {
+ client
+ .block_put(file)
+ .map(|block| {
+ println!();
+ println!(" key : {}", block.key);
+ println!(" size : {}", block.size);
+ println!();
+ })
+ },
+ ("rm", 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)) => {
+ client
+ .block_rm(key)
+ .map(|rm| {
+ println!();
+ println!(" hash : {}", rm.hash);
+ if let Some(error) = rm.error {
+ println!(" error : {}", error);
+ }
+ println!();
+ })
+ },
+ ("stat", 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!();
+ client
+ .block_stat(key)
+ .map(|stat| {
+ println!();
+ println!(" key : {}", stat.key);
+ println!(" size : {}", stat.size);
+ println!();
+ })
}
- _ => unreachable!(),
- }
+ );
}