/get_webhooks

Gets the list of generated webhooks with detailed information.

Requests

The request body at this endpoint is the header_msg JSON object.

Authorization / Authentication

Apps using Access Token Authorization

Use a valid access token in an Authorization: Bearer request header.

See Authenticating with an Access Token for more details.

Apps using ECDSA Authentication

Only authsignature header is required for this request.

See the section on ECDSA Authentication for more detail about ECDSA signature generation.

POST /0.2/get_webhooks HTTP/1.1
sandbox.silamoney.com
Content-Type: application/json
// if using OAuth2
Authorization: Bearer [GENERATED JWT TOKEN HERE]
// if using ECDSA
authsignature: [GENERATED AUTHSIGNATURE HEX STRING HERE]

{
  "header": {
    "created": 1234567890, 
    "app_handle": "app_handle",
    "version": "0.2", 
    "reference": "<your unique id>"
  }, 
  "message": "header_msg",
  "search_filters": {
    "uuid": "some UUID string assigned by Sila",
    "delivered": true,
    "sort_ascending": false,
    "event_type": 'kyc_update',
    "endpoint_name": 'receiver'
    "user_handle": 'user',
    "start_epoch": 1234567860,
    "end_epoch": 1234567891,
    "page": 1,
    "per_page": 20   
  }
}

***

HTTP/1.1 200 OK

{
    "success": true,
    "customer_reference_id": "<your unique id>",
    "sila_reference_id": "sila_assigned_id",
    "status": "SUCCESS",
    "response_time_ms": "171",  
    "page": 1,
    "returned_count": 2,
    "total_count": 2,
    "webhooks": [
         {
            "user_handle": "user",
            "uuid": "1dc1294f-8100-40e3-8240-49679a10576a",
            "delivered": false,
            "details": {              
              "kyc": "cd449904-1de6-45b6-89f6-634ac8cf0f10",
              "entity": "user"
              "outcome": "pending",
            },
            "attempts": 1,
            "responses": [
                {
                  "created": "1634577920",
                  "status_code": 200
                }
            ],
            "processing": true,                        
            "created_epoch": 1582754399,
            "last_update_epoch": 1582754414,
            "next_attempt_epoch": "",           
            "event_type": "kyc_update",
            "endpoint_name": "receiver_2",
            "endpoint_url": "http://localhost/receiver-2"                      
        },
        {
            "user_handle": "user",
            "uuid": "d830a9d9-1e05-42e5-8a38-6c4598e49789",
            "delivered": false,
            "details": {              
              "kyc": "cd449904-1de6-45b6-89f6-634ac8cf0f10",
              "entity": "user"
              "outcome": "passed",
            },
            "attempts": 1,
            "responses": "responses": [
                {
                  "created": "1634577920",
                  "status_code": 200
                }
            ],
            "processing": true,                        
            "created_epoch": 1582784399,
            "last_update_epoch": 1582794414,
            "next_attempt_epoch": "",           
            "event_type": "kyc_update",
            "endpoint_name": "receiver_2",
            "endpoint_url": "http://localhost/receiver-2"                      
        },
    ]
}
var searchFilters = {
    "uuid": "some UUID string assigned by Sila",
    "delivered": true,
    "sort_ascending": false,
    "event_type": 'kyc_update',
    "endpoint_name": 'receiver'
    "user_handle": 'user',
    "start_epoch": 1234567860,
    "end_epoch": 1234567891,
    "page": 1,
    "per_page": 20   
};
const res = await Sila.getWebhooks(userHandle, userPrivateKey, searchFilters);

// Success Response Object
console.log(res.statusCode); // 200
console.log(res.data.status);
console.log(res.data.success); // TRUE
console.log(res.data.page); // The # of page
console.log(res.data.returned_count); // # of wallets returned
console.log(res.data.total_count); // Total # of wallets
console.log(res.data.webhooks); // Wallets array
console.log(res.data.webhooks[0].created_epoch);
console.log(res.data.webhooks[0].last_update_epoch);
console.log(res.data.webhooks[0].next_attempt_epoch);
console.log(res.data.webhooks[0].event_type);
console.log(res.data.webhooks[0].endpoint_name);
console.log(res.data.webhooks[0].endpoint_url);
console.log(res.data.webhooks[0].uuid);
console.log(res.data.webhooks[0].delivered);
console.log(res.data.webhooks[0].endpoint_name);
console.log(res.data.webhooks[0].details);
console.log(res.data.webhooks[0].attempts);
console.log(res.data.webhooks[0].responses);
console.log(res.data.webhooks[0].processing);
console.log(res.data.webhooks[0].user_handle);
WebhookSearchFilters searchFilters = new WebhookSearchFilters();
        searchFilters.setUuid("some UUID string assigned by Sila");
        searchFilters.setDelivered(true);
        searchFilters.setEventType("kyc_update");
        searchFilters.setSortAscending(false);
        searchFilters.setEndpointName("receiver");
        searchFilters.setUserHandle("user handle");
        searchFilters.setStartEpoch(1234567860);
        searchFilters.setEndEpoch(1234567891);
        searchFilters.setPage(1);
        searchFilters.setPerPage(20);
        ApiResponse response = api.getWebhooks("user handle", searchFilters);

        System.out.println(response.getStatusCode()); // 200
        GetWebhooksResponse parsedResponse = (GetWebhooksResponse) response.getData();
        System.out.println(parsedResponse.getSuccess()); // true
        System.out.println(parsedResponse.getStatus()); // SUCCESS
        System.out.println(parsedResponse.getWebhooks().get(0).getUserHandle());
        System.out.println(parsedResponse.getWebhooks().get(0).getUuid());
        System.out.println(parsedResponse.getWebhooks().get(0).getDelivered());
        System.out.println(parsedResponse.getWebhooks().get(0).getDetails().getKyc());
        System.out.println(parsedResponse.getWebhooks().get(0).getDetails().getEntity());
        System.out.println(parsedResponse.getWebhooks().get(0).getDetails().getOutcome());
        System.out.println(parsedResponse.getWebhooks().get(0).getAttempts());
        System.out.println(parsedResponse.getWebhooks().get(0).getResponses());
        System.out.println(parsedResponse.getWebhooks().get(0).getProcessing());
        System.out.println(parsedResponse.getWebhooks().get(0).getCreatedEpoch());
        System.out.println(parsedResponse.getWebhooks().get(0).getLastUpdateEpoch());
        System.out.println(parsedResponse.getWebhooks().get(0).getNextAttemptEpoch());
        System.out.println(parsedResponse.getWebhooks().get(0).getEventType());
        System.out.println(parsedResponse.getWebhooks().get(0).getEndpointName());
        System.out.println(parsedResponse.getWebhooks().get(0).getEndpointUrl());
        System.out.println(parsedResponse.getPagination().getReturnedCount());
        System.out.println(parsedResponse.getPagination().getTotalCount());
        System.out.println(parsedResponse.getPagination().getCurrentPage());
        System.out.println(parsedResponse.getPagination().getTotalPages());
payload = {
    "user_handle": "user.silamoney.eth"           
}

response = User.get_webhooks(silaApp, payload, eth_private_key)

### Success Response Object
{
    'success': True,
    'webhooks': [{
        'created_epoch': 1635760689,
        'last_update_epoch': 1635760689,
        'next_attempt_epoch': None,
        'event_type': 'kyc_update',
        'endpoint_name': 'kyc_update1',
        'endpoint_url': 'http://www.silamoney.com',
        'uuid': 'f0b9ae40-13fb-41e6-a6aa-9153a33c9abf',
        'delivered': True,
        'details': {
            'kyc': '83206f2f-af98-4473-9c90-6c36b3c7c7db',
            'entity': 'pahujxetoe',
            'outcome': 'passed'
        },
        'attempts': 1,
        'responses': [{
            'created': '1635760689',
            'status_code': 200
        }],
        'processing': False,
        'user_handle': 'pahujxetoe'
    }],
    'page': 1,
    'returned_count': 1,
    'total_count': 1,
    'pagination': {
        'returned_count': 1,
        'total_count': 1,
        'current_page': 1,
        'total_pages': 1
    },
    'status': 'SUCCESS',
    'status_code': 200
}

### Failure Response Object
{
    status: 'FAILURE'
}
$privateKey = "user private key";
$filters = new SearchFilters();
$response = $client->api->getWebhooks($privateKey, $filters);

echo $response->getStatusCode();
echo $response->getData()->status;
echo $response->getData()->success;
WebhooksSearchFilters searchFilters = new WebhooksSearchFilters();
ApiResponse<object> response = api.GetWebhooks(userHandle, searchFilters);
// searchFilters is optional 


// Success Response Object
Console.WriteLine(response.StatusCode); // 200            
Console.WriteLine(((GetWebhooksResponse)response.Data).Success); // true
Console.WriteLine(((GetWebhooksResponse)response.Data).Page); // Page number
Console.WriteLine(((GetWebhooksResponse)response.Data).ReturnedCount); // Returned count
Console.WriteLine(((GetWebhooksResponse)response.Data).TotalCount); // Total count.
Console.WriteLine(((GetWebhooksResponse)response.Data).Status); // SUCCESS
Console.WriteLine(((GetWebhooksResponse)response.Data).Pagination); // Pagination   

Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Attempts); // Attempts            
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].CreatedEpoch); // Created epoch
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Delivered); // Delivered          
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].EndpointName); // Endpoint name
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].EndpointUrl); // Endpoint url
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].EventType); // Event type
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].LastUpdateEpoch); // Last update epoch
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].NextAttemptEpoch); // Next attempt epoch
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Processing); // Processing            
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].UserHandle); // User handle   
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Uuid); // uuid   

Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Responses[0].Created); // Responses created
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Responses[0].StatusCode); // Responses statuscode

Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.Account); // Account
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.AccountName); // Account Name
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.Entity); // Entity
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.KYC); // KYC
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.Transaction); // Transaction
Console.WriteLine(((GetWebhooksResponse)response.Data).Webhooks[0].Details.TransactionType); // TransactionType
KeyTypeDescription
headerJSON objectRequired.

Requires these keys in JSON format:

created
app_handle

See the /check_handle endpoint for the complete list of fields in this object.
search_filtersJSON objectOptional. Allows filtering results.
search_filters.
uuid (Webhook ID)
StringOptional. Webhook ID. The format should be a UUID string.
Example: 5167160d-9d12-4fa8-a8cd-302507782de0
search_filters.
sort_ascending
BooleanOptional. Default: true
Example: false
search_filters.
start_epoch
IntegerOptional. UTC Unix Timestamp. Minimum 0
Example: 1631610941
search_filters.
end_epoch
IntegerOptional. UTC Unix Timestamp. Minimum 0
Example: 1631610950
search_filters.pageIntegerOptional. Min Length 1 Default: 1
search_filters.
per_page
IntegerOptional. Min 1
Max 100
Default per page 20
search_filters.user_handleStringOptional. Webhook user handle.
search_filters.deliveredBooleanOptional. Webhook delivere to endpoint.
Example: false
search_filters.event_typeStringOptional. Webhook trigger type.
Example: kyc_update
search_filters.endpoint_nameStringOptional. Webhook endpoint name.
Example: receiver_2

Responses

Status Codesuccess AttributeDescription
200trueSuccessfully fetched array of webhooks.
400falseBad request format - check validation_details for more information.
401falseauthsignature header was absent or incorrect.
KeyTypeDescription
uuidUUIDAn auto-generated ID for webhook.
detailsJSONThe event-specific payload will be included in the request.
attemptsIntegerThe number of attempts
next_attempt_epochIntegerThe next time that this Event should be attempted, if any
responsesJSONA JSON object structured as [{"created":TIMESTAMP,"status_code":RESPONSE_CODE}
deliveredBooleanTrue when Webhook returns a 200 status code. Will be set to FALSE if the maximum number of attempts on the related Webhook has been reached and no 200 response has been received. default Null
processingBooleanWebhook in progress. Default FALSE
user_handleStringUser
endpoint_nameStringWebhook endpoint name
endpoint_urlStringWebhook endpoint url
event_typeStringWebhook event type