Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/bluzzi/todoist-googlecalendar

Integration between Google Calendar and Todoist.
https://github.com/bluzzi/todoist-googlecalendar

google-calendar sync todoist

Last synced: 3 months ago
JSON representation

Integration between Google Calendar and Todoist.

Awesome Lists containing this project

README

        

# Todoist sync Google Calendar
An integration between Todoist and Google Calendar retrieves events for the next 7 days from Google Calendar and creates a synchronized copy on Todoist.

It is possible to synchronize multiple Google accounts with Todoist, and for each of them, the title, description, date, duration, and meeting links of the events are synchronized. Additionally, the email associated with the Google account is added as a label on the Todoist task.

Context: I primarily use Todoist to manage my daily tasks, but I'm required to use Google Calendar for work meetings. Having to use a second tool alongside Todoist isn't practical, and Todoist's default integration doesn't provide all the necessary information from Google Calendar: the meeting link and event description. That's why I created this integration.

## Setup
You need to configure [OAuth 2.0 and Consent Screen](https://support.google.com/cloud/answer/6158849) from the Google Cloud Platform Console.

For deployment, you'll need a server to deploy a NodeJS application containing a web server and a CRON, as well as a PostgreSQL database. I recommend the use of my template Railway, which enables one-click deployment.

[![Deploy on Railway](https://railway.app/button.svg)](https://railway.app/template/AP1rpk?referralCode=J6p1cI)

You'll need to set the following environment variables (if you're using your own machine, you can define them in an `.env` file at the root of the project):
```sh
# The webserver port (default 3000):
PORT=3000

# The CRON string (default "* * * * *" every minute):
CRON="* * * * *"

# Google OAuth 2.0 Client ID and secret:
GOOGLE_CLIENT_ID="Google Client ID"
GOOGLE_CLIENT_SECRET="Google Client Secret"

# Todoist API token:
TODOIST_TOKEN="Todoist Token"

# PostgreSQL database URL:
POSTGRES_URL="Postgres URL"

# Ignored events (comma-separated list of event names):
IGNORE_EVENTS="Absent au bureau,Running"
```

## Contributing
Contributions are welcome! Feel free to submit issues or pull requests.

## License
This project is licensed under the [MIT License](./LICENSE).