UNPKG

plivo

Version:

A Node.js SDK to make voice calls and send SMS using Plivo and to generate Plivo XML

446 lines (367 loc) 15.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.NumberInterface = exports.NumberResource = exports.PhoneNumberInterface = exports.PhoneNumber = exports.UpdateNumberResponse = exports.SearchNumberResponse = exports.BuyNumberResponse = undefined; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _base = require('../base'); var _common = require('../utils/common.js'); function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var clientKey = Symbol(); var action = 'Number/'; var idField = 'number'; var BuyNumberResponse = exports.BuyNumberResponse = function BuyNumberResponse(params, statusCode) { _classCallCheck(this, BuyNumberResponse); params = params || {}; this.apiId = params.apiId; this.numbers = params.numbers; this.status = params.status; this.message = params.message; this.statusCode = statusCode; }; var SearchNumberResponse = exports.SearchNumberResponse = function SearchNumberResponse(params) { _classCallCheck(this, SearchNumberResponse); params = params || {}; this.number = params.number; this.prefix = params.prefix; this.city = params.city; this.country = params.country; this.region = params.region; this.rate_center = params.rate_center; this.lata = params.lata; this.type = params.type; this.sub_type = params.sub_type; this.setup_rate = params.setup_rate; this.monthly_rental_rate = params.monthly_rental_rate; this.sms_enabled = params.sms_enabled; this.sms_rate = params.sms_rate; this.voice_enabled = params.voice_enabled; this.voice_rate = params.voice_rate; this.restriction = params.restriction; this.restriction_text = params.restriction_text; this.resource_uri = params.resource_uri; }; var UpdateNumberResponse = exports.UpdateNumberResponse = function UpdateNumberResponse(params) { _classCallCheck(this, UpdateNumberResponse); params = params || {}; this.apiId = params.apiId; this.message = params.message; }; /** * Represents a PhoneNumber * @constructor * @param {function} client - make api call * @param {object} [data] - data of call */ var PhoneNumber = exports.PhoneNumber = function (_PlivoResource) { _inherits(PhoneNumber, _PlivoResource); function PhoneNumber(client) { var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; _classCallCheck(this, PhoneNumber); var _this = _possibleConstructorReturn(this, (PhoneNumber.__proto__ || Object.getPrototypeOf(PhoneNumber)).call(this, 'PhoneNumber/', PhoneNumber, idField, client)); if (idField in data) { _this.id = data[idField]; } (0, _common.extend)(_this, data); _this[clientKey] = client; return _this; } /** * Buy Phone Number * @method * @param {string} appId - app id * @param {string} cnamLookup - cnam lookup * @promise {@link PlivoGenericResponse} return PlivoGenericResponse Object if success * @fail {Error} return Error */ _createClass(PhoneNumber, [{ key: 'buy', value: function buy(number, appId, cnamLookup) { return new PhoneNumberInterface(this[clientKey], { id: this.id }).buy(number, appId, cnamLookup); } }]); return PhoneNumber; }(_base.PlivoResource); /** * Represents a PhoneNumbers Interface * @constructor * @param {function} client - make api call * @param {object} [data] - data of call * @param {string} [data.test] - test data */ var PhoneNumberInterface = exports.PhoneNumberInterface = function (_PlivoResourceInterfa) { _inherits(PhoneNumberInterface, _PlivoResourceInterfa); function PhoneNumberInterface(client) { var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; _classCallCheck(this, PhoneNumberInterface); var _this2 = _possibleConstructorReturn(this, (PhoneNumberInterface.__proto__ || Object.getPrototypeOf(PhoneNumberInterface)).call(this, 'PhoneNumber/', PhoneNumber, idField, client)); (0, _common.extend)(_this2, data); _this2[clientKey] = client; return _this2; } /** * Buy Phone Number * @method * @param {string} appId - app id * @param {string} cnamLookup - cnam lookup * @promise {@link PlivoGenericResponse} return PlivoGenericResponse Object if success * @fail {Error} return Error */ _createClass(PhoneNumberInterface, [{ key: 'buy', value: function buy(number, appId, cnamLookup) { var params = {}; if (appId) { params.app_id = appId; } if (cnamLookup) { params.cnam_lookup = cnamLookup; } var client = this[clientKey]; return new Promise(function (resolve, reject) { client('POST', 'PhoneNumber/' + number + '/', params).then(function (response) { resolve(new BuyNumberResponse(response.body, response.response.status, idField)); }).catch(function (error) { reject(error); }); }); } }]); return PhoneNumberInterface; }(_base.PlivoResourceInterface); /** * Represents a Number * @constructor * @param {function} client - make api call * @param {object} [data] - data of call */ var NumberResource = exports.NumberResource = function (_PlivoResource2) { _inherits(NumberResource, _PlivoResource2); function NumberResource(client) { var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; _classCallCheck(this, NumberResource); var _this3 = _possibleConstructorReturn(this, (NumberResource.__proto__ || Object.getPrototypeOf(NumberResource)).call(this, action, NumberResource, idField, client)); if (idField in data) { _this3.id = data[idField]; } (0, _common.extend)(_this3, data); _this3[clientKey] = client; return _this3; } /** * Unrent Number * @method * @promise {boolean} return true if success * @fail {Error} return Error */ _createClass(NumberResource, [{ key: 'unrent', value: function unrent(number) { var client = this[clientKey]; var action = 'Number/'; return new Promise(function (resolve, reject) { client('DELETE', action + number + '/').then(function () { resolve(true); }).catch(function (error) { reject(error); }); }); } /** * Update Number * @method * @param {object} params * @param {string} [params.appId] - app id * @param {string} [params.subAccount] - auth_id of subaccount * @param {string} [params.alias] - textual name of number * @param {string} [params.cnamLookup] - cnam lookup of number * @promise {@link NumberResource} return NumberResource Object if success * @fail {Error} return Error */ }, { key: 'update', value: function update(number, params) { var client = this[clientKey]; var action = 'Number/'; var that = this; // Handle subAccount parameter specifically for numbers update API var apiParams = Object.assign({}, params); if (apiParams.subAccount) { apiParams.subaccount = apiParams.subAccount; delete apiParams.subAccount; } return new Promise(function (resolve, reject) { client('POST', action + number + '/', apiParams).then(function (response) { (0, _common.extend)(that, response.body); if (params.hasOwnProperty('isVoiceRequest')) { delete params.isVoiceRequest; } (0, _common.extend)(that, params); resolve(new UpdateNumberResponse(that)); }).catch(function (error) { reject(error); }); }); } }]); return NumberResource; }(_base.PlivoResource); /** * Represents a Numbers * @constructor * @param {function} client - make api call * @param {object} [data] - data of call */ var NumberInterface = exports.NumberInterface = function (_PlivoResourceInterfa2) { _inherits(NumberInterface, _PlivoResourceInterfa2); function NumberInterface(client) { _classCallCheck(this, NumberInterface); var _this4 = _possibleConstructorReturn(this, (NumberInterface.__proto__ || Object.getPrototypeOf(NumberInterface)).call(this, action, NumberResource, idField, client)); _this4[clientKey] = client; return _this4; } /** * Buy Phone Number * @method * @param {string} number - number to buy * @param {string} appId - app id * @param {string} cnamLookup - cnam lookup * @promise {@link PlivoGenericResponse} return PlivoGenericResponse Object if success * @fail {Error} return Error */ _createClass(NumberInterface, [{ key: 'buy', value: function buy(number, appId, cnamLookup) { var errors = (0, _common.validate)([{ field: 'number', value: number, validators: ['isRequired'] }]); if (errors) { return errors; } return new PhoneNumber(this[clientKey], { id: number }).buy(number, appId, cnamLookup); } /** * Add own number from carrier * @method * @param {string} numbers - A comma separated list of numbers that need to be added for the carrier. * @param {string} carrier - The carrier_id of the IncomingCarrier that the number is associated with. * @param {string} region - region that is associated with the Number * @param {string} optionaParams - optional params * @promise {@link PlivoGenericResponse} return PlivoGenericResponse Object if success * @fail {Error} return Error */ }, { key: 'addOwnNumber', value: function addOwnNumber(numbers, carrier, region, optionalParams) { var errors = (0, _common.validate)([{ field: 'numbers', value: numbers, validators: ['isRequired'] }, { field: 'carrier', value: carrier, validators: ['isRequired'] }, { field: 'region', value: region, validators: ['isRequired'] }]); if (errors) { return errors; } var params = optionalParams || {}; params.numbers = numbers; params.carrier = carrier; params.region = region; var client = this[clientKey]; return new Promise(function (resolve, reject) { client('POST', action, params).then(function (response) { resolve(new _base.PlivoGenericResponse(response.body, idField)); }).catch(function (error) { reject(error); }); }); } /** * Add own number from carrier * @method * @param {string} countryISO - The ISO code A2 of the country * @param {string} optionaParams - optional params * @promise {@link PhoneNumberInterface} return PhoneNumbers Object if success * @fail {Error} return Error */ }, { key: 'search', value: function search(countryISO, optionalParams) { var errors = (0, _common.validate)([{ field: 'country_iso', value: countryISO, validators: ['isRequired'] }]); if (errors) { return errors; } var params = optionalParams || {}; params.country_iso = countryISO; return new PhoneNumberInterface(this[clientKey]).list(params); } /** * Update Number * @method * @param {string} number - number to update * @param {object} params * @param {string} [params.appId] - app id * @param {string} [params.subAccount] - auth_id of subaccount * @param {string} [params.alias] - textual name of number * @param {string} [params.cnamLookup] - cnam lookup of number * @promise {@link NumberResource} return NumberResource Object if success * @fail {Error} return Error */ }, { key: 'update', value: function update(number, params) { var errors = (0, _common.validate)([{ field: 'number', value: number, validators: ['isRequired'] }]); if (errors) { return errors; } return new NumberResource(this[clientKey], { id: number }).update(number, params); } /** * Unrent Number * @method * @param {string} number - number to unrent * @promise {boolean} return true if success * @fail {Error} return Error */ }, { key: 'unrent', value: function unrent(number) { var errors = (0, _common.validate)([{ field: 'number', value: number, validators: ['isRequired'] }]); if (errors) { return errors; } return new NumberResource(this[clientKey], { id: number }).unrent(number); } }]); return NumberInterface; }(_base.PlivoResourceInterface);