aboutsummaryrefslogtreecommitdiffstats
path: root/src/bin/zot/zot/network_stream.rs
blob: a5a7142f4a3b8a0421b7a59e08de0ca76dc99061 (plain) (blame)
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
95
96
97
98
99
100
101
102
103
104
/* Example Zot API command line utility, part of zotapi.
 * Copyright (C) 2018 Harald Eilertsen <haraldei@anduin.net>
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

use zotapi;

use serde_json;
use std::iter::Iterator;

pub async fn fetch(client: &zotapi::Client, raw: bool) {
    match zotapi::network_stream().fetch(&client).await {
        Ok(payload) => {
            if raw {
                println!("{}", payload);
            } else {
                list(&payload);
            }
        }
        Err(e) => {
            println!("Error getting channel stream: {:?}", e);
        }
    }
}

fn list(payload: &str) {
    match serde_json::from_str(&payload) {
        Ok(serde_json::Value::Array(v)) => {
            for item in v.into_iter() {
                print_item(&item);
                println!("-----");
            }
        }
        Ok(_) => println!("Wrong type returned, expected an array."),
        Err(e) => {
            println!("Error: {}", e);
        }
    }
}

fn get_str(v: &serde_json::Value) -> &str {
    v.as_str().unwrap_or("")
}

fn get_verb(item: &serde_json::Value) -> &str {
    match get_str(&item["verb"]).split("/").last() {
        Some("post") => "posted",
        Some("like") => "liked",
        Some("share") => "shared",
        Some("dislike") => "disliked",
        _ => "unknown verb",
    }
}

fn get_object_type(item: &serde_json::Value) -> &str {
    get_str(&item["object_type"])
        .split("/")
        .last()
        .unwrap_or("unknown object")
}

fn get_tags(item: &serde_json::Value) -> String {
    match item["tags"] {
        serde_json::Value::Array(ref v) => v
            .iter()
            .map(|t| {
                let prefix = match get_str(&t["type"]) {
                    "hashtag" => "#",
                    "forum" => "!",
                    "mention" => "@",
                    _ => "",
                };
                format!("{}{}", prefix, get_str(&t["tag"]))
            })
            .collect::<Vec<_>>()
            .join(", "),
        serde_json::Value::Null => String::new(),
        _ => String::from("invalid tags, expected array..."),
    }
}

fn print_item(item: &serde_json::Value) {
    let author = &item["author"];
    print!("{} ", get_str(&item["created"]));
    print!("{} ", get_str(&author["name"]));
    println!("{} a {}", get_verb(&item), get_object_type(&item));
    println!("URL:   {}", get_str(&author["url"]));
    println!("Proto: {}", get_str(&author["network"]));
    println!("Title: {}", get_str(&item["title"]));
    println!("Tags : {}", get_tags(&item));
    println!("Message:\n{}", get_str(&item["body"]));
}