Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jakubvalenta/automatic-diary

Create one timeline from various digital sources
https://github.com/jakubvalenta/automatic-diary

calendar csv diary journal log productivity

Last synced: about 1 month ago
JSON representation

Create one timeline from various digital sources

Awesome Lists containing this project

README

        

# Automatic Diary

Automatic Diary is a script that creates one timeline from various digital
sources describing your life.

![Automatic Diary screenshot](./automatic_diary_screenshot.png)

_On the screenshot above, you can see: calendar events (blue), completed todo
list items (yellow), software development work (gray), sport activity (green),
and films watched (red)._

## Why

Automatic Diary can be useful to those who:

(a) have bad memory,\
(b) want to remember what they did,\
(c) but don't have the time to write a real diary.

## What is collected

- [X] Calendar events (via CalDAV service and iCalendar file reading)
- [X] Emails sent and received (via Maildir reading)
- [X] Sport activity (via spreadsheet parsing)
- [X] Facebook and Twitter posts (via Facebook/Twitter data archive parsing)
- [X] Software development work (via Git repository log)
- [X] Completed todo list items (via todo.txt parsing)
- [X] Films watched (via ČSFD website parsing and Trakt.tv)
- [X] Custom diary notes (via plain-text and Org-mode files parsing)

## What is not collected

Automatic Diary could be extended to collect also the following data but right
now it is considered low priority:

- [ ] Custom notes and ideas
- [ ] Articles and blog posts written
- [ ] Phone calls and text messages (SMS)
- [ ] Social media private messages and messaging apps
- [ ] Browser history
- [ ] Music listened (via Last.fm)
- [ ] OpenStreetMap contributions
- [ ] Money transfers
- [ ] News headlines
- [ ] Weather

## Installation

### Mac

``` shell
$ brew install python
$ pip install poetry
$ pip install --user --upgrade .
```

### Arch Linux

``` shell
# pacman -S python-poetry libsecret
$ pip install --user --upgrade .
```

### Other systems

Install these dependencies manually:

- Python >= 3.9
- poetry
- libsecret (Linux keyring) -- required by the `caldav` provider

Then run:

``` shell
$ pip install --user --upgrade .
```

## Configuration

Before you run Automatic Diary, you need to configure all the providers (sources
from which the data for your timeline will be read). The following providers are
supported:

- [caldav](#caldav)
- [csfd](#csfd)
- [csv](#csv)
- [facebook](#facebook)
- [git](#git)
- [icalendar](#icalendar)
- [maildir](#maildir)
- [orgmode](#orgmode)
- [orgmodelist](#orgmodelist)
- [todotxt](#todotxt)
- [trakt](#trakt)
- [twitter](#twitter)
- [txt](#txt)

All providers are configured using a single `config.json` file. Use
[config-sample.json](./config-sample.json) as a template for your own
configuration.

### caldav

- Input: CalDAV server

- Output: Names and locations of calendar events

- Configuration:

``` json
{
"url": "",
"username": "",
"password_key": "",
"password_val": "",
"cache_dir": ""
}
```

### csfd

- Input: User profile on [ČSFD](https://www.csfd.cz/) (film database website, something
like IMDB)

- Output: Titles of films rated

- Configuration:

``` json
{
"profile_url": "",
"cache_dir": ""
}
```

### csv

- Input: CSV spreadsheet (.csv) file

- Output: Rows formatted using a template

- Configuration

``` json
{
"path": "",
"date_source": "{{}}",
"date_format": "",
"text_source": ""
}
```

### facebook

- Input: Downloaded Facebook archive

- Output: Texts of statuses

- Configuration

``` json
{
"path": "",
"username": ""
}
```

### git

- Input: Directory with checked-out Git repositories and an author name

- Output: Commit messages by the author from all repositories

- Configuration

``` json
"config": {
"base_path": "",
"author": "",
"cache_dir": "",,
"max_depth": ""
}
```

### icalendar

- Input: Calendar events stored offline in iCalendar (.ics) files

- Output: Names and locations of calendar events

- Configuration:

``` json
{
"paths": [
"",
...
]
}
```

Not that events from all the listed .ics files will be merged -- duplicate
events removed.

### maildir

- Input: Emails stored offline in the Maildir format

- Output: Subjects of emails

- Configuration:

``` json
{
"received_pathname": "",
"sent_pathname": ""
}
```

### orgmode

- Input: Emacs Org-mode (.org) file in format:

``` org
* <2019-01-17 Thu>

Lorem ipsum
foo.

bar

* <2019-01-18 Fri>

spam spam
...
```

- Output: Example:

``` csv
2019-01-17,Lorem ipsum foo.
2019-01-17,bar
2019-01-18,spam spam
```

- Configuration:

``` json
{
"path": ""
}
```

### orgmodelist

- Input: Emacs Org-mode (.org) file in format:

- Lorem ipsum foo. <2019-01-17 Thu>
- bar <2019-01-18 Fri 11:30>
...

- Output: Example:

``` csv
2019-01-17,Lorem ipsum foo.
2019-01-18T11:00:00+02:00,bar
```

- Configuration:

``` json
{
"path": ""
}
```

### todotxt

- Input: Todo.txt completed tasks file (done.txt)

- Output: Texts of completed tasks

- Configuration

``` json
{
"path": ""
}
```

### trakt

- Input: [Manually create an application within Trakt.tv](https://trakt.tv/oauth/applications/new). Manual login with OAuth when running this provider. A recommended `Redirect URI` is `urn:ietf:wg:oauth:2.0:oob`

- Output: Texts of watched films and shows

- Configuration

``` json
{
"key_id": "",
"key_secret": "",
"app_id": ""
}
```

### twitter

- Input: Downloaded Twitter archive

- Output: Texts of tweets

- Configuration

``` json
{
"path": ""
}
```

### txt

- Input: Plain text (.txt) file in format:

```
2015-12-02 St
Some
Text
Lorem
Ipsum
Hierarchy
Spam
2015-12-03 Čt
Foobar
...
```

- Output: Example:

``` csv
2015-12-02,Some
2015-12-02,Text
2015-12-02,Lorem: Ipsum: Hierarchy
2015-12-02,Lorem: Ipsum: Spam
2015-12-03,Foobar
```

- Configuration

``` json
{
"path": ""
}
```

## Usage

### Generating CSV

The basic output of Automatic Diary is a CSV file. Generate it by running:

``` shell
$ automatic-diary
```

Example:

``` shell
$ automatic-diary ~/.config/automatic-diary/config.json ~/Desktop/automatic_diary.csv
```

The CSV output is in format:

``` csv
,,,
```

Example CSV output:

``` csv
2019-01-23T15:31:54-08:00,git,human-activities,model: Log exceptions while scanning
2019-01-24T09:00:00+01:00,caldav,https://dav.mailbox.org/caldav/da39a3ee5e6b,DHL Packstation
2019-01-25,todotxt,done.txt,Opravit Ondrovi kolo
```

See the help for all command line options:

``` shell
$ automatic-diary --help
```

### Visualization

The output CSV file can also be rendered as an HTML document which looks kind of
like a calendar. See the screenshot above. Generate this HTML document by
running:

``` shell
$ automatic-diary-visualize
```

Example:

``` shell
$ automatic-diary-visualize ~/Desktop/automatic_diary.csv ~/Desktop/automatic_diary.html
```

By default, this command visualizes only those CSV items that happened within
the latest year in the CSV file. To visualize **all items**, use the `-a` /
`--all-years` option. Then pass a directory path as ``
(instead of passing a file path). Example:

``` shell
$ automatic-diary-visualize --all-years ~/Desktop/automatic_diary.csv ~/Desktop/automatic_diary
```

The result will be a directory with an HTML document for each year:

```
automatic_diary
├── 2022.html
├── 2023.html
└── 2024.html
```

For **custom styling** of the HTML document, you can pass an additional CSS file
using the `-c` / `--css-url` option. The passed CSS URL must be absolute or
relative to the output path. Example:

``` shell
$ automatic-diary-visualize --css-url ./my_stylesheet.css ~/Desktop/automatic_diary.csv ~/Desktop/automatic_diary.html
```

In your file, you can use for example the `data-subprovider` selector. Example:

``` css
.csv[data-subprovider="running.csv"] {
color: #008080;
}
```

You can also use the `-t` / `--tags-file` option to add **additional CSS
classes** to the diary items based on provided regexes. For example when you
create the following tags JSON file:

``` json
{
"^Sport: ": "sport",
"^Idea: ": "idea",
}
```

And pass it to the command like this:

``` shell
$ automatic-diary-visualize --css-url ./my_stylesheet.css --tags-file ./my_tags.json ~/Desktop/automatic_diary.csv ~/Desktop/automatic_diary.html
```

Then the command will add a CSS class `tag-sport` to each diary item that starts
with "Sport: " and a CSS class `tag-idea` to each diary item that starts with
"Idea: ". Then you can use these classes in your custom CSS (see the `-c` /
`--css-url` option).

See the **help** for all command line options:

``` shell
$ automatic-diary-visualize --help
```

## Development

### Installation

``` shell
$ make setup
```

### Testing and linting

``` shell
$ make test
$ make lint
```

### Help

``` shell
$ make help
```

## Contributing

__Feel free to remix this project__ under the terms of the GNU General Public
License version 3 or later. See [COPYING](./COPYING) and [NOTICE](./NOTICE).