Command-line utility which exports all of a user's Google Calendars to iCal/ICS format for backup (or portability)
Project description
Overview
Gcalvault is a command-line utility which exports all of a user's Google Calendars to iCal/ICS format for backup (or portability).
Features:
- Automatically discovers all calendars visible the user
- Downloads them in iCal/ICS format and saves them to disk for archival
- Optionally manages version history for each calendar in an on-disk "vault" (a git repo under the covers)
- Can be run via Docker image (multi-arch) or installed directly as a Python package with command-line interface
How it works
- Uses Google's Identity Provider to authenticate (via OAuth2/OIDC)
- Uses Google's Calendar API to discover a user's calendars
- Uses Google's CalDAV endpoints to download iCal/ICS calendars
- Uses GitPython to manage local git repo for version history under the covers
Usage
Some example commands...
Sync all calendars for foo.bar@gmail.com user:
gcalvault sync foo.bar@gmail.com
Sync one specific calendar:
gcalvault sync foo.bar@gmail.com family123@group.calendar.google.com
Sync only "writable" calendars:
gcalvault sync foo.bar@gmail.com --ignore-role reader
Simply export calendars, do not save version history:
gcalvault sync foo.bar@gmail.com --export-only
See the CLI help for full usage and other notes.
Requirements
- Python 3.9+
Installation
Via PyPi
pip install gcalvault
gcalvault sync foo.bar@gmail.com
Via Docker
docker run -it --rm \
-v ${HOME}/.gcalvault:/root/.gcalvault \
-v ${PWD}/gcalvault:/root/gcalvault \
rtomac/gcalvault sync foo.bar@gmail.com
OAuth2 authentication
The CLI initiates an OAuth2 authentication the first time it is run (interactive), and then uses refresh tokens for subsequent runs (headless).
When you use Gcalvault in its default configuration, you are initiating the OAuth2 flow with Google using Gcalvault's client ID. There is nothing inherently insecure about this, since the application is running locally and therefore only you will have access to the data it reads from Google.
That said, it is recommended to create your own client ID through the Google API Console, since the shared client ID may be used by others and subject to limits which may cause unpredictable failures.
rclone has a good write-up on making your own client ID.
You can provide your client ID and secret to gcalvault as follows:
gcalvault sync foo.bar@gmail.com --client-id my_client_id --client-secret my_client_secret
If you are providing your own Google OAuth2 client, you will need to ensure the following APIs and OAuth2 scopes are enabled for the project/client in GCP.
Google APIs:
- Google Calendar API:
calendar-json.googleapis.com - CalDAV API:
caldav.googleapis.com
OAuth2 scopes:
openidhttps://www.googleapis.com/auth/userinfo.emailhttps://www.googleapis.com/auth/calendar.readonly
Development
Source repository:
http://github.com/rtomac/gcalvault
Install dependencies and run locally
pip install virtualenv
make devenv
. ./.devenv/bin/activate
gcalvault --help
Run tests
pytest
Build distribution
make dist
Build Docker image
make docker-build
Run via Docker image
make docker-run user=foo.bar@gmail.com
Release to PyPi and Docker Hub
make release
See targets and variables in Makefile for more options.
License
MIT License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file gcalvault-2.0.2.tar.gz.
File metadata
- Download URL: gcalvault-2.0.2.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0687d1038c45bd40c15ef98b188642ab3d265ab551fc44dcc52cd285d83f8ea9
|
|
| MD5 |
50ac2e7faaede2735624f5a4b78e6dee
|
|
| BLAKE2b-256 |
f77783eef40da3c6b89962a3a8c2ea6993de50b590477606d6299b568639fa78
|