Webhooks
Retrieves all webhook configurations for the current account. Returns detailed information about each webhook including: - Webhook ID and name - URL endpoint - Subscribed events - Active/inactive status - Creation and last update timestamps - Delivery statistics (success/failure counts)
Only webhooks belonging to the authenticated user's account are returned. Requires owner role to view webhook configurations.
List of webhooks.
User is not authorized to list webhooks.
GET /sfp/api/webhooks HTTP/1.1
Host:
Authorization: Bearer JWT
Accept: */*
[
{
"id": "123e4567-e89b-12d3-a456-426614174000",
"name": "Deploy to Production",
"event": "release.published",
"provider": "github",
"config": {
"url": "text",
"method": "get",
"headers": {},
"filter": {}
},
"timeout": 10000,
"retryCount": 3,
"retryDelay": 60000,
"status": "active",
"lastDeliveryAt": "2025-01-22T07:42:09.000Z",
"errorCount": 0,
"createdBy": "[email protected]",
"createdAt": "2025-01-22T07:42:09.000Z",
"updatedAt": "2025-01-22T07:42:09.000Z"
}
]
Creates a new webhook configuration for receiving notifications about system events. Webhooks allow external systems to be notified when specific events occur within the SFP platform.
The webhook configuration includes:
- URL endpoint to receive HTTP POST requests
- Events to subscribe to (e.g., deployment.started, deployment.completed)
- Optional headers for authentication
- Active/inactive status
- Retry configuration for failed deliveries
Each webhook is associated with the creating account and can only be managed by users with owner role in that account.
Repository identifier in format owner/repo
octocat/hello-world
URL where GitHub should send webhook events
https://example.com/webhook
The webhook has been successfully created.
Invalid webhook configuration.
User is not authorized to create webhooks.
POST /sfp/api/webhooks HTTP/1.1
Host:
Authorization: Bearer JWT
Content-Type: application/json
Accept: */*
Content-Length: 206
{
"name": "Simple Webhook",
"event": "user.created",
"provider": "http",
"config": {
"url": "https://api.example.com/webhook",
"method": "post",
"headers": {
"Content-Type": "application/json",
"X-API-Key": "your-api-key"
}
}
}
{
"id": "123e4567-e89b-12d3-a456-426614174000",
"name": "Deploy to Production",
"event": "release.published",
"provider": "github",
"config": {
"url": "text",
"method": "get",
"headers": {},
"filter": {}
},
"timeout": 10000,
"retryCount": 3,
"retryDelay": 60000,
"status": "active",
"lastDeliveryAt": "2025-01-22T07:42:09.000Z",
"errorCount": 0,
"createdBy": "[email protected]",
"createdAt": "2025-01-22T07:42:09.000Z",
"updatedAt": "2025-01-22T07:42:09.000Z"
}
Retrieves detailed information about a specific webhook configuration. Returns comprehensive webhook details including: - Complete configuration (URL, headers, events) - Delivery statistics and recent delivery history - Active/inactive status and last state change - Retry configuration and backoff settings
This endpoint is useful for debugging webhook delivery issues or verifying webhook configuration. Requires owner role.
Webhook ID
The webhook configuration.
User is not authorized to view webhooks.
Webhook not found.
GET /sfp/api/webhooks/{id} HTTP/1.1
Host:
Authorization: Bearer JWT
Accept: */*
{
"id": "123e4567-e89b-12d3-a456-426614174000",
"name": "Deploy to Production",
"event": "release.published",
"provider": "github",
"config": {
"url": "text",
"method": "get",
"headers": {},
"filter": {}
},
"timeout": 10000,
"retryCount": 3,
"retryDelay": 60000,
"status": "active",
"lastDeliveryAt": "2025-01-22T07:42:09.000Z",
"errorCount": 0,
"createdBy": "[email protected]",
"createdAt": "2025-01-22T07:42:09.000Z",
"updatedAt": "2025-01-22T07:42:09.000Z"
}
Permanently deletes a webhook configuration. This action: - Stops all future event deliveries to this webhook - Cancels any pending retries for failed deliveries - Removes the webhook configuration from the system - Retains historical delivery logs for audit purposes
This operation cannot be undone. The webhook must belong to the authenticated user's account. Requires owner role.
Webhook ID
The webhook has been successfully deleted.
User is not authorized to delete webhooks.
Webhook not found.
DELETE /sfp/api/webhooks/{id} HTTP/1.1
Host:
Authorization: Bearer JWT
Accept: */*
No content
Updates an existing webhook configuration. All fields are optional - only provided fields will be updated. Common updates include: - Changing the endpoint URL - Adding/removing subscribed events - Updating authentication headers - Enabling/disabling the webhook - Modifying retry configuration
The webhook must belong to the authenticated user's account. Updates take effect immediately for new event deliveries. Requires owner role.
Webhook ID
A human-readable name for the webhook
Deploy to Production
The event that triggers this webhook
release.published
Provider-specific configuration
{"repository":"owner/repo","workflow":"deploy.yml","ref":"main"}
Timeout in milliseconds
10000
Number of retry attempts
3
Delay between retries in milliseconds
60000
Current status of the webhook
active
Possible values: The webhook has been successfully updated.
Invalid webhook configuration.
User is not authorized to update webhooks.
Webhook not found.
PATCH /sfp/api/webhooks/{id} HTTP/1.1
Host:
Authorization: Bearer JWT
Content-Type: application/json
Accept: */*
Content-Length: 145
{
"config": {
"url": "https://new-api.example.com/webhook",
"method": "post",
"headers": {
"Content-Type": "application/json",
"X-New-Header": "new-value"
}
}
}
{
"id": "123e4567-e89b-12d3-a456-426614174000",
"name": "Deploy to Production",
"event": "release.published",
"provider": "github",
"config": {
"url": "text",
"method": "get",
"headers": {},
"filter": {}
},
"timeout": 10000,
"retryCount": 3,
"retryDelay": 60000,
"status": "active",
"lastDeliveryAt": "2025-01-22T07:42:09.000Z",
"errorCount": 0,
"createdBy": "[email protected]",
"createdAt": "2025-01-22T07:42:09.000Z",
"updatedAt": "2025-01-22T07:42:09.000Z"
}
Manually queues a custom payload for delivery to a specific webhook. This endpoint is useful for: - Testing webhook connectivity and payload handling - Replaying failed deliveries with corrected data - Sending custom notifications outside normal event flow
The payload is queued for asynchronous delivery and will follow the webhook's retry configuration if delivery fails. Returns a delivery ID for tracking. Requires owner or application role.
Webhook ID
The payload to deliver to the webhook endpoint
{"event":"deployment","environment":"production","status":"success"}
Webhook delivery has been queued
POST /sfp/api/webhooks/{id}/deliver HTTP/1.1
Host:
Authorization: Bearer JWT
Content-Type: application/json
Accept: */*
Content-Length: 104
{
"payload": {
"event": "user.notification",
"message": "Hello World",
"timestamp": "2025-08-09T05:56:43.260Z"
}
}
Webhook delivery has been queued
{
"success": true,
"statusCode": 1,
"error": "text",
"duration": 1,
"message": "text",
"providerDetails": {
"method": "get",
"url": "text",
"headers": {},
"filtered": true,
"queued": true,
"deliveryId": "text",
"notFound": true,
"eventName": "text",
"webhookId": "text",
"reason": "text",
"response": {}
}
}
Triggers webhook deliveries for all active webhooks subscribed to a specific event. This endpoint: - Finds all active webhooks subscribed to the specified event - Queues the payload for delivery to each matching webhook - Processes deliveries asynchronously with configured retry policies - Returns delivery IDs for tracking each webhook delivery
This is the primary mechanism for event-driven webhook notifications in the system. Useful for manual event triggering or system integrations. Requires owner or application role.
The event that triggers the webhooks
document.created
The event payload
{"id":"doc123","name":"example.md","type":"markdown","createdBy":"[email protected]"}
Webhook deliveries have been queued
POST /sfp/api/webhooks/trigger HTTP/1.1
Host:
Authorization: Bearer JWT
Content-Type: application/json
Accept: */*
Content-Length: 109
{
"event": "user.created",
"payload": {
"userId": "123",
"action": "created",
"timestamp": "2025-08-09T05:56:43.260Z"
}
}
Webhook deliveries have been queued
[
{
"success": true,
"statusCode": 1,
"error": "text",
"duration": 1,
"message": "text",
"providerDetails": {
"method": "get",
"url": "text",
"headers": {},
"filtered": true,
"queued": true,
"deliveryId": "text",
"notFound": true,
"eventName": "text",
"webhookId": "text",
"reason": "text",
"response": {}
}
}
]
Was this helpful?