Golang Calendar CLI
This application is a CLI that was written in Golang using Cobra, it communicates with your Google calendar, allowing you to create, display and delete events via the command line.
Technologies
GCP Setup
Follow the steps below to configure your application on GCP, as we need to create a project in it and activate the Calendar API.
Go to Google Cloud Platform here: link
Step 1
Create a new project
data:image/s3,"s3://crabby-images/31d6b/31d6b1d723b5b8e19ca868be3e8f27bd547c38ac" alt="gcp-step-1"
Step 2
Define project name
data:image/s3,"s3://crabby-images/59fc1/59fc17ef507e30b019039ae7d28df4a93edd8e9a" alt="gcp-step-2"
Step 3
Access Google Calendar API page
data:image/s3,"s3://crabby-images/595d4/595d4a32bf34742130dd284b8a27d79fc2652e44" alt="gcp-step-3"
Step 4
Enable Google Calendar API
data:image/s3,"s3://crabby-images/2eeb7/2eeb790a452c275721ed984793987bbdffb7ad0d" alt="gcp-step-4"
Step 5
Access credentials page
data:image/s3,"s3://crabby-images/066eb/066eb6e738f86daf4de458d4d7fc24d34ac4ee79" alt="gcp-step-5"
Step 6
Access service account option
data:image/s3,"s3://crabby-images/e56a1/e56a1b1704c227f357517e95586112317aa7c6d6" alt="gcp-step-6"
Step 7
Service account details
data:image/s3,"s3://crabby-images/78270/78270f0ded9fff0123a0d6a390e6d31873f2475c" alt="gcp-step-7"
Step 8
Grant this service account access to project
data:image/s3,"s3://crabby-images/a5b6d/a5b6d319b40f662ec43d50c095bc5a3959eee4d5" alt="gcp-step-8"
Step 9
Click on your created service account
data:image/s3,"s3://crabby-images/8e31a/8e31ae1a2d33ebffd05c01d58c7a29bac800507e" alt="gcp-step-9"
Step 10
Create new key
data:image/s3,"s3://crabby-images/80520/80520d51250718279c41142ddd9079067baaea13" alt="gcp-step-10"
Step 11
Download the JSON file
data:image/s3,"s3://crabby-images/c864d/c864dd5b0b85a6251e13ecb0d284ecf188f35d0a" alt="gcp-step-11"
Save it in the project root with the name credentials.json
Google Calendar Setup
Follow the steps below to configure your application on Google Calendar.
Go to Google Calendar here: link
Step 1
Access settings page
data:image/s3,"s3://crabby-images/fb6f4/fb6f469d3534dd971d3f63e7fe2eed81f9721a9c" alt="google-calendar-step-1"
Step 2
Create a new calendar
data:image/s3,"s3://crabby-images/cd302/cd3026608668c83fd9ea00952fe22d789155e17f" alt="google-calendar-step-2-1"
Step 3
Share with specific people or groups
data:image/s3,"s3://crabby-images/df633/df63381e1cca21d82f708187c617f59ab54c217b" alt="google-calendar-step-3"
Copy the client_email
from the credentials file previously downloaded from GCP and add this email in this step.
Step 4
Copy calendar ID
data:image/s3,"s3://crabby-images/82fcf/82fcf02966349dda26a0d88e72db08898c1fa86f" alt="google-calendar-step-4"
You need to copy the calendar id, as it will be used in the application execution step below.
Execute application
Setup app
Make sure the credentials.json
file is in the root of the project, as instructed in the GCP setup step.
Change the calendar name in internal/calendar/calendar.go line 17:
const AGENDA = "YOUR CALENDAR NAME"
Install dependencies:
$ go mod download
Execute app
Build application:
$ go build
Create integration:
$ ./golang-calendar-cli agenda ID
Is the ID copied in the Google Calendar Setup step.
This action is only necessary once.
Commands
Create a new event
$ ./golang-calendar-cli events insert --title "New Event" --description "New Event Description" --location "My home" --dateTimeStart "2024-03-29T09:00:00-03:00" --dateTimeEnd "2024-03-29T17:00:00-03:00"
For more details run: ./golang-calendar-cli events insert -h
Show events by day
$ ./golang-calendar-cli events day
Show events by week
$ ./golang-calendar-cli events week
Delete event by ID
$ ./golang-calendar-cli events delete ID
You can get the event ID by viewing events by day or week