Skip to main content

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

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:

  • openid
  • https://www.googleapis.com/auth/userinfo.email
  • https://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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gcalvault-2.0.2.tar.gz (13.0 kB view details)

Uploaded Source

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

Hashes for gcalvault-2.0.2.tar.gz
Algorithm Hash digest
SHA256 0687d1038c45bd40c15ef98b188642ab3d265ab551fc44dcc52cd285d83f8ea9
MD5 50ac2e7faaede2735624f5a4b78e6dee
BLAKE2b-256 f77783eef40da3c6b89962a3a8c2ea6993de50b590477606d6299b568639fa78

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page