'v3',
credentials=gsheets_creds,
cache_discovery=False)
+files = service.files()
permissions = service.permissions()
db = boto3.resource('dynamodb')
turb.db = db
turb.table = db.Table("turbot")
turb.sheets = sheets
+turb.files = files
turb.permissions = permissions
def error(message):
def turbot_lambda(event, context):
"""Top-level entry point for our lambda function.
+ This can handle either a REST API request from Slack, or an HTTP
+ request for teh Turbot web view
+ """
+
+ # First, determine if we've been invoked by Slack, (by presence of
+ # the X-Slack-Signature header)
+ headers = requests.structures.CaseInsensitiveDict(event['headers'])
+
+ if 'X-Slack-Signature' in headers:
+ return turbot_slack_handler(event, context)
+
+ # Otherwise, emit the Turbot web view
+ return turbot_web_view(event, context)
+
+def turbot_web_view(event, context):
+ """Turbot web view
+
+ """
+
+ return {
+ 'statusCode': '200',
+ 'body': 'Hello, Lambda world.',
+ 'headers': {
+ 'Content-Type': 'application/text',
+ },
+ }
+
+def turbot_slack_handler(event, context):
+ """Primary entry point for all Slack-initiated API requests to Turbot
+
This function first verifies that the request actually came from
Slack, (by means of the SLACK_SIGNING_SECRET SSM parameter), and
refuses to do anything if not.
Then this defers to either turbot_event_handler or
turbot_slash_command to do any real work.
+
"""
headers = requests.structures.CaseInsensitiveDict(event['headers'])
action = actions[0]
atype = action['type']
- avalue = action['value']
+ if 'value' in action:
+ avalue = action['value']
+ else:
+ avalue = '*'
if (
atype in turbot.interaction.actions