2016-08-17 18:34:11 +02:00
|
|
|
# See readme.md for instructions on running this code.
|
|
|
|
|
|
|
|
class FollowupHandler(object):
|
|
|
|
'''
|
|
|
|
This plugin facilitates creating follow-up tasks when
|
|
|
|
you are using Zulip to conduct a virtual meeting. It
|
2017-02-16 22:56:32 +01:00
|
|
|
looks for messages starting with '@mention-bot'.
|
2016-08-17 18:34:11 +02:00
|
|
|
|
|
|
|
In this example, we write follow up items to a special
|
|
|
|
Zulip stream called "followup," but this code could
|
|
|
|
be adapted to write follow up items to some kind of
|
|
|
|
external issue tracker as well.
|
|
|
|
'''
|
|
|
|
|
|
|
|
def usage(self):
|
|
|
|
return '''
|
|
|
|
This plugin will allow users to flag messages
|
|
|
|
as being follow-up items. Users should preface
|
2017-02-16 22:56:32 +01:00
|
|
|
messages with "@mention-bot".
|
2016-08-17 18:34:11 +02:00
|
|
|
|
|
|
|
Before running this, make sure to create a stream
|
|
|
|
called "followup" that your API user can send to.
|
|
|
|
'''
|
|
|
|
|
2016-10-10 18:42:14 +02:00
|
|
|
def handle_message(self, message, client, state_handler):
|
2017-03-05 19:58:18 +01:00
|
|
|
bot_response = self.get_bot_followup_response(message)
|
2016-08-17 18:34:11 +02:00
|
|
|
client.send_message(dict(
|
|
|
|
type='stream',
|
|
|
|
to='followup',
|
|
|
|
subject=message['sender_email'],
|
2017-03-05 19:58:18 +01:00
|
|
|
content=bot_response,
|
2016-08-17 18:34:11 +02:00
|
|
|
))
|
|
|
|
|
2017-03-05 19:58:18 +01:00
|
|
|
def get_bot_followup_response(self, message):
|
|
|
|
original_content = message['content']
|
|
|
|
original_sender = message['sender_email']
|
|
|
|
temp_content = 'from %s:' % (original_sender,)
|
|
|
|
new_content = temp_content + original_content
|
|
|
|
|
|
|
|
return new_content
|
|
|
|
|
2016-08-17 18:34:11 +02:00
|
|
|
handler_class = FollowupHandler
|