Made job signoffs notify the target
This commit is contained in:
parent
46129b8d24
commit
58f6af7cde
|
|
@ -4,6 +4,7 @@ import channel_util
|
|||
import google_api
|
||||
import identifier
|
||||
import slack_util
|
||||
import scroll_util
|
||||
|
||||
SHEET_ID = "1lPj9GjB00BuIq9GelOWh5GmiGsheLlowPnHLnWBvMOM"
|
||||
|
||||
|
|
@ -68,11 +69,27 @@ def signoff_callback(slack, msg, match):
|
|||
slack_util.reply(slack, msg, "Gave {} one housejob point.\n"
|
||||
"They now have {} for this period.\n"
|
||||
"You ({}) were credited with the signoff".format(bro_name, bro_total, ass_name))
|
||||
alert_user(slack, bro_name,
|
||||
"You, who we believe to be {}, just had your house job signed off by {}!".format(bro_name, ass_name))
|
||||
except BadName as e:
|
||||
# We didn't find a name - no action was performed.
|
||||
slack_util.reply(slack, msg, e.as_response())
|
||||
|
||||
|
||||
def alert_user(slack, name, saywhat):
|
||||
"""
|
||||
DM a brother saying something
|
||||
"""
|
||||
brother_dict = scroll_util.find_by_name(name)
|
||||
# We do this as a for loop just in case multiple people reg. to same scroll for some reason (e.g. dup accounts)
|
||||
for slack_id in identifier.lookup_brother_userids(brother_dict):
|
||||
dm_id = slack_util.im_channel_for_id(slack, slack_id)
|
||||
if dm_id:
|
||||
slack_util.reply(slack, None, saywhat, to_channel=dm_id, in_thread=False)
|
||||
else:
|
||||
print("Warning: unable to find dm for brother {}".format(brother_dict))
|
||||
|
||||
|
||||
def punish_callback(slack, msg, match):
|
||||
# Find the index of our person.
|
||||
name = match.group(2)
|
||||
|
|
@ -90,6 +107,11 @@ def punish_callback(slack, msg, match):
|
|||
"You can easily earn it back by signing off the right person ;).".format(bro_name,
|
||||
bro_total,
|
||||
ass_name))
|
||||
alert_user(slack, bro_name,
|
||||
"You, who we believe to be {}, just had your house job UN-signed off by {}.\n"
|
||||
"Perhaps the asshoman made a mistake when they first signed you off.\n"
|
||||
"If you believe this to be a mistake, talk to them".format(bro_name, signer))
|
||||
|
||||
except BadName as e:
|
||||
# We didn't find a name - no action was performed.
|
||||
slack_util.reply(slack, msg, e.as_response())
|
||||
|
|
@ -99,7 +121,7 @@ def adjust_scores(*name_delta_tuples):
|
|||
# Get the current stuff
|
||||
points = get_curr_points()
|
||||
names = [p[0] for p in points]
|
||||
results = []
|
||||
modified_user_indexes = []
|
||||
|
||||
for name, delta in name_delta_tuples:
|
||||
# Find our guy
|
||||
|
|
@ -118,16 +140,18 @@ def adjust_scores(*name_delta_tuples):
|
|||
|
||||
# target should be in the form index, (name, score)
|
||||
target_new = [target_name, curr_score + delta]
|
||||
results.append(target_new)
|
||||
|
||||
# Put it back
|
||||
points[target_index] = target_new
|
||||
|
||||
# Record all when done
|
||||
# Record where we edited
|
||||
modified_user_indexes.append(target_index)
|
||||
|
||||
# Push all to sheets if exit loop without error
|
||||
put_points(points)
|
||||
|
||||
# Return the adjusted name/score_tuples
|
||||
return results
|
||||
# Conver indexes to rows, then return the adjusted name/score_tuples
|
||||
return [points[i] for i in modified_user_indexes]
|
||||
|
||||
|
||||
def reset_callback(slack, msg, match):
|
||||
|
|
|
|||
|
|
@ -20,9 +20,20 @@ def reply(slack, msg, text, in_thread=True, to_channel=None):
|
|||
if in_thread:
|
||||
thread = (msg.get("thread_ts") # In-thread case - get parent ts
|
||||
or msg.get("ts")) # Not in-thread case - get msg itself ts
|
||||
slack.rtm_send_message(channel=to_channel, message=text, thread=thread)
|
||||
result = slack.rtm_send_message(channel=to_channel, message=text, thread=thread)
|
||||
else:
|
||||
slack.rtm_send_message(channel=to_channel, message=text)
|
||||
result = slack.rtm_send_message(channel=to_channel, message=text)
|
||||
return result
|
||||
|
||||
|
||||
def im_channel_for_id(slack, user_id):
|
||||
conversations = slack.api_call("conversations.list", types="im")
|
||||
if conversations["ok"]:
|
||||
channels = conversations["channels"]
|
||||
for channel in channels:
|
||||
if channel["is_im"] and channel["user"] == user_id:
|
||||
return channel["id"]
|
||||
return None
|
||||
|
||||
|
||||
class SlackDebugCondom(object):
|
||||
|
|
|
|||
Loading…
Reference in New Issue