How to receive notifications about your lab and job state changes
Artificial's platform includes a Job Monitoring Service designed to enhance the visibility of the status of your lab and its jobs. You can integrate this service with any automation tool or service (i.e., Zapier, Make, IFTTT, AWS Lambda, Google Cloud Functions, etc.) that supports webhooks. By doing so, you can receive timely notifications via Slack, Email, SMS, or any other apps your tool supports.
Currently, the Artificial Job Monitoring service provides notifications for when:
- Job actions go into "ERROR"
- Job actions go into "ASSISTANCE NEEDED"
- Jobs are completed
- System logs, including Information, Errors, and Warning
To receive notifications, you will need to:
- Configure your automation tool or service to provide a unique URL for webhooks: these instructions will vary depending on the platform of your choice.
- Set the webhook URL in Artificial:
- Go to your Artificial Instance and select "Settings"
- Go to the "Lab" section and select the lab for which you want to set up notifications.
- Under the "Lab Configuration" section, enter a new key with the following information:
- Name: WEBHOOK_URL
- Value: Paste the webhook URL
- Save it.
- Set up any rules for filtering notifications or changing the notification path: The event types that Artificial's Monitoring Job Service provides are:
- ASSISTANCE_NEEDED": for when jobs require manual help with an Assistant
- "HAS_ERROR": for when jobs go into an error state
- "JOB_COMPLETED": for when jobs are completed
- "SYSTEM_LOG": for system log messages (information, error, warning)
- To filter by severity, you can add a rule:
- Data: Severity
- Condition: (Text) Exactly Matches
- Data: Select if you want ERROR, INFO, WARNING
- To filter by severity, you can add a rule:
Zapier Set-up Instructions
Below, you can find instructions on how to connect Zapier with the Artificial Monitoring Service. To set it up, you will need to:
- Configure Zapier to receive notifications from Artificial
- Configure Zapier to route the incoming notifications to the services or people of your choice
Step 1: Configure Zapier to receive notifications from Artificial
After logging into your Zapier account, follow the below steps.
- Click on "Create" and select "New Zap"
- Click on the "Trigger" and select “Webhooks by Zapier”
- For the “Event” field, select “Catch Hook” and press Continue.
- Ignore the “Pick off a Child Key” field for now and press Continue again.
- Copy the webhook URL.
- Go to your Artificial Instance and select "Settings"
- Go to the "Lab" section, and select the lab you want to set up notifications for.
- Under the "Lab Configuration" section, enter a new key with the following information:
- Name: WEBHOOK_URL
- Value: Paste the webhook URL you copied in Zapier
- Save it.
- Test the trigger
- Run a job with an Assistant in that lab and test the trigger. You should see it come through!
- You can also generate your own requests.
- Run a job with an Assistant in that lab and test the trigger. You should see it come through!
Your Zap should now be configured to receive incoming notifications!
You will need to set the Lab Settings for each lab you want to receive notifications from. You can use the same URL for multiple labs or one URL per lab if you want to route notifications from different labs based on different rules.
Step 2: Configure Zapier to route notifications from Artificial
Depending on what notifications you want to route and where you want to route them, these instructions will vary depending on your need! Generally, you will want to follow the below steps
-
If testing the trigger is successful, press “Continue with Selected Record” or click on the block labeled “2. Action” in the workspace.
-
Select the “Path” action type under "Built-in tools."
- Configure the paths to determine the route for notifications by:
- Select"Path Rules" to bring up rule configuration options
- Configure the paths to determine the route for notifications by:
-
-
-
-
For "only continue if," set the following:
-
Field: Event Type
- Condition: (Text) Exactly Matches
- Insert Data...: You will select the Event Type that you want to be alerted of
- Options include:
- "ASSISTANCE_NEEDED": for when jobs require manual help with an Assistant
- "HAS_ERROR": for when jobs go into an error state
- "JOB_COMPLETED": for when jobs are completed
- "SYSTEM_LOG": for system log messages (information, error, warning)
- To filter by severity, you can add in an additional rule:
- Data: Severity
- Condition: (Text) Exactly Matches
- Data: Select if you want ERROR, INFO, WARNING
- To filter by severity, you can add in an additional rule:
- Options include:
-
-
-
-
It can be useful to trigger each type of notification through Artificial to get Zapier to see what data it provides.
-
-
-
-
Press Continue and confirm the path would have continued for this test data, and press Continue again.
-
-
-
-
Select the "Action" on the same Path.
-
Select the action type for your preferred notification such as - "Slack," “SMS by Zapier,” “Email by Zapier," "Teams", and more.
- Configure the action type to your needs.
- For the message, write out the text you'd like to use. By selecting "Catch Hook in Webhooks by Zapier," you can add job details such as the name, action name, and more. If you want to hyperlink text with the job URL, use the format <URL| text>
-
For more information about Zapier's capabilities, see their Help Center
Below are examples to show how to configure:
- Slack notifications to a channel for jobs that go into "Assistance Needed"
- Slack notifications directly to a user for jobs that go into "Error"
- Email notifications for system log events that are errors
Example: Setting up Slack channel notifications for jobs in "Assistance Needed"
-
If testing the trigger is successful, press “Continue with Selected Record” or click on the block labeled “2. Action” in the workspace.
-
Select the “Path” action type under "Built-in tools."
-
Select the "Path rules" block under Path A to bring up the rule configuration options.
-
For "only continue if," set the following:
-
Field: Event Type
- Condition: (Text) Exactly Matches
- Insert Data...: Event Type: ASSISTANCE_NEEDED
-
-
Press Continue
-
Confirm this path would have continued for this test data and press Continue again.
-
Select the "Action" on the same Path.
-
Select "Slack" for the action type.
-
You can also pick “SMS by Zapier” or “Email by Zapier” to send notifications via text or email.
-
-
For the “Event” field, select “Send Channel Message” and press Continue.
-
Connect your Slack account to send messages and press Continue.
- Fill out the following fields in the “Action” form:
- Channel - Select the channel to which you want to send notification messages.
- Message Text - write out the text you'd like to use. By selecting "Catch Hook in Webhooks by Zapier," you can add job details such as the name, action name, and more. If you want to hyperlink text with the job URL, use the format <URL| text>
- Send as a bot: Yes
- Bot Name - the name you want to send the message as; we’ve found it most helpful to send as the lab_name.
- Bot Icon - the icon that will show up next to the name; you can use any icon available in your slack instance (e.g. :fire:, :mechanical_arm:, or :octopus:)
- Include a link to this Zap? - No
- Press Continue
- Press “Test Zap” to send a Slack message based on your sample payload. You should see a new message in your selected channel.
Example: Setting up Slack messages for jobs in "Error"
-
Select the "Path rules" block under Path B to bring up the rule configuration options.
-
For "only continue if," set the following:
-
Field: Event Type
- Condition: (Text) Exactly Matches
- Insert Data...: Event Type: HAS_ERROR
-
-
Press Continue
-
Confirm this path would have continued for this test data and press Continue again.
-
Select the "Action" on the same Path.
-
Select "Slack" for the action type.
-
For the “Event” field, select “Send Direct Message" and press Continue.
-
Connect your Slack account to send messages and press Continue.
- Fill out the following fields in the “Action” form:
- To Username - select the user you want to send notification messages to.
- Message Text - write out the text you'd like to use. By selecting "Catch Hook in Webhooks by Zapier," you can add job details such as the name, action name, and more. If you want to hyperlink text with the job URL, use the format <URL| text>
- Send as a bot: Yes
- Bot Name - the name you want to send the message as; we’ve found it most helpful to send as the lab_name.
- Bot Icon - the icon that will show up next to the name; you can use any icon available in your Slack instance (e.g. :fire:, :mechanical_arm:, or :octopus:)
- Include a link to this Zap? - No
- Press Continue
- Press “Test Zap” to send a Slack message based on your sample payload. You should see a new message in your selected channel.
Known Issue:
In some cases, you may get duplicate error notifications, one for the Action that encountered an error and one for an "Error Handler" Action. In this case, we recommend adding a Filter to your Zap to ignore the "Error Handler" notification.