Create a webhook
POST
/webhooks(.:format)
Creates a new webhook. The provided URL should respond with a 200 HTTP status. After
creation, the URL will receive notifications when events on documents in the
administration occur. It is also possible to subscribe to certain events by adding an array
with events you would like to receive notifications from.
We strongly recommend that you use a secure HTTPS endpoint for receiving payload from Moneybird.
If you use unencrypted HTTP, anyone on the network may be able to listen in on sensitive information like contacts and invoices.
Parameters
Parameter
Type
Description
url
String
Required
enabled_events
Array[string]
Example: creates a webhook
Request
curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
-XPOST \
-d '{"url":"http://www.mocky.io/v2/5185415ba171ea3a00704eed"}' \
https://moneybird.com/api/v2/123/webhooks.json
data = { :url => "http://www.mocky.io/v2/5185415ba171ea3a00704eed" }
RestClient . post (
"https://moneybird.com/api/v2/123/webhooks.json" , data ,
{ authorization: "Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" }
)
Response
Status: 201 Created
{
"id" : "440890555240547792" ,
"administration_id" : 123 ,
"url" : "http://www.mocky.io/v2/5185415ba171ea3a00704eed" ,
"enabled_events" : [],
"last_http_status" : null ,
"last_http_body" : null ,
"token" : "JLf7eUksvxFSpUbM5gWmDKZD"
}
Example: creates a webhook that is subscribed to enabled_events
Request
curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
-XPOST \
-d '{"url":"http://www.mocky.io/v2/5185415ba171ea3a00704eed","enabled_events":["contact_created"]}' \
https://moneybird.com/api/v2/123/webhooks.json
data = { :url => "http://www.mocky.io/v2/5185415ba171ea3a00704eed" ,
:enabled_events => [ "contact_created" ]}
RestClient . post (
"https://moneybird.com/api/v2/123/webhooks.json" , data ,
{ authorization: "Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" }
)
Response
Status: 201 Created
{
"id" : "440890555376862676" ,
"administration_id" : 123 ,
"url" : "http://www.mocky.io/v2/5185415ba171ea3a00704eed" ,
"enabled_events" : [
"contact_created"
],
"last_http_status" : null ,
"last_http_body" : null ,
"token" : "fDPjpPqhYzSVQZwxYr1kMMQ9"
}
Example: returns an error when events is provided
Request
curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
-XPOST \
-d '{"url":"http://www.mocky.io/v2/5185415ba171ea3a00704eed","events":["contact_created"]}' \
https://moneybird.com/api/v2/123/webhooks.json
data = { :url => "http://www.mocky.io/v2/5185415ba171ea3a00704eed" ,
:events => [ "contact_created" ]}
RestClient . post (
"https://moneybird.com/api/v2/123/webhooks.json" , data ,
{ authorization: "Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" }
)
Response
Status: 400 Bad Request
{
"error" : "'events' has been removed from webhooks, use 'enabled_events'" ,
"symbolic" : {
"events" : "removed"
}
}
Example: returns an error when fields are not provided
Request
curl -s -H "Content-Type: application/json" -H "Authorization: Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" \
-XPOST \
-d '{}' \
https://moneybird.com/api/v2/123/webhooks.json
data = {}
RestClient . post (
"https://moneybird.com/api/v2/123/webhooks.json" , data ,
{ authorization: "Bearer 84ec207ad0154a508f798e615a998ac1fd752926d00f955fb1df3e144cba44ab" }
)
Response