summaryrefslogtreecommitdiffstats
path: root/bin/domain/imag-mail/src/ui.rs
blob: 54a89b635264124b722d765b50d90c8f382e9da5 (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
86
87
88
89
90
91
92
93
94
//
// imag - the personal information management suite for the commandline
// Copyright (C) 2015-2019 Matthias Beyer <mail@beyermatthias.de> and contributors
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public
// License as published by the Free Software Foundation; version
// 2.1 of the License.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
// Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public
// License along with this library; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
//

use std::path::PathBuf;

use libimagstore::storeid::StoreId;
use libimagrt::runtime::IdPathProvider;
use libimagstore::storeid::IntoStoreId;
use libimagerror::trace::MapErrTrace;

use clap::{Arg, ArgMatches, App, SubCommand};

pub fn build_ui<'a>(app: App<'a, 'a>) -> App<'a, 'a> {
    app
        .subcommand(SubCommand::with_name("import-mail")
                    .about("Import a mail (create a reference to it) (Maildir)")
                    .version("0.1")
                    .arg(Arg::with_name("ignore-existing-ids")
                         .long("ignore-existing")
                         .short("I")
                         .takes_value(false)
                         .required(false)
                         .help("Ignore errors that might occur when store entries exist already"))

                    .arg(Arg::with_name("path")
                         .index(1)
                         .takes_value(true)
                         .multiple(true)
                         .required(true)
                         .help("Path to the mail file(s) to import")
                         .value_name("PATH"))
                    )

        .subcommand(SubCommand::with_name("list")
                    .about("List all stored references to mails")
                    .version("0.1")

                    .arg(Arg::with_name("list-read")
                         .long("read")
                         .short("r")
                         .takes_value(false)
                         .required(false)
                         .multiple(false)
                         .help("Print the textual content of the mail itself as well"))

                    .arg(Arg::with_name("list-id")
                         .index(1)
                         .takes_value(true)
                         .required(false)
                         .multiple(true)
                         .help("The ids of the mails to list information for"))

                    )

        .subcommand(SubCommand::with_name("mail-store")
                    .about("Operations on (subsets of) all mails")
                    .version("0.1")
                    .subcommand(SubCommand::with_name("update-refs")
                                .about("Create references based on Message-IDs for all loaded mails")
                                .version("0.1"))
                    // TODO: We really should be able to filter here.
                    )
}

pub struct PathProvider;
impl IdPathProvider for PathProvider {
    fn get_ids(matches: &ArgMatches) -> Vec<StoreId> {
        if matches.is_present("list-id") {
            matches.values_of("list-id")
                .unwrap()
                .map(|s| PathBuf::from(s).into_storeid().map_err_trace_exit_unwrap())
                .collect()
        } else {
            vec![]
        }
    }
}