aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.rs
blob: a4728a1bd9c372760d956b86485cfa97d1b4fd66 (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
// icaltool - a tool to get information out of ical/ics files.
// 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 <https://www.gnu.org/licenses/>.

use ical;
use chrono::{DateTime, TimeZone, Utc};
use std::fs::File;
use std::io::BufReader;

#[derive(Default)]
struct Event {
    start: Option<DateTime<Utc>>,
    end: Option<DateTime<Utc>>,
    summary: String,
}

fn parse_datetime(datetime: Option<String>) -> Option<DateTime<Utc>> {
    if let Some(mut dt) = datetime {
        if dt.is_empty() {
            return None;
        }

        if !dt.contains("T") {
            dt += "T000000";
        }
        Utc.datetime_from_str(&dt, "%Y%m%dT%H%M%S").ok()
    }
    else {
        None
    }
}

fn main() {
    let buf = BufReader::new(File::open("test.ics").unwrap());
    let calendars: Vec<_> = ical::IcalParser::new(buf)
        .filter_map(|c| c.ok())
        .collect();
    println!("Found {} calendard in file...", calendars.len());

    for c in calendars {
        for e in c.events {
            let mut ev = Event::default();

            for p in e.properties {
                match p.name.as_ref() {
                    "DTSTART" => ev.start = parse_datetime(p.value),
                    "DTEND"   => ev.end = parse_datetime(p.value),
                    "SUMMARY" => ev.summary = p.value.unwrap_or("".to_string()),
                    _ => (),
                }
            }

            println!("---> {} - {}: {}",
                ev.start.unwrap_or(Utc::now()),
                ev.end.unwrap_or(Utc::now()),
                ev.summary);
        }
    }
}