diff options
author | lonkaars <loek@pipeframe.xyz> | 2022-03-14 20:03:41 +0100 |
---|---|---|
committer | lonkaars <loek@pipeframe.xyz> | 2022-03-14 20:03:41 +0100 |
commit | 072a0971c29037bf26e1a7092b93ca28f6c4f2bb (patch) | |
tree | d6f29726e5c1563edea2bad60c6b9d61d23f9fc6 | |
parent | 63e70e3e4d023ab0ebd07599e6f84c57d6dfa00f (diff) |
[wip] added task generation
-rwxr-xr-x | main.py | 59 |
1 files changed, 41 insertions, 18 deletions
@@ -1,8 +1,10 @@ #!/bin/python3 from libdecsync import Decsync -from icalendar import Calendar +from icalendar import Calendar, Event from taggen import tag_gen +from datetime import datetime +from uuid import uuid4 import time import json import os @@ -11,28 +13,49 @@ import requests APPID = "brightspace-decsync" def load_config(): - config_file = open("./config.json", "r") - config_json = json.loads(config_file.read()) - config_json["decsync"]["dir"] = os.path.expanduser(config_json["decsync"]["dir"]) - return config_json + config_file = open("./config.json", "r") + config_json = json.loads(config_file.read()) + config_json["decsync"]["dir"] = os.path.expanduser(config_json["decsync"]["dir"]) + return config_json def get_brightspace_events(config): - request = requests.get(config["brightspace"]) - cal = Calendar.from_ical(request.text) - return list(cal.walk('vevent')) + request = requests.get(config["brightspace"]) + cal = Calendar.from_ical(request.text) + return list(cal.walk('vevent')) + +def create_task_ical(cal_event): + cal = Calendar() + event = Event() + cal.add('prodid', APPID) + cal.add('version', '2.0') + + event.add("priority", 9) + event.add("status", "needs-action") + + tag = tag_gen(cal_event.get('location')) + if tag: event.add("categories", tag) + + event.add("created", datetime.now()) + + event.add("dtstamp", str(cal_event.get('dtstart'), 'utf-8')) + event.add("uid", uuid4()) + + event.add("summary", str(cal_event.get('summary'), 'utf-8')) + event.add("description", str(cal_event.get('description'), 'utf-8')) + cal.add_component(event) + return cal.to_ical() def task_handler(config, ds, event): - epoch = time.time() - timestamp = f"{int(epoch)}{int((epoch % 1) * 10 ** 9)}" - print(timestamp) - ds.set_entry(["resources", timestamp], None, "ical content here") + epoch = time.time() + timestamp = f"{int(epoch)}{int((epoch % 1) * 10 ** 9)}" + ds.set_entry(["resources", timestamp], None, create_task_ical(event)) def main(): - config = load_config() - ds = Decsync(config["decsync"]["dir"], "tasks", config["decsync"]["collection"], APPID) - events = get_brightspace_events(config) - for event in events: - task_handler(config, ds, event) + config = load_config() + ds = Decsync(config["decsync"]["dir"], "tasks", config["decsync"]["collection"], APPID) + events = get_brightspace_events(config) + for event in events: + task_handler(config, ds, event) if __name__ == "__main__": - main() + main() |