from urllib.parse import parse_qs
from slack import WebClient
+import base64
import boto3
import requests
import json
import os
+import pickle
from types import SimpleNamespace
+from google.auth.transport.requests import Request
+from googleapiclient.discovery import build
import turbot.actions
import turbot.commands
slack_bot_token = response['Parameter']['Value']
slack_client = WebClient(slack_bot_token)
+response = ssm.get_parameter(Name='GSHEETS_PICKLE_BASE64', WithDecryption=True)
+gsheets_pickle_base64 = response['Parameter']['Value']
+gsheets_pickle = base64.b64decode(gsheets_pickle_base64)
+gsheets_creds = pickle.loads(gsheets_pickle)
+if gsheets_creds:
+ if gsheets_creds.valid:
+ print("Loaded valid GSheets credentials from SSM")
+ else:
+ gsheets_creds.refresh(Request())
+ gsheets_pickle = pickle.dumps(gsheets_creds)
+ gsheets_pickle_base64 = base64.b64encode(gsheets_pickle)
+ print("Storing refreshed GSheets credentials into SSM")
+ ssm.put_parameter(Name='GSHEETS_PICKLE_BASE64',
+ Type='SecureString',
+ Value=gsheets_pickle_base64,
+ Overwrite=True)
+service = build('sheets',
+ 'v4',
+ credentials=gsheets_creds,
+ cache_discovery=False)
+sheets = service.spreadsheets()
+
db = boto3.resource('dynamodb')
turb = SimpleNamespace()
turb.slack_client = slack_client
turb.db = db
+turb.sheets = sheets
def error(message):
"""Generate an error response for a Slack request