This project provides a node module that extends the ringcentral-js-concise module with a more semantic interface. The concise module is optimized for being light-weight. As a result, it tends to be more abstract, and harder to use for beginners.
This module hopes to make the vastness of the RingCentral API more accessible to beginners.
To illustrate, here are two functionally equivalent code samples using the two modules:
This is "yet another ringcentral npm" developed as a proof-of-concept to offer developers a simpler interface over the the ringcentral-js-concise
library. Developers have a number of choices when choosing a RingCentral npm, here are some of them:
- ringcentral - The official javascript library maintained by RingCentral.
- ringcentral-client - In part, inspiration for this module, as it provides a more explicit (a.k.a. "semantic") interface for supported methods. etc. The author had difficulty using this module however (which could be entirely his own darn fault).
- ringcentral-js-concise - An npm optimized for size. It is effective, but more abstract. The author had a personal affinity for this module.
- ringcentral-semantic - This npm, a wrapper around
ringcentral-js-concise
that attempts to combine they best parts of the modules above.
const promise = client.post('/restapi/v1.0/account/~/extension/~/sms', {
from: { phoneNumber: '+12054387726' },
to: [{ phoneNumber: '+15105553204' }],
text: 'This is a test SMS.'
})
const promise = client.sendSMS({
sender: '+12054387726',
receiver: '+15105553204',
text: 'This is a test SMS.'
})
Hopefully, what you can see is a slightly more intuitive interface, one that exposes explicit functions for each of RingCentral's capabilities, and abstracts developers completely away from having to know API endpoints, or methods.
All of RingCentral's APIs can be scoped to a specific organization and user by specifying the corresponding account and/or extension in the endpoint's path. You can set these path parameters by passing in the following parameters into each method supported by this SDK:
accountId
extension
If these parameters are omitted, they will both default to ~
, which refers to the account/extension of the currently authed user.
Example
client.sendSMS({
accountId: '+12125558373',
extension: '110',
from: { phoneNumber: '+12054387726' },
to: [{ phoneNumber: '+15105553204'}],
text: 'This is a test SMS.'
})
Each method supported by this library takes as input an associative array of request parameters. For all methods, developers are free to use the raw input format of the RingCentral API (as documented in RingCentral's API Explorer).
In some circumstances however, this SDK will accept simpler formats so that code can be easier to read and input by the developer. In these circumstances, the method documented below will highlight a "Simplified Syntax" one can utilize.
To illustrate, let's look at how one might compose a request to send an SMS using the raw input format, and the simplified format.
Using the Raw Input Format
client.sendSMS({
from: { phoneNumber: '+12054387726' },
to: [{ phoneNumber: '+15105553204'}],
text: 'This is a test SMS.'
})
Using the Simplified Syntax:
client.sendSMS({
sender: '+12054387726',
receiver: '+15105553204',
text: 'This is a test SMS.'
})
When one needs to get, update or delete a specific record via id, this is done by passing in an id
parameter in the array of request parameters for the corresponding method. For example:
client.updateContact({ id: '736483937493', email: 'newemail@example.com' })
client.getContact({ id: '736483937493' })
client.deleteContact({ id: '736483937493' })
This library utilizes ES6 asynchronous methods. Each method returns a promise, to which you can attach then
, catch
and finally
blocks.
The then
block is called when the method returns successfully, and is passed the axios response object. This is how you can access the data returned by RingCentral.
For example:
client.sendSMS({
sender: '+12054387726',
receiver: '+15105553204',
text: 'This is a test SMS.'
}).then( function (response) {
console.log( "Message ID" + response.data['id'] )
}).catch( function (error) {
console.log( "Something went wrong: " + error.message )
}).finally( function () {
console.log( "All finished. ")
})
Creates a new contact in the associated account. This method has no simplified syntax.
Updates a single contact with the specified id. Developers need only specify the contact properties they wish to update. See "Getting, Updating and Deleting Records."
Simplified Syntax
client.updateContact({
id: '736483937493',
email: 'newemail@example.com'
})
Returns a single contact with the specified id. See "Getting, Updating and Deleting Records."
Returns a list of contacts associated the current account. This method has no simplified syntax.
Returns a list of extensions associated with the given account. See "Path Parameters" above for how to scope this call to a given account and/or extension.
Will send an SMS to the designated recipient.
Simplified Syntax
client.sendSMS({
sender: '+12054387726',
receiver: '+15105553204',
text: 'This is a test SMS.'
})
Returns a list of messages associated the current account. This method has no simplified syntax.
Will dial the caller first, then connect the sender to the receiver when they pick up. Optionally accepts a callerId parameter.
Simplified Syntax
client.ringOut({
caller: '+15105553204',
receiver: '+12054387726',
callerId: '+15105555555'
})
This module is licensed under the MIT license.