Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Integralist/Google-Home-GSuite-Calendar-Sync
Sync your G Suite Calendar to your personal Google account so you can access events via Google Home
https://github.com/Integralist/Google-Home-GSuite-Calendar-Sync
g-suite google google-home googlehome gsuite
Last synced: about 2 months ago
JSON representation
Sync your G Suite Calendar to your personal Google account so you can access events via Google Home
- Host: GitHub
- URL: https://github.com/Integralist/Google-Home-GSuite-Calendar-Sync
- Owner: Integralist
- License: mit
- Created: 2018-02-04T22:16:05.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2020-09-21T07:22:56.000Z (over 4 years ago)
- Last Synced: 2024-10-28T09:13:49.902Z (2 months ago)
- Topics: g-suite, google, google-home, googlehome, gsuite
- Language: JavaScript
- Size: 15.6 KB
- Stars: 44
- Watchers: 10
- Forks: 11
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Google Home: GSuite Calendar Sync
## Problem
Google Home doesn't support G Suite (Google's business version of Google Docs).
e.g. if you wanted Google Home to read out both your personal & work calendar events, it won't work.
Even if you were to share your G Suite calendar with your personal Google account, the Google Home will just ignore the G Suite calendar and only read out calendar events associated directly with your personal Google account.
### Solution
To solve this problem I'm utilising [Google Apps Script](https://script.google.com/intro) (executed via my G Suite account) to copy my G Suite calendar events to my personal Google account calendar (i.e. a standard @gmail calendar).
The full code can be found in the [`code.gs`](code.gs) file in this repo.
### Resources Needed
This script requires access to the following resources:
- Personal Google Calendar
- G Suite Email
- G Suite Spreadsheet## Step-by-Step
> Note: use the "[useful reference links](#useful-reference-links)" at the bottom of this README for more information.
1. Share your _personal_ Google calendar (i.e. the standard @gmail account associated with your Google Home) with your G Suite account + be sure to enable "Make changes to events" so your G Suite account can actually create new events in your personal calendar when necessary.
2. Copy the code inside the [`code.gs`](code.gs) file into a new [Google Apps Script](https://script.google.com/intro) project + be sure the new project is setup in your G Suite account.
3. Change all template references in the code (e.g. anything inside brackets `<...>`, such as `"`) to a real/working value.
4. Setup a "trigger" (in the project UI) for the script, e.g. I set mine to run on a timer (every 5 mins). This means if there is a change to an existing event, I'll know about it in 5 minutes time. It's not perfect, but then again, this is just a hack after all.
5. Run the script manually (_twice_!). The first time you'll need to modify the script (see "[creating the spreadsheet](#creating-the-spreadsheet)" below for details), the second time is because you'll need to authorize the script to access your personal/G Suite calendar/email/spreadsheet features. After the script is authorized it'll run automatically in future without any issues.
## Creating the spreadsheet
You can either manually create a spreadsheet (using the Google UI) or you can let the script do it for you. Either way, the script still needs authorization regardless, so you might as well let the script create the spreadsheet for you.
The script will create a spreadsheet with the following structure:
```
gsuite_event_id, personal_event_id, event_title, event_start
```If you're creating the spreadsheet yourself, then make sure you have one row with those columns created.
If you're relying on the script to create it for you, then modify the code as follows:
```diff
- if (false) { createSpreadsheet(companyName); return }
+ if (true) { createSpreadsheet(companyName); return }
```> Note: don't forget to change it back afterwards.
Once run, check the logs and you'll see the ID for the new spreadsheet that was created. Once you have that you can change the line of code back to being `if (false) ...` and then update the following line of code like so (as an example, just remember to use whatever ID value you have):
```diff
- var sheetID = ""
+ var sheetID = "1234567890"
```## Monitoring
You can monitor your script by going to [https://script.google.com/home/my](https://script.google.com/home/my) and selecting your project. You can also view the number of "executions", where it'll show you when _you_ (as the editor) manually ran the code vs the automated/time-based executions that were made.
## How does it work?
[Google Apps Script](https://script.google.com/home) (GAS) will execute the script on a timer based interval. The value can be in minutes, hours or days. When the script runs, GAS will look for a function called `myFunction` (annoyingly it seems you can't change this).
`myFunction`: acquires references to your personal and G Suite calendars, as well as tracking the G Suite events found for the current day. It then opens a tracking spreadsheet, which exists to help create a mapping between events that have already been setup in your personal calendar. If an existing id is found in the spreadsheet, the script will attempt to find out if the event has been updated (e.g. has the title or start time changed?) and if there has been a change it'll update the event in your personal calendar.
> Note: the script also sends creation/update notification emails to you
The script also tries to clean up the spreadsheet by deleting tracked events that have already passed. Otherwise, as we loop over the spreadsheet looking for matching events, we would find that (as time goes on and more and more events are added) the length of the operation would increase.
## Useful Reference Links
- [Google Apps Script](https://script.google.com/home)
- [Calendar API](https://developers.google.com/apps-script/reference/calendar/calendar-app)
- [Find Calendar ID](https://docs.simplecalendar.io/find-google-calendar-id/)
- [Sharing Calendars](https://support.google.com/calendar/answer/37082?hl=en-GB)
- [Simple Triggers](https://developers.google.com/apps-script/guides/triggers/)