Skip to content

Latest commit

 

History

History
198 lines (145 loc) · 8.09 KB

CONFIGURING-GOOGLE.md

File metadata and controls

198 lines (145 loc) · 8.09 KB

Configuring Google

This instructions' guide will give your application permission to make a copy of the post-mortem doc template in your Google Drive whenever a new incident is started.

Contents

  1. Official documentation
  2. Get a Client ID and Client Secret
  3. Google Drive API
  4. Google Calendar API
  5. Setting environment variables

Official documentation

The instructions here are a summary of the official documentation.

Get a Client ID and Client Secret

  1. Open the Google API Console Credentials page.
  2. From the project drop-down menu, select an existing project or create a new one.

OAuth consent screen

  1. On the OAuth consent screen page, select an User Type, then click Create.
  2. Give a name for it and save it.

Credentials

  1. On the Credentials page, select Create credentials, then select OAuth client ID.
  2. Under Application type, choose Desktop app and give it a name, ie. Hellper. Then, click Create.
  3. On this next page, take note of the Client ID and Client Secret. You'll need these going forward. Then, click Ok.
  4. At last, click in the Download icon button to configure your credentials.
  5. Copy the content file and paste it in your environment variable called: HELLPER_GOOGLE_CREDENTIALS.

Google Drive API

Authorizing requests to the Google Drive API

  1. Copy the Client ID you got in the last step (Credentials).
  2. In the following URL, change YOUR_CLIENT_ID_HERE with the content from Client ID:
https://accounts.google.com/o/oauth2/v2/auth?client_id=YOUR_CLIENT_ID_HERE&response_type=code&scope=https://www.googleapis.com/auth/drive&access_type=offline&redirect_uri=urn:ietf:wg:oauth:2.0:oob
  1. Access the new URL in your web browser.
  2. Allow the permissions to your application to be able to access yours files.
  3. On this next page, take note of the Code. You'll need this going forward.

Generate Google Drive access token

  1. Now you need to copy the Client ID, Client Secret and Code of the last steps (Credentials and Authorizing requests to the Google Drive API), and replace them respectively in the follow command:
curl --data client_id="YOUR_CLIENT_ID_HERE" \
  --data client_secret="YOUR_CLIENT_SECRET_HERE" \
  --data code="YOUR_AUTH_CODE_HERE" \
  --data redirect_uri=urn:ietf:wg:oauth:2.0:oob \
  --data grant_type=authorization_code \
  https://oauth2.googleapis.com/token
  1. Run it in your terminal and copy the response.
  2. Past it in your environment variable called: HELLPER_GOOGLE_DRIVE_TOKEN.

Example

Run it in terminal

curl --data client_id="YOUR_CLIENT_ID" \
  --data client_secret="YOUR_CLIENT_SECRET" \
  --data code="YOUR_AUTH_CODE" \
  --data redirect_uri=urn:ietf:wg:oauth:2.0:oob \
  --data grant_type=authorization_code \
  https://oauth2.googleapis.com/token

Response

{
  "access_token": "xxxxxxxxxxxxxxxxxx",
  "expires_in": 3599,
  "refresh_token": "xxxxxxxxxxxxxxxxxx",
  "scope": "https://www.googleapis.com/auth/drive",
  "token_type": "Bearer"
}

Enabling Google Drive API

Access API Library, then click Enable.

Template Post-mortem

  1. Create new a file in your Google Doc and copy the ID from the file, like this:

https://docs.google.com/document/d/YOUR_FILE_ID_IS_HERE/edit

  1. Paste the ID in your environment variable called: HELLPER_GOOGLE_DRIVE_FILE_ID.

Google Calendar API

Authorizing requests to the Google Calendar API

  1. Copy the Client ID you got in the last step (Credentials).
  2. In the following URL, change YOUR_CLIENT_ID_HERE with the content from Client ID:
https://accounts.google.com/o/oauth2/v2/auth?client_id=YOUR_CLIENT_ID_HERE&response_type=code&scope=https://www.googleapis.com/auth/calendar&access_type=offline&redirect_uri=urn:ietf:wg:oauth:2.0:oob
  1. Access the new URL in your web browser.
  2. Allow the permissions to your application to be able to access your files.
  3. On this next page, take note of the Code. You'll need this going forward.

Generate Google Calendar access token

  1. Now you need to copy the Client ID, Client Secret and Code of the last steps (Credentials and Authorizing requests to the Google Calendar API)), and replace them respectively in the follow command:
curl --data client_id="YOUR_CLIENT_ID_HERE" \
  --data client_secret="YOUR_CLIENT_SECRET_HERE" \
  --data code="YOUR_AUTH_CODE_HERE" \
  --data redirect_uri=urn:ietf:wg:oauth:2.0:oob \
  --data grant_type=authorization_code \
  https://oauth2.googleapis.com/token
  1. Run it in your terminal and copy the response.
  2. Past it in your environment variable called: HELLPER_GOOGLE_CALENDAR_TOKEN.

Example

Run it in terminal

curl --data client_id="YOUR_CLIENT_ID" \
  --data client_secret="YOUR_CLIENT_SECRET" \
  --data code="YOUR_AUTH_CODE" \
  --data redirect_uri=urn:ietf:wg:oauth:2.0:oob \
  --data grant_type=authorization_code \
  https://oauth2.googleapis.com/token

Response

{
  "access_token": "xxxxxxxxxxxxxxxxxx",
  "expires_in": 3599,
  "refresh_token": "xxxxxxxxxxxxxxxxxx",
  "scope": "https://www.googleapis.com/auth/calendar",
  "token_type": "Bearer"
}

Enabling Google Calendar API

Access API Library, then click Enable.

Obtain your Google Calendar's ID

If you don't need to create a new google calendar go to step 6, otherwise follow the instructions below.

  1. On your computer, open Google Calendar
  2. On the left, next to Other calendars click Add other calendars
  3. Click Create new calendar
  4. Add a name and description for your calendar
  5. Click Create calendar
  6. In the Google Calendar interface, locate the My calendars area on the left
  7. Hover over the calendar you need and click the downward arrow
  8. A menu will appear. Click Calendar settings
  9. In the Calendar Address section of the screen, you will see your Calendar ID. It will look something like: abcd1234@group.calendar.google.com
  10. Paste the ID in your environment variable called: HELLPER_GOOGLE_CALENDAR_ID

Setting environment variables

Now you need to change these three variables:

Variable Explanation
HELLPER_GOOGLE_CREDENTIALS Google Credentials
HELLPER_GOOGLE_DRIVE_TOKEN Google Drive Token
HELLPER_GOOGLE_DRIVE_FILE_ID Google Drive File Id to your post-mortem template
HELLPER_GOOGLE_CALENDAR_TOKEN Google Calendar Token
HELLPER_GOOGLE_CALENDAR_ID Google Calendar Id to schedule your post-mortem