Have Sanity Notify your team on Slack using Webtask.io
Connect Sanity's webhooks to a Slack channel with Webtask.io
Published
Knut MelvƦr
Head of Developer Community and Education
data:image/s3,"s3://crabby-images/20015/20015dc2b19a5a89c56eb456b159897f66376c1c" alt=""
Lots of people have been chopping up their infrastructures into small single purpose slices known as microservices. Cloud functions, or serverless functions if you like your buzzwords served hot, lets the rest of us easily use the same kind of architecture for everyday tasks.
In this post, we'll make a tiny, tiny service that relays a message to Slack every time someone either creates, updates or deletes a blog post in a Sanity Content Studio.Ā Sanity is a ābackendĀ as a serviceā that allows you to easily structure your content and get a graph-based realtime API instantly. It's pretty neat, and you can read about setting up a simple react-driven blog on it here.
1. Setting up the Webtask function
There are multiple services that offer easy-to-set-up serverless functions out there. The free dyno onĀ HerokuĀ can be used, as well asĀ stdlibĀ andĀ AWS lambda. But today, we're gonna useĀ Webtask.ioĀ by Auth0 as our serverless function provider. They all work pretty much the same though. You'll get an URL you can send HTTP-requests to, which runs a function that takes this request and a callback as itās parameters. It doesn't have a persistent state (unless you connect it to some sort of database or session provider) and is geared towards doing one thing.
If you have theĀ wt command line interfaceĀ (npm i -g wt-cli
), run to deploy this script on your own Webtask-account:
wt create https://raw.githubusercontent.com/kmelve/webtask-sanity-slack-update/master/webtask.js --name sanity-slack-update
You can alsoĀ copy-paste the codeĀ into the online editor atĀ webtask.io/make.
Make sure that the node dependencies (axios and @sanity/client) are installed. If you need to add these manually, do so by clicking the wrench button š§ and chooseĀ npm modules.
data:image/s3,"s3://crabby-images/1a847/1a8477b0cdc94221f003cba52ad18c85d0138fe7" alt="Make sure that npm modules are installed."
2. Create a Slack Incoming Webhook
Go toĀ the Slack custom integration configuration pageĀ and clickĀ Incoming WebhooksĀ andĀ Add configuration. Customize it as you want and remember to push the save button when you're done. Copy the webhook URL (looks like this:Ā https://hooks.slack.com/services/<code>/<code>/<code>
).
In your webtask editor ($ wt editor
Ā orĀ webtask.io/make, add the webhook as a secret key. Find the wrench icon and chooseĀ secretsĀ in the menu. Give the new key the nameĀ SLACK_WEBHOOK_URL
Ā and the webhook as the value. Now webtask knows where to send the update messages.
data:image/s3,"s3://crabby-images/e95e9/e95e957a1c95cad5cf491a2d66a1ed241e34bb65" alt="Adding secrets to Webtask."
And yeah, do keep your webhook URLs asĀ secrets. If someone gets a hold of them, they'll be able to flood your Slack channels with spam messages.
3. Add your webtask URL to Sanity webhooks
Copy the webtask-URL printed at the bottom line of the editor page (should look likeĀ https://wt-<SECRET CODE>.sandbox.auth0-extend.com/<SCRIPT NAME>
) and runĀ sanity hook create name-of-your-choosing
. Choose the dataset you want reporting on, and paste in your webtask-URL when prompted.
data:image/s3,"s3://crabby-images/3dacd/3dacdf9926f4179c4be05f2d749e4c8811373100" alt="All tied together"
Customize
Check out theĀ script on Github. You can easily customize it by either setting more parameters in the filter query (if you only want updates on a certain type etc), or by tweaking theĀ messaging formatting. If you are curious about Sanity,Ā check out the documentation.
Good luck serverlessin'!