The Notify API allows you to interact with Notify calls and SMS messages using scripts.

Access the global Notify class and its associated methods in the SNC namespace.

Notify - call(String notifyPhoneNumber, String toPhoneNumber, GlideRecord conferenceCall, GlideRecord conferenceCallRecord, String userSysId, String groupSysId, GlideRecord sourceRecord)

Calls the specified E.164-compliant telephone number.

In addition, this method can automatically add the specified phone number to a specified conference call.

Table 2. Returns
Type Description
void

Example

This example illustrates how to initiate a call to another phone number.

var from = '+14048007337';
var to = '+31646810495';

// set up call
new SNC.Notify().call(from, to);

Example

This example illustrates how to initiate a call to list of telephone numbers and automatically join those numbers into a new conference call.

var notify = new SNC.Notify();
var from = '+14041234567';
var participants = ['+31612345678', '+31623456789', '+31687654321'];

// set up a conference call
var conferenceCall = notify.conferenceCall();

// set up the outbound calls for all conference call participants
for (var i in participants) {
    var to = participants[i];
    notify.call(from, to, conferenceCall);
}

Example

This example illustrates how to initiate a new conference call.

SNC.Notify.call('+15413970605', '+91406XXXXXXX', SNC.Notify.conferenceCall(), null, null, null);

Example

This example illustrates how to initiate new a conference call using a user record.

var sysUserGr = new GlideRecord('sys_user');
sysUserGr.get('active conference sys id');
 
if (conferenceGr.isValid) {
    SNC.Notify.call('+15413970605', '+91406XXXXXXX', SNC.Notify.conferenceCall(), sysUserGr.getUniqueValue(), null, null);
}

Example

This example illustrates how to initiate a new conference call with a user, group, and source record.

var sysUserGr = new GlideRecord('sys_user');
sysUserGr.get('active sys user sys id');
 
var sysUserGroupGr = new GlideRecord('sys_user_group');
sysUserGroupGr.get('active sys user group sys id');
 
var incidentGr = new GlideRecord('incident');
incidentGr.get('incident sys_id');
 
if (conferenceGr.isValid) {
    SNC.Notify.call('+15413970605', '+91406XXXXXXX',
        SNC.Notify.conferenceCall(),
        sysUserGr.getUniqueValue(),
        sysUserGroupGr.getUniqueValue(),
        incidentGr.getUniqueValue());
}

Scoped equivalent

To use the call() method in a scoped application, use the corresponding scoped method: NotifyScoped - call().

Notify - conferenceCall(GlideRecord sourceRecord)

Creates a new conference call GlideRecord.

Table 3. Parameters
Name Type Description
sourceRecord GlideRecord Optional. Record that initiated the request to create the conference call. Used to populate the source and table fields on notify_conference_call record.
Table 4. Returns
Type Description
GlideRecord New Notify conference call [notify_conference_call] record.

Example

var notify = new SNC.Notify();
var from = '+14041234567';
var participants = ['+31612345678', '+31623456789', '+31687654321'];

// set up a conference call
var conferenceCall = notify.conferenceCall();

// set up the outbound calls for all conference call participants
for (var i in participants) {
    var to = participants[i];
    notify.call(from, to, conferenceCall);
}

Scoped equivalent

To use the conferenceCall() method in a scoped application, use the corresponding scoped method: NotifyScoped - conferenceCall().

Notify - dequeueCall(GlideRecord callRecord)

Resumes a call after it was put in a queue (on hold).

Use this method to resume calls that were put in a queue with the queueCall() method.

Table 5. Parameters
Name Type Description
callRecord GlideRecord A GlideRecord object on the Notify Call [notify_call] table with the held call you want to resume.
Table 6. Returns
Type Description
void

Example

The following example shows how to reactivate a call that was put on hold.

var notifyCallGr = new GlideRecord('notify_call');
notifyCallGr.get('active participant sys id');
 
if (notifyCallGr.isValid) {
    SNC.Notify.dequeueCall(notifyCallGr);
}

Scoped equivalent

To use the dequeueCall() method in a scoped application, use the corresponding scoped method: NotifyScoped - dequeueCall().

Notify - forwardCall(GlideRecord call, String destination, String dtmf)

Forwards the specified call to a different call recipient.

Table 7. Parameters
Name Type Description
call GlideRecord or String Notify call record or the telephony provider call ID, of the call to be forwarded.
destination GlideRecord or String Notify phone number record or an E.164-compliant phone number, of the caller to which to forward the call.
dtmf String Dual Tone - Multi Frequency (DTMF) code to send upon call connection.
Table 8. Returns
Type Description
void

Example

The following example shows how to forward a call to another phone number.

var callID = 'CA92374b5aa561dab476a7001db6026edc'; // Twilio Call ID
var phoneNumber = '+91406xxxxxxx';
var dtmfTones = null;
 
var notifyCallGr = new GlideRecord('notify_call');
notifyCallGr.get('active participant sys id');
 
if (notifyCallGr.isValid) {
    SNC.Notify.forwardCall(notifyCallGr(or) callID, phoneNumber, dtmfTones)
}

Scoped equivalent

To use the forwardCall() method in a scoped application, use the corresponding scoped method: NotifyScoped - forwardCall().

Notify - getAvailableClients(String notifyNumber)

Returns a list of client sessions that are available to receive calls.

Table 9. Parameters
Name Type Description
notifyNumber String Valid Notify phone number.
Table 10. Returns
Type Description
GlideRecord GlideRecord from the notify_client_session table for the specified phone number.

Returns "0" if there are no available client sessions.

Example

The following example shows how to use the getAvailableClients() method to index into the notify_client_session table and then iterate across all available Notify clients.

var clientSessionGr = SNC.Notify.getAvailableClients('+185xxxxxxxx'); 
// Here clientSessionGr is of type GlideRecord on 'notify_client_session' table.
 
var isLoggedInUserAvailable = false;
while (clientSessionGr.next()) {
  if (clientSessionGr.user == gs.getUserID())
    isLoggedInUserAvailable = clientSessionGr.available;
}
gs.info('isLoggedInUserAvailable - ' + isLoggedInUserAvailable);

Scoped equivalent

To use the getAvailableClients() method in a scoped application, use the corresponding scoped method: NotifyScoped - getAvailableClients().

Notify - getParentCallID(GlideRecord callRecord)

Returns the sys_id of a specified call's parent call.

Any call started by forwarding another call, such as with the Forward workflow activity, is considered a child of the original call. The original call is the parent call.

Table 11. Parameters
Name Type Description
callRecord GlideRecord Record on the Notify Call [notify_call] table for which to return the call status.
Table 12. Returns
Type Description
String Unique sys_id of the parent call record.

Example

This example shows how to obtain the parent call of the specified call.

var callRecord = new GlideRecord('notify_call');
callRecord.get("0f4f5863ff13310014ecffffffffff28");

var notify = new SNC.Notify();
var parentCallID = notify.getParentCallID(callRecord);

Notify - getPhoneNumbers()

Returns all phone numbers and short codes available to Notify.

Table 13. Parameters
Name Type Description
None
Table 14. Returns
Type Description
List List of NotifyPhoneNumber objects, each object representing one phone number available to Notify.

Example

var list = SNC.Notify.getPhoneNumbers();
for (var i = 0; i < list.size(); i++) {
    var num = list.get(i);
    gs.info(num.getNumber())
}

Scoped equivalent

To use the getPhoneNumbers() method in a scoped application, use the corresponding scoped method: NotifyScoped - getPhoneNumbers().

Notify - getTokens(GlideRecord, record)

Returns client tokens for any active telephony drivers for use in WebRTC or mobile clients.

Table 15. Parameters
Name Type Description
record GlideRecord GlideRecord to use to identify the Notify client, such as a group record or a user record.
Table 16. Returns
Type Description
String Web RTC tokens for the supported drivers, as a JSON string with the following format: {driverName1: "token1", driverName2: "token2"}, such as "TwilioDirect":"eyJhxxxx.eyJleHAiOiIxxxx.7fejxxx_mbLxxx"

Example

This example shows how to obtain the client tokens for the currently logged in user.

// get Notify client Tokens per active Notify driver for the currently logged in user
var json = new SNC.Notify().getTokens();
 
// Parse the JSON that was return into a tokens object
var tokens = JSON.parse(json);

// Log line
gs.log('Notify client tokens for the currently logged in user');

 // iterate over the driver tokens
for (var driver in tokens) {
 	gs.log(driver + ' Driver token: ' + tokens[driver]);
}

Example

This example shows how to obtain the client tokens for every Notify group.

// instantiate Notify
var notify = new SNC.Notify();
 
// get all Notify Groups
var notifyGroup = new GlideRecord("notify_group");
notifyGroup.query();
 
// iterate over all notify groups
while (notifyGroup.next()) {
  // generate Notify Client tokens per active Notify Driver for this group
  var json = notify.getTokens(notifyGroup);
  var tokens = JSON.parse(json);
 
  for (var driver in tokens) {
    gs.log(gs.getMessage("Notify Client token for {0} driver and Notify Group '{1}': {2}", [driver, notifyGroup.getValue('name'), tokens[driver]]));
  }
}

Scoped equivalent

To use the getTokens() method in a scoped application, use the corresponding scoped method: NotifyScoped - getTokens().

Notify - getTokenTTL(String owner)

Returns the maximum amount of time that a client session stays active for a specified telephony driver before automatically timing out.

Table 17. Parameters
Name Type Description
owner String Name of the telephony driver for which to retrieve the session length.

Valid values:

  • Twilio: for the old driver
  • TwilioDirect: for the new driver
Table 18. Returns
Type Description
Integer Maximum length of the session (in seconds). Default: 1800 seconds

Example

The following example shows how to properly call this method and the associated response. It also shows what is returned if an invalid driver is passed.

var owner = "TwilioDirect";  // Valid driver
var ttl = SNC.Notify.getTokenTTL(owner);
gs.info("Token TTL for " + owner + " --> " + ttl);
 
owner = "Abcxyz";  // Invalid driver
ttl = SNC.Notify.getTokenTTL(owner);
// For an invalid driver, we throw NoSuchNotifyDriverException saying that Abcxyzdriver is not available
// and return the default value of TTL
gs.info("Token TTL for " + owner + " --> " + ttl); 

Scoped equivalent

To use the getTokenTTL() method in a scoped application, use the corresponding scoped method: NotifyScoped - getAvailableClients().

Notify - hasCapability(String notifyPhoneNumber, String capability)

Determines whether the specified phone number has the specified capability.

The telephony driver associated with the phone number contains a list of all of the capabilities of the phone.
Note: In the base system, the Notify JS driver only has 'show_speakers' as a capability; this can be modified.
Table 19. Parameters
Name Type Description
notifyPhoneNumber String Phone number for which to check for the specified capability.
capability String Capability to detect. The string text must be an exact match to what is in the phone.
Table 20. Returns
Type Description
Boolean Flag that indicates whether the specified phone has the specified capability.
  • true: phone has the capability
  • false: phone does not have the capability

Example

This example shows how to check if a phone has a specific capability.

// Each driver has a defined set of capabilities.

var capability = 'show_speakers';
gs.info(SNC.Notify.hasCapability('+185xxxxxxxx', capability)); // true
 
capability = 'send_sms';
gs.info(SNC.Notify.hasCapability('+185xxxxxxxx', capability)); // false

Scoped equivalent

To use the hasCapability() method in a scoped application, use the corresponding scoped method: NotifyScoped - hasCapability().

Notify - kick(GlideRecord participant)

Removes the specified caller from the current Notify conference call.

Table 21. Parameters
Name Type Description
participant GlideRecord GlideRecord object containing the Notify Participant [notify_participant] record of the caller to remove from the conference call.
Table 22. Returns
Type Description
void

Example

The following example shows how to remove a participant from a conference call.

var notifyParticipantGr = new GlideRecord('notify_participant');
notifyParticipantGr.get('active participant sys id');
 
if (notifyParticipantGr.isValid) {
    SNC.Notify.kick(notifyParticipantGr);
}

Scoped equivalent

To use the kick() method in a scoped application, use the corresponding scoped method: NotifyScoped - kick().

Notify - modifyCall(GlideRecord callRecord, NotifyAction notifyAction)

Performs one or more actions on an active Notify phone call.

Available actions that you can perform on calls include queuing or dequeueing the call, reading text, playing audio, or forwarding the call. You can also create custom actions Call the modifyCall() method after you have specified all the actions that you want to apply to the specified call. Refer to the NotifyAction API documentation for more information about available actions.

Table 23. Parameters
Name Type Description
callRecord GlideRecord Notify Call [notify_call] record of the call for which to apply the actions.
notifyAction NotifyAction NotifyAction object describing one or more actions to perform on the call. Create this object by calling one or more of the NotifyAction() methods.
Table 24. Returns
Type Description
void

Example

This example shows how to modify a call.

// get the most recent call record
var callRecord = new GlideRecord('notify_call');
callRecord.orderByDesc('sys_created_on');
callRecord.query();
 
if (callRecord.next()) {
    // instantiate notify action container class
    var notifyAction = new SNC.NotifyAction();
    // The call is already in progress. Now, we want to modify the call behavior by putting this call in a queue.
    // So, we add a queue action to queue the call
    notifyAction.addQueue('my fancy queue');
   
    // modify the call by passing in the above action, putting the call in a queue
    new SNC.Notify().modifyCall(callRecord, notifyAction);
} else {
    gs.log('no such call record');
}

Scoped equivalent

To use the modifyCall() method in a scoped application, use the corresponding scoped method: NotifyScoped - modifyCall().

Notify - mute(GlideRecord participantRecord)

Mutes the specified conference call participant.

Table 25. Parameters
Name Type Description
participantRecord GlideRecord GlideRecord from the notify_participant table for the participant to mute.
Table 26. Returns
Type Description
void

Example

The following example shows how to mute a caller.

var notifyParticipantGr = new GlideRecord('notify_participant');
notifyParticipantGr.get('active participant sys id');
 
if (notifyParticipantGr.isValid) {
    SNC.Notify.mute(notifyParticipantGr);
}

Scoped equivalent

To use the mute() method in a scoped application, use the corresponding scoped method: NotifyScoped - mute().

Notify - queueCall(GlideRecord callRecord)

Puts the specified call into a queue (on hold).

Resume a queued call using the dequeueCall() method.

Table 27. Parameters
Name Type Description
callRecord GlideRecord GlideRecord object of the Notify Call record (notify_call table) to put on hold.
Table 28. Returns
Type Description
void

Example

The following example shows how to put a call on hold (in the queue).

var notifyCallGr = new GlideRecord('notify_call');
notifyCallGr.get('active participant sys id');
 
if (notifyCallGr.isValid) {
    SNC.Notify.queueCall(notifyCallGr);
}

Scoped equivalent

To use the queueCall() method in a scoped application, use the corresponding scoped method: NotifyScoped - queueCall().

Notify - sendBulkSMS(String notifyPhoneNumber, Array toPhoneNumbers, String messageBody, GlideRecord source)

Sends a specified SMS message to the specified list of Notify clients (phone numbers).

Table 30. Returns
Type Description
String Null

Example

The following example shows how to send a bulk SMS message.

var incidentGr = new GlideRecord('incident');
incidentGr.get(active incident sys_id');
if (incidentGr.isValid()) {
    SNC.Notify.sendBulkSMS('+15413970605', ['+919885XXXXXX', '+919775XXXXXX'], 'Test automation message', incidentGr);
}

Scoped equivalent

To use the sendBulkSMS() method in a scoped application, use the corresponding scoped method: NotifyScoped - sendBulkSMS().

Notify - sendSMS(String notifyPhoneNumber, String toPhoneNumber, String messageBody, GlideRecord source)

Sends an SMS text message to an E.164-compliant phone number.

This method creates a new record on the Notify Message [notify_message] table and associates it with the source record.

Table 32. Returns
Type Description
String Unique message SID; stored in the Notify Message [notify_message] record as message_id.

Example

The following example shows how to send an SMS message.

var incidentGr = new GlideRecord('incident');
incidentGr.get('active incident sys_id');
if (incidentGr.isValid()) {
    SNC.Notify.sendSMS('+15413970605', '+919885XXXXXX', 'Test automation message', incidentGr);
}

Scoped equivalent

To use the sendSMS() method in a scoped application, use the corresponding scoped method: NotifyScoped - sendSMS().

Notify - unmute(GlideRecord participantRecord)

Unmutes the specified conference call participant.

Table 33. Parameters
Name Type Description
participantRecord GlideRecord GlideRecord from the notify_participant table for the participant to unmute.
Table 34. Returns
Type Description
void

Example

The following example shows how to unmute a caller.

var notifyParticipantGr = new GlideRecord('notify_participant');
notifyParticipantGr.get('active participant sys id');
 
if (notifyParticipantGr.isValid) {
    SNC.Notify.unmute(notifyParticipantGr);
}

Scoped equivalent

To use the unmute() method in a scoped application, use the corresponding scoped method: NotifyScoped - unmute().