1 from turbot.blocks import input_block
4 def new_hunt(turb, payload):
5 """Handler for the action of user pressing the new_hunt button"""
9 "private_metadata": "new_hunt",
10 "title": { "type": "plain_text", "text": "New Hunt" },
11 "submit": { "type": "plain_text", "text": "Create" },
13 input_block("Hunt name", "name", "Name of the hunt"),
14 input_block("Hunt ID", "slug", "Short hunt prefix (no spaces)"),
15 input_block("Hunt URL", "url", "External URL of hunt")
19 result = turb.slack_client.views_open(trigger_id=payload['trigger_id'],
22 submission_handlers[result['view']['id']] = new_hunt_submission
29 def new_hunt_submission(turb, payload):
30 """Handler for the user submitting the new hunt modal
32 This is the modal view presented to the user by the new_hunt
35 state = payload['view']['state']['values']
36 name = state['name']['name']['value']
37 slug = state['slug']['slug']['value']
38 url = state['url']['url']['value']
40 # Create a channel for the hunt
41 response = turb.slack_client.conversations_create(name=slug)
43 if not response['ok']:
44 print("Error creating channel for hunt {}: {}"
45 .format(name, str(response)))
50 user_id = payload['user']['id']
51 channel_id = response['channel']['id']
53 # Create a sheet for the channel
54 turbot.sheets.sheets_create(turb, slug)
56 # Insert the newly-created hunt into the database
57 turb.hunts_table = turb.db.Table("hunts")
58 turb.hunts_table.put_item(
60 'channel_id': channel_id,
68 # Invite the initiating user to the channel
69 turb.slack_client.conversations_invite(channel=channel_id, users=user_id)
75 def view_submission(turb, payload):
77 """Handler for Slack interactive view submission
79 Specifically, those that have a payload type of 'view_submission'"""
81 view_id = payload['view']['private_metadata']
83 if view_id in submission_handlers:
84 return submission_handlers[view_id](turb, payload)
86 print("Error: Unknown view ID: {}".format(view_id))
97 submission_handlers = {
98 "new_hunt": new_hunt_submission