Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Slack DM ability to self.say #375

Open
wants to merge 245 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
245 commits
Select commit Hold shift + click to select a range
afd8457
Fix world time plugin
woohgit Oct 8, 2017
16b325f
WorldTime plugin does not require API keys
woohgit Oct 8, 2017
b774d83
Handle errors/exceptions too
woohgit Oct 8, 2017
5f86669
strip HTML tags for shell backend
woohgit Oct 8, 2017
c068a6a
Merge pull request #285 from woohgit/google_worldtime
skoczen Oct 9, 2017
24f4182
Merge pull request #287 from woohgit/strip_html_tags_for_shell_backend
skoczen Oct 9, 2017
3e63f77
Merge pull request #276 from mike-love/feature/dockerized
skoczen Oct 9, 2017
2ed4488
v1.0.1 release, with credits
Oct 9, 2017
437d92d
Fixes merge conflicts
Oct 9, 2017
1d092a3
Merge branch 'Tenzer-all-the-changes'
Oct 9, 2017
db3b483
Adds tox to dev reqs, and circle
Oct 9, 2017
d3c3c4e
Adds symlink support for cleanup
Oct 9, 2017
fb37ac9
Merges in py3 and master changes. (MASSIVE CONFLICTS)
Oct 9, 2017
576073c
Cleanup from style choices I didn't quite agree with, prints in 2.x, …
Oct 9, 2017
52fb864
Uses built-in html_to_text
Oct 9, 2017
bc2901d
Fixes up tests.
Oct 9, 2017
7d173fc
Friendlier location output
Oct 9, 2017
a9ab4ab
Merge pull request #288 from skoczen/feature/merges-in-py3
skoczen Oct 9, 2017
fb62839
Teaches will how to reply in slack threads.
Oct 10, 2017
45dd899
Merge branch 'feature/merges-in-py3' into feature/shell-backend
Oct 10, 2017
6695210
Finishes teaching Will how to handle threads in slack, and adds a bit…
Oct 10, 2017
b497f45
Handles mentions, even when the slack app doesn't auto-link.
Oct 10, 2017
588ab56
Minorly clean up will.plugin
wontonst Oct 10, 2017
008f329
Allow will.plugin.WillPlugin.say to accept a string room param
wontonst Oct 10, 2017
fcb9df3
Merge branch 'master' into master
chillipeper Oct 15, 2017
33a76e7
Adding custom filters support for jinja2 rendered_template decorator
Oct 15, 2017
6131f3b
Readme rendered_template update
Oct 15, 2017
a7047ed
Pulls handle_regexes
skoczen Oct 15, 2017
62aa87b
Renames and cleans up data.source mess, and makes SECRET_KEY automagi…
skoczen Oct 18, 2017
d5f11ff
Adds deprecation warnings for admin_only.
skoczen Oct 18, 2017
811c4ad
Encrypt by default
skoczen Oct 18, 2017
ebe836b
ACL 2.0
skoczen Oct 18, 2017
f11a4dc
Detects and auto-moves config.py.dist to config.py
skoczen Oct 18, 2017
534bf9b
Daaaamn. Will now auto-tracks replies. Simple as self.reply("Oh, hi!")
skoczen Oct 18, 2017
6e37740
Wipes all the old .reply(message, "actual reply") syntax out of the b…
skoczen Oct 18, 2017
ca22f97
Moves Roster to HipchatRoster, provides defaults for WILL_HANDLE, cle…
skoczen Oct 18, 2017
230f6d3
Moves RosterMixin, cleans up docs
skoczen Oct 18, 2017
2f1cbc2
Sorts a couple of the rocketchat TODOs
skoczen Oct 19, 2017
10db469
Merges in master, resolves conflicts, removes ListenerMixin.
skoczen Oct 19, 2017
984bd5e
Partway to fixed tests
skoczen Oct 19, 2017
f9c7f50
Adds pytz, locks sleekxmpp to 1.3.2
skoczen Oct 19, 2017
291ce60
Moves to original_incoming_event
skoczen Oct 19, 2017
1fc32cd
Main-room hipchat working.
skoczen Oct 19, 2017
cf9106c
Wires will up to hipchat private rooms with current spec
skoczen Oct 19, 2017
35e5754
Makes sure card is added.
skoczen Oct 19, 2017
d1d342c
Remind me working on all platforms, adds mention_handle to take care …
skoczen Oct 19, 2017
5eac5b2
Updates readme for 2.x
skoczen Oct 19, 2017
9468ecb
Attempt at start of weird hipchat bug.
skoczen Oct 20, 2017
7b01e95
Moves to EncryptionMixin, but it's not fully baked yet and I don't wa…
skoczen Oct 20, 2017
65290d2
Handles history null state
skoczen Oct 20, 2017
9482f7c
Merge remote-tracking branch 'upstream/master'
Oct 20, 2017
1e54430
Add Roy Zheng to AUTHORS, clean up trailing slashes
wontonst Oct 20, 2017
775e079
Provide a fallback in case yappi isn't installed.
skoczen Oct 22, 2017
8587846
Adds support for slack to specify by channel name or ID, as well as t…
skoczen Oct 23, 2017
5bf3298
Adds abstracted topic support, cleans up the worst bits left.
skoczen Oct 23, 2017
90ecd1d
Hipchat abstraction and cleanup
skoczen Oct 23, 2017
332e350
Merge branch 'feature/shell-backend' into feature/encrytion-mixin
skoczen Oct 23, 2017
5f14c47
Encryption mixin and storage working!
skoczen Oct 23, 2017
a777bc9
De-base64
skoczen Oct 23, 2017
706b256
Streamline, don't store in memory
skoczen Oct 23, 2017
fe6750d
Cleans up config.py documentation
skoczen Oct 23, 2017
6689a54
Gets tests passing.
skoczen Oct 24, 2017
f837d9d
Moves Room->HipChatRoom, consistency on HipChat
skoczen Oct 24, 2017
0366bfd
No longer require HIPCHAT_HANDLE or HIPCHAT_NAME, automatically get t…
skoczen Oct 24, 2017
26e57d8
Handles UTF8 in docstrings, provides room/channel fallbacks.
skoczen Oct 24, 2017
291eacc
Merge pull request #290 from wontonst/master
skoczen Oct 24, 2017
9c3c9dc
Merge pull request #291 from chillipeper/master
skoczen Oct 24, 2017
482da19
1.0.2 credits and version
skoczen Oct 24, 2017
71eaed8
Merge branch 'master' of github.com:skoczen/will
skoczen Oct 24, 2017
ddffaea
Ignores E722
skoczen Oct 24, 2017
502f44f
Adds docs for 1.0.2
skoczen Oct 24, 2017
a71711b
Adds missing paren.
skoczen Oct 24, 2017
98b4267
Merges in master and 1.0.2
skoczen Oct 24, 2017
7b688ab
Ports @wontonst 's room= improvements to 2.x
skoczen Oct 24, 2017
a01c584
Merge branch 'master' of github.com:skoczen/will
Oct 24, 2017
11e1775
Merge branch 'feature/shell-backend' of github.com:skoczen/will
Oct 24, 2017
a696afa
Fixes up rocket.chat, adds routing, gets code to same patterns, provi…
skoczen Oct 25, 2017
0092b42
Pep8 and Birthday :)
skoczen Oct 25, 2017
cc656a5
Moves reqs to a folder, moves profile to an arg.
skoczen Oct 25, 2017
21e0b6c
Updates circle with reqs folder
skoczen Oct 25, 2017
357fea5
Adds `service=` argument to .say() and similar, adds warnings if .rep…
skoczen Oct 25, 2017
425ec4d
Defaults to all reqs, updates config.py.dist, provides fallbacks for …
skoczen Oct 25, 2017
793a4af
Swaps to REQS_DIR
skoczen Oct 25, 2017
62fc8fc
Updates MANIFEST.in with new reqs structure, requests version.
skoczen Oct 25, 2017
b2e94a2
pulls eggs for testing
skoczen Oct 26, 2017
2c46496
Merge branch 'feature/shell-backend' of github.com:skoczen/will
Oct 26, 2017
d26792f
pull from docker base; allow branch as arg
Oct 26, 2017
bbb2d0a
fixed alpine typo
Oct 26, 2017
7c0e6d2
moved to python2.7 to enable beta2.0 version'
Oct 26, 2017
c83250b
move to base-2.7 to break out versions of python
Oct 26, 2017
d1bf6db
Moves to forked markdownify for 3.x support until PR is merged
skoczen Oct 26, 2017
3d474ef
Code cleanup
skoczen Oct 26, 2017
a9c0620
Bit more cleanup
skoczen Oct 26, 2017
c772e95
Explicitly notes that ZeroMQ won't be in 2.0.1.
skoczen Oct 26, 2017
b4258d6
Gets generate_will_project working smoothly, starts re-support of pyt…
skoczen Oct 27, 2017
8f6fc0b
Mostly gets things working in python 3
skoczen Oct 27, 2017
d18e832
Gets images to python 3 compatability
skoczen Oct 27, 2017
c7280c3
Fixes flake8
skoczen Oct 27, 2017
b07f9ac
Merge branch 'feature/shell-backend' of github.com:skoczen/will
Oct 28, 2017
723b9fc
Updates setup to handle forked packages, adds some birthday magic.
skoczen Nov 1, 2017
a3dc61c
Much better handling for startup when you're upgrading from Will v1 a…
skoczen Nov 1, 2017
6a6ff80
Adds default settings for Fuzziness.
skoczen Nov 1, 2017
2072d49
Fixes pep8
skoczen Nov 1, 2017
8677a6e
Documentation time!
skoczen Nov 1, 2017
1df6774
req cleanup
skoczen Nov 2, 2017
82ebed0
Moves to temporary forks
skoczen Nov 2, 2017
c46eec5
Adds upgrade to 2.x docs
skoczen Nov 2, 2017
54d7c1b
Documentation for 2.0.1beta1 release
skoczen Nov 2, 2017
deead3f
Lots of docs, consistency in backend method names
skoczen Nov 2, 2017
d4222bf
Fully fleshed out docs :)
skoczen Nov 2, 2017
a30c61e
ignore testing file so i do not stupidly commit passwords
Nov 3, 2017
b6e75b7
moving to a multi py version dist method
Nov 3, 2017
589fb02
create a base image for will that pulls from py2 alpine repo
Nov 3, 2017
9f3f22a
create a base image for will that pulls from py3 alpine repo
Nov 3, 2017
6cdda8e
create a will container definition that will pull from the will-base:py3
Nov 3, 2017
fdea72c
create a will container definition that will pull from the will-base:py2
Nov 3, 2017
8da567e
update docker compose to use latest image
Nov 3, 2017
fbf25b9
pull from docker base; allow branch as arg
Oct 26, 2017
98ba11c
fixed alpine typo
Oct 26, 2017
f9f570d
moved to python2.7 to enable beta2.0 version'
Oct 26, 2017
beef8a9
move to base-2.7 to break out versions of python
Oct 26, 2017
3edd39b
Merge branch 'feature/docker-updates' of github.com:mike-love/will in…
Nov 3, 2017
b016ae1
updates for new params and dist
Nov 3, 2017
80f3dd1
docker updates for new dist methods
Nov 3, 2017
2390d17
Merge branch 'feature/dockerized' into feature/docker-updates
Nov 3, 2017
d232dca
Interactive generation, documentation nav and transitions.
skoczen Nov 3, 2017
7d391a8
Documentation for all backends in, smarter generate_will - maybe the …
skoczen Nov 4, 2017
9e5774c
Tightens up docs
skoczen Nov 4, 2017
4723077
cleanup docker deployment docs & add the dockerfile specific instruct…
Nov 6, 2017
d387fbb
remove redundant 2.x in place of the more specific 2.7
Nov 6, 2017
0ebf013
cleanup docker deployment docs & add the dockerfile specific instruct…
Nov 6, 2017
1c84ed3
docker platform section is unnecessary we can just add to deploy
Nov 6, 2017
ea79528
Documents Slack token
skoczen Nov 6, 2017
c1fe3fe
Merge pull request #299 from mike-love/feature/docker-updates
skoczen Nov 6, 2017
fcc6924
Merge pull request #258 from skoczen/feature/shell-backend
skoczen Nov 6, 2017
974d43f
Updates release date and formatting
skoczen Nov 6, 2017
1106782
Documentation for Will 2.0 cleanup
skoczen Nov 6, 2017
023b036
Pulls builtin bonjour, doc formatting
skoczen Nov 6, 2017
4ec5e9c
Adds transition
skoczen Nov 6, 2017
78c7232
Merge branch 'master' of github.com:skoczen/will into HEAD
Nov 6, 2017
9a74df8
pipe yes to installer to get around interactive commands
Nov 7, 2017
2717331
add to latest dockerfile as well
Nov 7, 2017
633c41e
add to latest dockerfile as well
Nov 7, 2017
3d0f37c
Merge branch 'bugfix/dockerbuildprompts' of github.com:mike-love/will…
Nov 7, 2017
8750238
Start of 2.1 branch
skoczen Nov 8, 2017
45d2b7b
Bugfixes, 2.0.1-beta2 bump.
skoczen Nov 8, 2017
5d310f4
Merge pull request #301 from mike-love/bugfix/dockerbuildprompts
skoczen Nov 8, 2017
97bd732
Adds docs
skoczen Nov 8, 2017
3eaed59
Merges in master
skoczen Nov 8, 2017
5347fc8
Conditional on input loop.
skoczen Nov 12, 2017
68eecc7
Bumps version number, markdownify release.
skoczen Nov 12, 2017
b083174
Merge pull request #305 from skoczen/bugfix/cpu
skoczen Nov 12, 2017
d52f4a5
create build script
Nov 7, 2017
89363c9
add build to script
Nov 7, 2017
6a15c70
not always called from the right dir; need to get the script director…
Nov 7, 2017
877c075
now we should fail the build when a docker build fails
Nov 7, 2017
9892e09
add commit tag for tracking build details
Nov 9, 2017
5e95f44
add deployment and export the commit tag from non-production
Nov 9, 2017
683b159
fixed missing `
Nov 9, 2017
c317378
simplify this and correct dumb mistakes
Nov 9, 2017
249dbbb
wrong env var for the commit
Nov 9, 2017
995d9dc
will base being moved to own project
Nov 16, 2017
cdc41fe
build script will build locally from a remote branch tags and pushes …
Nov 16, 2017
3823bc1
GTAG does not make sense using CTAG for commit tag
Nov 16, 2017
7c33ed3
make the source repo a build arg
Nov 17, 2017
f64221e
make the source repo a build arg
Nov 17, 2017
9560f55
btag should be ctag and reflect the commit
Nov 17, 2017
553b870
update for added build arg
Nov 17, 2017
a81fe85
Adds start_thread, fixes color passing.
skoczen Nov 20, 2017
c23f2b2
Fixes inline linking for slack
skoczen Nov 20, 2017
6f59b5c
Documentation for 2.0.1b4
skoczen Nov 20, 2017
a822621
Little bit of magic, and instruction for handling start_thread in cas…
skoczen Nov 20, 2017
265553d
Merge pull request #309 from skoczen/release/2.0.1b4
skoczen Nov 20, 2017
4ba1b48
Adds docker cloud encrypted creds
skoczen Nov 20, 2017
a1171d8
2.0.1 release - pulls beta.
skoczen Nov 21, 2017
95d5514
Fixes hipchat all rooms bug, bumps to 2.0.2.
skoczen Nov 22, 2017
44599c0
Merge pull request #302 from mike-love/feature/travis-dockerbuild
skoczen Nov 22, 2017
c637296
Merge branch 'master' into feature/encrypted-credentials
skoczen Nov 22, 2017
61c4dea
Merge pull request #311 from skoczen/feature/encrypted-credentials
skoczen Nov 22, 2017
9170aa4
Updates travis docker encrypted pass
skoczen Nov 22, 2017
576fa29
All in one for travis build
skoczen Nov 22, 2017
6a39599
Updates build syntax on docker build script
skoczen Nov 22, 2017
5412eac
Shifts to beta to get master passing
skoczen Nov 23, 2017
a642d41
Switches to fabric command.
skoczen Nov 24, 2017
4a77b33
Fixes pep8
skoczen Nov 24, 2017
35bc23d
Adds dev reqs
skoczen Nov 24, 2017
ffc4d3c
Path prefix
skoczen Nov 24, 2017
fee4f5b
Adds docker as a service
skoczen Nov 24, 2017
3ade333
Updates to ctag name
skoczen Nov 24, 2017
a9faf09
Fixes args
skoczen Nov 24, 2017
ec37c3d
Adds latest
skoczen Nov 24, 2017
ca8733e
Switches to right tags
skoczen Nov 27, 2017
f43fdb9
Fully pulls base
skoczen Nov 27, 2017
00f1f6a
Shifts to base markdownify.
skoczen Nov 27, 2017
9109a48
Fixes py3 for dev mode
skoczen Nov 27, 2017
3e9a2f8
Adds docker login
skoczen Nov 28, 2017
7491140
Updates to 2.1, documents docker hub
skoczen Nov 28, 2017
b845a3d
Merge pull request #316 from skoczen/beta
skoczen Nov 28, 2017
97e174e
save "all_listener_regexes" to storage
acommasplice Dec 6, 2017
3a3da67
Attempt to work around WebSocketConnectionClosedException for slack
Feb 11, 2018
bd7b279
Fix for #337
netjunki Feb 24, 2018
c94f301
Candidate fix for #336 and #306
ostracon Mar 7, 2018
25dc27b
Merge pull request #339 from netjunki/patch-1
skoczen Mar 19, 2018
acdcead
Update AUTHORS
acommasplice Mar 19, 2018
3ba3b91
Merge pull request #325 from acommasplice/patch-1
skoczen Mar 19, 2018
64d8424
Merge pull request #340 from ostracon/master
skoczen Mar 21, 2018
1498a6b
Merge pull request #333 from mattcl/slack-reconnects
skoczen Mar 21, 2018
374ca8d
Sets up for 2.1.1
skoczen Mar 22, 2018
1ce6955
Fixes #332
skoczen Mar 22, 2018
3af1474
Sets confidence to 91, fixes the life-affirming #327.
skoczen Mar 22, 2018
babfb72
Fixes up tests, sets release date.
skoczen Mar 22, 2018
9a375c7
Fixes ctag import
skoczen Mar 22, 2018
b6b6c06
Use python3 str type check in hipchat room str conversion
wontonst Mar 29, 2018
ac18c24
Merge pull request #343 from wontonst/fix_py2_basestring
skoczen Mar 29, 2018
62dda7c
2.1.2 credits
skoczen Mar 29, 2018
15967f5
Add --backends option to generate_will_project
wontonst Apr 2, 2018
00ce1cc
Correct Slack default channel setting
reist Apr 23, 2018
d418c86
scheduled reminders should notify the user who requested them
unicolet May 2, 2018
be3aca3
Added support for slack attachments
eosman-tibco May 17, 2018
97970a2
Improve Slack Connection handling
eosman-tibco May 18, 2018
7b62ab3
Fixed import path
eosman-tibco May 28, 2018
dd5c461
credit
unicolet Jun 6, 2018
1cb02a9
Added contribution credit
Ashex Jun 6, 2018
599e8ea
Add self to authors
reist Jun 7, 2018
437f8be
Fix fabfile with new Fabric v2
reist Jun 7, 2018
9210307
Make channel logic more robust
reist Jun 7, 2018
eba732d
Merge pull request #363 from seekingalpha/fabric-2
skoczen Jun 13, 2018
2da427a
Merge pull request #351 from Ashex/slack_attachments
skoczen Jun 13, 2018
22150eb
Merge pull request #362 from seekingalpha/fix-slack
skoczen Jun 13, 2018
bdd2e6b
Merge branch 'master' into issue_348_notify_for_remind
skoczen Jun 13, 2018
1e55530
Merge pull request #349 from unicolet/issue_348_notify_for_remind
skoczen Jun 13, 2018
490ebbd
Merge pull request #345 from wontonst/will_generate_project_backends
skoczen Jun 13, 2018
6af8104
Merge branch 'master' into slack_reconnect
skoczen Jun 13, 2018
fb4de83
Merge pull request #353 from Ashex/slack_reconnect
skoczen Jun 13, 2018
cfea0f5
Adds release notes, authors, and version bump for 2.1.3.
skoczen Jun 13, 2018
dac4b60
Adds libffi-dev
skoczen Jun 13, 2018
c56df36
Moves to `before_install`
skoczen Jun 13, 2018
16036e0
Adds libffi-dev to dockerfiles.
skoczen Jun 13, 2018
4b4c364
Pulls docker builds for now.
skoczen Jun 13, 2018
15c8a32
Just pulls deploy block from docker for simplicity.
skoczen Jun 13, 2018
920a1d1
Fixes comma string bug.
skoczen Jun 13, 2018
9daf781
Moves back to fabric 1 :(
skoczen Jun 13, 2018
a35c2a8
Pulls fabric 2 from release (for now).
skoczen Jun 13, 2018
aa85060
Fixes lcd syntax.
skoczen Jun 13, 2018
fb58579
Added Slack DM ability to self.say
Jul 24, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Remind me working on all platforms, adds mention_handle to take care …
…of platform-specific handle implementations.
  • Loading branch information
skoczen committed Oct 19, 2017
commit d1d342cb1f8f1aa664dc43ec6c957d7faf98c1e3
2 changes: 1 addition & 1 deletion will/__init__.py
Original file line number Diff line number Diff line change
@@ -1 +1 @@
VERSION = "2.0.1"
VERSION = "2.0.1-beta"
1 change: 1 addition & 0 deletions will/abstractions.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ class Person(Bunch):
REQUIRED_FIELDS = [
"id",
"handle",
"mention_handle",
"source",
"name",
"first_name"
Expand Down
3 changes: 3 additions & 0 deletions will/backends/io_adapters/hipchat.py
Original file line number Diff line number Diff line change
Expand Up @@ -173,6 +173,7 @@ def start_xmpp_client(self, xmpp_bridge_queue=None, backend_name=""):

self.nick = settings.HIPCHAT_NAME
self.handle = settings.HIPCHAT_HANDLE
self.mention_handle = "@%s" %settings.HIPCHAT_HANDLE

self.whitespace_keepalive = True
self.whitespace_keepalive_interval = 30
Expand Down Expand Up @@ -419,6 +420,7 @@ def people(self):
full_roster["%s" % (user['id'],)] = Person(
id=user["id"],
handle=user["mention_name"],
mention_handle="@%s" % user["mention_name"],
source=clean_for_pickling(user),
name=user["name"],
)
Expand All @@ -431,6 +433,7 @@ def people(self):
full_roster["%s" % (user['id'],)] = Person(
id=user["id"],
handle=user["mention_name"],
mention_handle="@%s" % user["mention_name"],
source=clean_for_pickling(user),
name=user["name"],
)
Expand Down
2 changes: 2 additions & 0 deletions will/backends/io_adapters/rocketchat.py
Original file line number Diff line number Diff line change
Expand Up @@ -268,6 +268,7 @@ def _rest_users_list(self):
total = 0

self.handle = settings.ROCKETCHAT_HANDLE
self.mention_handle = "@%s" % settings.ROCKETCHAT_HANDLE

people = {}

Expand All @@ -291,6 +292,7 @@ def _rest_users_list(self):
person = Person(
id=user['_id'],
handle=user['username'],
mention_handle="@%s" % user["username"],
source=clean_for_pickling(user)['username'],
name=user['name'],
timezone='GMT'
Expand Down
2 changes: 2 additions & 0 deletions will/backends/io_adapters/shell.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ class ShellBackend(StdInOutIOBackend):
partner = Person(
id="you",
handle="shelluser",
mention_handle="@shelluser",
source=Bunch(),
name="Friend",
)
Expand Down Expand Up @@ -85,6 +86,7 @@ def bootstrap(self):
self.me = Person(
id="will",
handle="will",
mention_handle="@will",
source=Bunch(),
name="William T. Botterton",
)
Expand Down
14 changes: 11 additions & 3 deletions will/backends/io_adapters/slack.py
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,11 @@ def send_message(self, event):
except:
pass

# Auto-link mention names
if data["text"].find("<@") != -1:
data["text"] = data["text"].replace("&lt;@", "<@")
data["text"] = data["text"].replace("&gt;", ">")

data.update({
"token": settings.SLACK_API_TOKEN,
"channel": channel_id,
Expand All @@ -250,7 +255,6 @@ def send_message(self, event):
)
resp_json = r.json()
if not resp_json["ok"]:
# print(resp_json)
assert resp_json["ok"]

def _map_color(self, color):
Expand Down Expand Up @@ -281,6 +285,8 @@ def _update_channels(self):

def _update_people(self):
people = {}
if not hasattr(self, "client"):
self.client = SlackClient(settings.SLACK_API_TOKEN)

self.handle = self.client.server.username

Expand All @@ -290,13 +296,15 @@ def _update_people(self):
user_timezone = v.tz
people[k] = Person(
id=v.id,
mention_handle="<@%s>" % v.id,
handle=v.name,
source=clean_for_pickling(v),
name=v.real_name,
)
if v.name == self.handle:
self.me = Person(
id=v.id,
mention_handle="<@%s>" % v.id,
handle=v.name,
source=clean_for_pickling(v),
name=v.real_name,
Expand All @@ -316,7 +324,7 @@ def _watch_slack_rtm(self):
if self.client.rtm_connect():
self._update_backend_metadata()

num_polls_between_updates = 20
num_polls_between_updates = 30 / settings.EVENT_LOOP_INTERVAL # Every 30 seconds
current_poll_count = 0
while True:
events = self.client.rtm_read()
Expand All @@ -328,7 +336,7 @@ def _watch_slack_rtm(self):

# Update channels/people/me/etc every 10s or so.
current_poll_count += 1
if current_poll_count < num_polls_between_updates:
if current_poll_count > num_polls_between_updates:
self._update_backend_metadata()
current_poll_count = 0

Expand Down
24 changes: 14 additions & 10 deletions will/mixins/schedule.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,10 @@
import time
import traceback
from apscheduler.triggers.cron import CronTrigger
from will.mixins.pubsub import PubSubMixin


class ScheduleMixin(object):
class ScheduleMixin(PubSubMixin, object):

def times_key(self, periodic_list=False):
if periodic_list:
Expand All @@ -31,15 +32,15 @@ def save_times_list(self, new_list, periodic_list=False):
return self.save(self.times_key(periodic_list=periodic_list), new_list)

# TODO: Create new version of this that's properly abstracted, instead of get_user_from_message
# def add_direct_message_to_schedule(self, when, content, message, *args, **kwargs):
# target_user = self.get_user_from_message(message)
# self.add_to_schedule(when, {
# "type": "direct_message",
# "content": content,
# "target_jid": target_user["jid"],
# "args": args,
# "kwargs": kwargs,
# })
def add_direct_message_to_schedule(self, when, content, message, target_user, *args, **kwargs):
# target_user = self.get_user_from_message(message)
self.add_to_schedule(when, {
"type": "direct_message",
"content": content,
"target_jid": target_user["jid"],
"args": args,
"kwargs": kwargs,
})

def add_room_message_to_schedule(self, when, content, room, *args, **kwargs):
self.add_to_schedule(when, {
Expand All @@ -50,6 +51,9 @@ def add_room_message_to_schedule(self, when, content, room, *args, **kwargs):
"kwargs": kwargs,
})

def add_outgoing_event_to_schedule(self, when, event, *args, **kwargs):
self.add_to_schedule(when, event, *args, **kwargs)

def add_to_schedule(self, when, item, periodic_list=False, ignore_scheduler_lock=False):
try:
while (
Expand Down
50 changes: 30 additions & 20 deletions will/plugin.py
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ def _trim_for_execution(self, message):
message.source_message.analysis = None
return message

def say(self, content, message=None, room=None, **kwargs):
def say(self, content, message=None, room=None, package_for_scheduling=False, **kwargs):
logging.info("self.say")
logging.info(content)

Expand Down Expand Up @@ -83,31 +83,35 @@ def say(self, content, message=None, room=None, **kwargs):
logging.info("backend: %s" % backend)

if backend:
logging.info("putting in queue: %s" % content)
self.publish("message.outgoing.%s" % backend, Event(
e = Event(
type="say",
content=content,
source_message=message,
kwargs=kwargs,
))
)
if package_for_scheduling:
return e
else:
logging.info("putting in queue: %s" % content)
self.publish("message.outgoing.%s" % backend, e)

def reply(self, event, content=None, **kwargs):
def reply(self, event, content=None, message=None, package_for_scheduling=False, **kwargs):
# Be really smart about what we're getting back.
if (
(
(event and hasattr(event, "will_internal_type") and event.will_internal_type == "Message") or
(event and hasattr(event, "will_internal_type") and event.will_internal_type == "Event")
) and type(content) == type("words")
):
# 1.x world - user passed a message and a string. Keep rolling.
# "1.x world - user passed a message and a string. Keep rolling."
pass
elif (
(
(content and hasattr(content, "will_internal_type") and content.will_internal_type == "Message") or
(content and hasattr(content, "will_internal_type") and content.will_internal_type == "Event")
) and type(event) == type("words")
):
# User passed the string and message object backwards, and we're in a 1.x world
# "User passed the string and message object backwards, and we're in a 1.x world"
temp_content = content
content = event
event = temp_content
Expand All @@ -116,24 +120,32 @@ def reply(self, event, content=None, **kwargs):
type(event) == type("words") and
not content
):
# We're in the Will 2.0 automagic event finding.
# "We're in the Will 2.0 automagic event finding."
content = event
event = self.message

else:
# Who knows what happened. Let it blow up.
# "No magic needed."
pass

# Be smart about backend.
message = event.data
if hasattr(event, "data"):
message = event.data
elif hasattr(self, "message") and hasattr(self.message, "data"):
message = self.message.data

if hasattr(message, "backend"):
self.publish("message.outgoing.%s" % message.backend, Event(
e = Event(
type="reply",
content=content,
topic="message.outgoing.%s" % message.backend,
source_message=message,
kwargs=kwargs,
))
)
if package_for_scheduling:
return e
else:
self.publish("message.outgoing.%s" % message.backend, e)

def set_topic(self, topic, message=None, room=None):

Expand All @@ -148,11 +160,9 @@ def set_topic(self, topic, message=None, room=None):
)

def schedule_say(self, content, when, message=None, room=None, *args, **kwargs):

content = self._prepared_content(content, message, kwargs)
if message is None or message["type"] == "groupchat":
rooms = self._rooms_from_message_and_room(message, room)
for r in rooms:
self.add_room_message_to_schedule(when, content, r, *args, **kwargs)
elif message['type'] in ('chat', 'normal'):
self.add_direct_message_to_schedule(when, content, message, *args, **kwargs)
packaged_event = self.reply(None, content=content, message=message, package_for_scheduling=True)
self.add_outgoing_event_to_schedule(when, {
"type": "message",
"topic": packaged_event.topic,
"event": packaged_event,
})
11 changes: 6 additions & 5 deletions will/plugins/productivity/remind.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,29 +4,30 @@

class RemindPlugin(WillPlugin):

@respond_to("(can|will you )?remind me to (?P<reminder_text>.*?) (at|on|in) (?P<remind_time>.*)?\?+")
@respond_to("(?:can |will you )?remind me(?: to)? (?P<reminder_text>.*?) (at|on|in) (?P<remind_time>.*)?\??")
def remind_me_at(self, message, reminder_text=None, remind_time=None):
"""remind me to ___ at ___: Set a reminder for a thing, at a time."""
parsed_time = self.parse_natural_time(remind_time)
natural_datetime = self.to_natural_day_and_time(parsed_time)

formatted_reminder_text = "@%(from_handle)s, you asked me to remind you %(reminder_text)s" % {
formatted_reminder_text = "%(mention_handle)s, you asked me to remind you %(reminder_text)s" % {
"mention_handle": message.sender.mention_handle,
"from_handle": message.sender.handle,
"reminder_text": reminder_text,
}
self.schedule_say(formatted_reminder_text, parsed_time, message=message)
self.say("%(reminder_text)s %(natural_datetime)s. Got it." % locals(), message=message)

@respond_to("(can|will you )?remind (?P<reminder_recipient>(?!me).*?) to (?P<reminder_text>.*?) (at|on|in) (?P<remind_time>.*)?\?+")
@respond_to("(?:can|will you )?remind (?P<reminder_recipient>(?!me).*?)(?: to) ?(?P<reminder_text>.*?) (at|on|in) (?P<remind_time>.*)?\??")
def remind_somebody_at(self, message, reminder_recipient=None, reminder_text=None, remind_time=None):
"""remind ___ to ___ at ___: Set a reminder for a thing, at a time for somebody else."""
parsed_time = self.parse_natural_time(remind_time)
natural_datetime = self.to_natural_day_and_time(parsed_time)

formatted_reminder_text = \
"@%(reminder_recipient)s, %(from_handle)s asked me to remind you %(reminder_text)s" % {
"%(reminder_recipient)s, %(from_handle)s asked me to remind you %(reminder_text)s" % {
"reminder_recipient": reminder_recipient,
"from_handle": message.sender.handle,
"from_handle": message.sender.mention_handle,
"reminder_text": reminder_text,
}

Expand Down
6 changes: 4 additions & 2 deletions will/scheduler.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,8 +118,10 @@ def check_scheduled_actions(self):
logging.critical("Scheduler run blew up.\n\n%s\nContinuing...\n", traceback.format_exc())

def run_action(self, task):
if task["type"] == "room_message":
self.bot.send_room_message(task["room"]["room_id"], task["content"], *task["args"], **task["kwargs"])

if task["type"] == "message" and "topic" in task:
self.publish(task["topic"], task["event"])
# self.bot.send_room_message(task["room"]["room_id"], task["content"], *task["args"], **task["kwargs"])
elif task["type"] == "direct_message":
user = self.bot.get_user_by_jid(task["target_jid"])
self.bot.send_direct_message(user["hipchat_id"], task["content"], *task["args"], **task["kwargs"])
Expand Down