Slack Interaction Routing Using Django Resolvers
Developing a integration for Slack is not easy task. Slack's API is pretty great and allows a lot of freedom. But when you start adding buttons, integrations and, more recently, interactions with blocks your code will quickly become a never-ending list of if/the/else clauses.
While developing integrations the new slack interactions we were writing were becoming unmangeable. For every new button there would be a new if block_id == "feedback-button"
so new solutions needed to be found.
The best one was using Django's routing mechanism to treat the interactions as urls on a website. Once this mindset was introduced everything became much easier. Let's start with some examples. First the main methods that make this possible:
# try the various urlconf files we have
=
return
continue
return
continue
As the method signatures show the slack_resolver
method receives the current url being processed and return the resolver to call the view's function.
The other method slack_reverse
makes sure we can pass a Django url name and get a url back.
The next step is just to defined url using Django's urlpatterns
. An example could be:
block_urls.py
=
onboarding_actions
is a simple function that returns JSON formatted for Slack.
This approach really sped up development on Slack and made our code be much less problematic.
Testing this approach is also much simpler.
There are some other nuances that weren't mentioned here. If you have any questions at all you can email me.