Zapier#
This section will walk through the steps needed to set up Zapier webhook to receive updates from Determined.
The steps to set up Zapier webhook are:
Creating a Zap with Webhook#
First, you need to create a Zap with webhook. Visit Zapier, signup if you haven’t already, and click on the Create Zap button.
Select Webhooks by Zapier as trigger Catch Raw Hook as event. Using Catch Raw Hook intead of Catch Hook because headers are needed to verify each webhook request.
Note
You need to upgrade to premium account to access Webhooks by Zapier
data:image/s3,"s3://crabby-images/e9287/e9287a9731120d4bd6d812c4faa3f5d8246d455e" alt="Zapier Webhooks page displaying Catch Raw Hook event selected"
Setting up the Webhook in Determined#
Then, you need to create a webhook in Determined using the Webhook URL from Zapier.
data:image/s3,"s3://crabby-images/8cfd6/8cfd6d57f6a8d6f34c62b664ed095b8e77d7c4c2" alt="This is where your webhook URL displays in Zapier"
Navigate to /det/webhooks
or click on the “Webhooks” item in navigation side menu, then click
the New Webhook button in the top right corner of the page.
data:image/s3,"s3://crabby-images/2373f/2373f0b508cb88dd450cc2166b3d8ed48c67b704" alt="Webhooks page displaying New Webhook fields including triggers."
Paste the Webhook URL that was copied from Zapier in the URL field. Select Default for the webhook type and then select the triggers that you want to receive notifications for. Finally, select Create Webhook and your webhook will be created.
Testing the Webhook#
To send a test payload, click on the triple dots on the right of webhook record and click on Test Webhook.
data:image/s3,"s3://crabby-images/d9784/d978457a802d808677acf180bf3fc268e349e5dc" alt="Webhooks page displaying where to find the Test Webhook action."
Then navigate back to Zapier and click on Test Trigger, then you should be able to see the test request.
data:image/s3,"s3://crabby-images/6d359/6d359ebcd0b3b502ce1334be4dd340014e4ae2ea" alt="Zapier Webhooks request page showing that your request was found."
Verifing the Signature#
Refer to Security and Signed Payload for the details behind verifing signature.
In Zapier, you can use Code by Zapier to compute signature based on payload and timestamp, then compare it with the signature in the request to verify each request.
Add a new action and choose Code by Zapier, select Run Python as an example.
data:image/s3,"s3://crabby-images/50098/5009811e4c32be1647023c5970503cd8e94a3bd4" alt="Code by Zapier action with a Run Python event"
Construct input data as following:
webhook_signing_key: match the
webhook_signing_key
in Determined.timestamp:
X-Determined-AI-Signature-Timestamp
from request header.signature:
X-Determined-AI-Signature
from request header.payload: raw body of request.
data:image/s3,"s3://crabby-images/c2dd0/c2dd033a85ea002ff1e6eddbcf88caf936576a3c" alt="Code by Zapier showing set up action input data like webhook_signing_key"
Input code as following:
import hmac, hashlib, json
signing_key = input_data['webhook_signing_key']
timestamp = input_data['timestamp']
signature = input_data['signature']
payload = json.loads(input_data['payload'])
calculated_signature = hmac.new(signing_key.encode(), f"{timestamp},{payload}".encode(), digestmod=hashlib.sha256).hexdigest()
if calculated_signature == signature:
return {"result": "PASS", "payload": payload}
return {"result": "Signature cannot be verified, request might not be legit"}
Under Test Action, test the code above, you should be able to see that verification has passed.
data:image/s3,"s3://crabby-images/2bae2/2bae266b4933ce465751429e86868e3e878368ac" alt="Code by Zapier showing that a Run Python event was sent"
Configuring Destination#
Finally, you can configure where to proceed under each scenario by adding more actions. For example, send out an alert when verification fails, or send out an email with experiment information when verification pass.