Skip to main content
Version: 5.9.0

API Hooks

brainCloud allows you to modify the default behaviour of most API methods by configuring a Cloud Code script to run immediately before (pre) or after (post) the built-in API code.

brainCloud commons refers to these as Pre-Hooks and Post-Hooks.

brainCloud also allows you to specify a "Post-Fail-Hook" that gets called in the event of an API processing exception. These are very similar to "Post-Hooks" except that is passes the "errorData" to the script rather than "message".

Configuring API Hooks

API Hooks are configured in the Design Portal, from the Design | Cloud Code | API Hooks screen.

When configuring an API Hook you need to specify:

  • The Service and Operation to hook into
  • The Script to invoke
  • Whether it is a Pre (before), Post (after) or PostFail (after failure) scripts
  • Any additional Parameters that you'd like to send into the script at runtime (allows you to potentially configure the same script for use in different situations)

Pre-Hook Scripts

Pre-hook scripts are called prior to executing the specified API method. Pre-Hook scripts can:

  • Do some pre-processing prior to the API call
  • Modify the parameters being passed to the API
  • Abort the call if required

The data object sent to a pre-hook script contains the following standard elements:

Data ElementDescription
servicethe name of the brainCloud service
operationthe name of the brainCloud operation being invokes (related to, but not necessarily the same as, the method name)
messagethe arguments sent to the API call that is being modified
parmsthe static parameters defined as part of the hook configuration

Pre-hook scripts must return results in a specific format so that brainCloud can decide how/if to modify the behaviour of the API call.

The JSON map returned by the script may contain the following members:

Data ElementDescription
statusReturn 200 to continue processing, anything else to abort and return that status to the client
reasonCodeAdditional error info (numeric) returned if status != 200
errorMessageTextual error info returned if status != 200
messageOverrideTo override the parameters sent to the API call, return a messageOverride element with the replacement set of parameters

CreateContactPreHook - intercepts the creation of contacts


// Declare the result object
var result = {};
result.status = 200;

// Check to see if we're creating a contact
if (data.message.entityType == "contact")
{
// Clone the message passed in
result.messageOverride = JSON.parse(JSON.stringify(data.message));

// Modify the last name of the contact to be created
result.messageOverride.data.lastName = data.message.data.lastName + data.parms.suffix;

}

// Return the result;
result;

CreateContactPreHook - Test parameters for script editor

{
"service": "Entity",
"operation": "CreateEntity",
"message": {
"entityType": "contact",
"acl": {
"other": 0
},
"data": {
"firstName": "Bruce",
"lastName": "Wayne"
}
},
"parms": {
"suffix": "o"
}
}

CreateContactPreHook - parameters for API Hook Configuration

{
"suffix": "o"
}

Post-Hook Scripts

Post-hook scripts are called after executing a particular API call. Post-hook scripts can do some post-processing of the API results, optionally modifying the data that is returned to the client.

The data object sent to a post-hook script contains the following standard elements:

Data ElementDescription
servicethe name of the brainCloud service
operationthe name of the brainCloud operation being invokes (related to, but not necessarily the same as, the method name)
callingMessagethe original parameters sent into the API call
messagethe data results from the api call
parmsthe static parameters defined as part of the hook configuration

The script can return null to have no effect on the original return value. If not null, the returned object may include the following parameters:

Data ElementDescription
statusReturn 200 for ok, other for not
reasonCodeAdditional error info (numeric) returned if status != 200
errorMessageTextual error info returned if status != 200
dataReplacement results of the call

ReadContactPostHook - adds a fullName field when returning contacts

var result = {};

// If the entity being returned is a contact
if (data.message.entityType == "contact") {

// Clone the data being returned
result.data = JSON.parse(JSON.stringify(data.message));

// Add a fullName field
result.data.data.fullName = result.data.data.firstName + " " + result.data.data.lastName;

// Set the status to success
result.status = 200;

}

result;

ReadContactPostHook - Example Test Parameters for script editor

{
"service": "entity",
"operation": "READ",
"callingMessage": {
"service": "entity",
"operation": "READ",
"data": {
"entityId": "a186da71-18b5-410d-9afa-779d6610bddd"
}
},
"message": {
"entityId": "a186da71-18b5-410d-9afa-779d6610bddd",
"entityType": "contact",
"version": 1,
"data": {
"lastName": "Wayneo",
"firstName": "Bruce"
},
"acl": {
"other": 0
},
"createdAt": 1467259136127,
"updatedAt": 1467259136127
},
"parms": {}
}

Post-Fail-Hook Scripts

Post-fail-hook scripts are called after executing a particular API call and encountering a processing exception. Post-fail-hook scripts can do some post-processing of the API failure, optionally overriding the failure in the return to the client.

The data object sent to a post-fail-hook script contains the following standard elements:

Data ElementDescription
servicethe name of the brainCloud service
operationthe name of the brainCloud operation being invokes (related to, but not necessarily the same as, the method name)
callingMessagethe original parameters sent into the API call
errorDatathe reasonCode and errorMessage of the processing exception
parmsthe static parameters defined as part of the hook configuration

The script can return null or any empty object to proceeed with the failure as is. If not null, the returned object should include the following parameters:

Data ElementDescription
statusReturn 200 for error override to success, other for replacement error
reasonCodeReplacement error info (numeric) returned if status != 200
errorMessageReplacement error info returned if status != 200
dataReplacement results of the call if returning 200

UpdateCreatePostFailHook - creates a record if the update fails due non-existing record

var result = {};

// If the error is missing record
if (data.errorData.reasonCode == 40332) {

// create the record
var entityProxy = bridge.getEntityServiceProxy();
var createResult = entityProxy.create(data.callingMessage.entityType, data.callingMessage.data, data.callingMessage.acl);

// provide the result of the create
result['status'] = createResult.status;
result['data'] = createResult.data;

}

result;