X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;f=turbot%2Finteraction.py;h=fb11599034fc1f518a1ec7a19a7d54ade43862be;hb=1efdf784442e0bfc0fb96a18ec833e2801af7973;hp=7f93c040ce8c4a5406adecf80104ab84c8e47d27;hpb=30846beeed5db3c857a19f75a91dc33c014c9204;p=turbot diff --git a/turbot/interaction.py b/turbot/interaction.py index 7f93c04..fb11599 100644 --- a/turbot/interaction.py +++ b/turbot/interaction.py @@ -82,6 +82,7 @@ def multi_static_select(turb, payload): actions['multi_static_select'] = {"*": multi_static_select} def edit(turb, body, args): + """Implementation of the `/edit` command To edit the puzzle for the current channel. @@ -893,6 +894,72 @@ def state(turb, body, args): commands["/state"] = state +def tag(turb, body, args): + """Implementation of the `/tag` command. + + Arg is either a tag to add (optionally prefixed with '+'), or if + prefixed with '-' is a tag to remove. + """ + + if not args: + return bot_reply("Usage: `/tag [+]TAG_TO_ADD` " + + "or `/tag -TAG_TO_REMOVE`.") + + channel_id = body['channel_id'][0] + + old_puzzle = puzzle_for_channel(turb, channel_id) + + if not old_puzzle: + return bot_reply( + "Sorry, the /tag command only works in a puzzle channel") + + if args[0] == '-': + tag = args[1:] + action = 'remove' + else: + tag = args + if tag[0] == '+': + tag = tag[1:] + action = 'add' + + # Force tag to all uppercase + tag = tag.upper() + + # Reject a tag that is not alphabetic or underscore A-Z_ + if not re.match(r'^[A-Z_]*$', tag): + return bot_reply("Sorry, tags can only contain letters " + + "and the underscore character.") + + if action == 'remove': + if 'tags' not in old_puzzle or tag not in old_puzzle['tags']: + return bot_reply("Nothing to do. This puzzle is not tagged " + + "with the tag: {}".format(tag)) + else: + if 'tags' in old_puzzle and tag in old_puzzle['tags']: + return bot_reply("Nothing to do. This puzzle is already tagged " + + "with the tag: {}".format(tag)) + + # OK. Error checking is done. Let's get to work + + # Make a copy of the puzzle object + puzzle = old_puzzle.copy() + + if action == 'remove': + puzzle['tags'] = [t for t in puzzle['tags'] if t != tag] + else: + if 'tags' not in puzzle: + puzzle['tags'] = [tag] + else: + puzzle['tags'].append(tag) + + turb.table.put_item(Item=puzzle) + + puzzle_update_channel_and_sheet(turb, puzzle, old_puzzle=old_puzzle) + + return lambda_ok + +commands["/tag"] = tag + def solved(turb, body, args): """Implementation of the /solved command