UNPKG

19.1 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _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; }; }();
8
9var _fs = require("fs");
10
11var _fs2 = _interopRequireDefault(_fs);
12
13var _path = require("path");
14
15var _path2 = _interopRequireDefault(_path);
16
17var _Credentials = require("./Credentials");
18
19var _Credentials2 = _interopRequireDefault(_Credentials);
20
21var _JwtGenerator = require("./JwtGenerator");
22
23var _JwtGenerator2 = _interopRequireDefault(_JwtGenerator);
24
25var _Message = require("./Message");
26
27var _Message2 = _interopRequireDefault(_Message);
28
29var _Voice = require("./Voice");
30
31var _Voice2 = _interopRequireDefault(_Voice);
32
33var _Number = require("./Number");
34
35var _Number2 = _interopRequireDefault(_Number);
36
37var _Verify = require("./Verify");
38
39var _Verify2 = _interopRequireDefault(_Verify);
40
41var _NumberInsight = require("./NumberInsight");
42
43var _NumberInsight2 = _interopRequireDefault(_NumberInsight);
44
45var _App = require("./App");
46
47var _App2 = _interopRequireDefault(_App);
48
49var _Account = require("./Account");
50
51var _Account2 = _interopRequireDefault(_Account);
52
53var _CallsResource = require("./CallsResource");
54
55var _CallsResource2 = _interopRequireDefault(_CallsResource);
56
57var _FilesResource = require("./FilesResource");
58
59var _FilesResource2 = _interopRequireDefault(_FilesResource);
60
61var _Conversion = require("./Conversion");
62
63var _Conversion2 = _interopRequireDefault(_Conversion);
64
65var _Media = require("./Media");
66
67var _Media2 = _interopRequireDefault(_Media);
68
69var _Redact = require("./Redact");
70
71var _Redact2 = _interopRequireDefault(_Redact);
72
73var _HttpClient = require("./HttpClient");
74
75var _HttpClient2 = _interopRequireDefault(_HttpClient);
76
77var _NullLogger = require("./NullLogger");
78
79var _NullLogger2 = _interopRequireDefault(_NullLogger);
80
81var _ConsoleLogger = require("./ConsoleLogger");
82
83var _ConsoleLogger2 = _interopRequireDefault(_ConsoleLogger);
84
85function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
86
87function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
88
89var jwtGeneratorInstance = new _JwtGenerator2.default();
90
91var Nexmo = function () {
92 /**
93 * @param {Credentials} credentials - Nexmo API credentials
94 * @param {string} credentials.apiKey - the Nexmo API key
95 * @param {string} credentials.apiSecret - the Nexmo API secret
96 * @param {Object} options - Additional options
97 * @param {boolean} options.debug - `true` to turn on debug logging
98 * @param {Object} options.logger - Set a custom logger.
99 * @param {string} options.appendToUserAgent - A value to append to the user agent.
100 * The value will be prefixed with a `/`
101 */
102 function Nexmo(credentials) {
103 var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : { debug: false };
104
105 _classCallCheck(this, Nexmo);
106
107 this.credentials = _Credentials2.default.parse(credentials);
108 this.options = options;
109
110 // If no logger has been supplied but debug has been set
111 // default to using the ConsoleLogger
112 if (!this.options.logger && this.options.debug) {
113 this.options.logger = new _ConsoleLogger2.default();
114 } else if (!this.options.logger) {
115 // Swallow the logging
116 this.options.logger = new _NullLogger2.default();
117 }
118
119 var userAgent = "nexmo-node/UNKNOWN node/UNKNOWN";
120 try {
121 var packageDetails = require(_path2.default.join(__dirname, "..", "package.json"));
122 userAgent = "nexmo-node/" + packageDetails.version + " node/" + process.version.replace("v", "");
123 } catch (e) {
124 console.warn("Could not load package details");
125 }
126 this.options.userAgent = userAgent;
127 if (this.options.appendToUserAgent) {
128 this.options.userAgent += " " + this.options.appendToUserAgent;
129 }
130
131 // This is legacy, everything should use rest or api going forward
132 this.options.httpClient = new _HttpClient2.default(Object.assign({ host: "rest.nexmo.com" }, this.options), this.credentials);
133
134 // We have two different hosts, so we use two different HttpClients
135 this.options.api = new _HttpClient2.default(Object.assign({ host: "api.nexmo.com" }, this.options), this.credentials);
136 this.options.rest = new _HttpClient2.default(Object.assign({ host: "rest.nexmo.com" }, this.options), this.credentials);
137
138 this.message = new _Message2.default(this.credentials, this.options);
139 this.voice = new _Voice2.default(this.credentials, this.options);
140 this.number = new _Number2.default(this.credentials, this.options);
141 this.verify = new _Verify2.default(this.credentials, this.options);
142 this.numberInsight = new _NumberInsight2.default(this.credentials, this.options);
143 this.applications = new _App2.default(this.credentials, this.options);
144 this.account = new _Account2.default(this.credentials, this.options);
145 this.calls = new _CallsResource2.default(this.credentials, this.options);
146 this.files = new _FilesResource2.default(this.credentials, this.options);
147 this.conversion = new _Conversion2.default(this.credentials, this.options);
148 this.media = new _Media2.default(this.credentials, this.options);
149 this.redact = new _Redact2.default(this.credentials, this.options);
150
151 /**
152 * @deprecated Please use nexmo.applications
153 */
154 this.app = this.applications;
155 }
156
157 /**
158 * Generate a JSON Web Token (JWT).
159 *
160 * The private key used upon Nexmo instance construction will be used to sign
161 * the JWT. The application_id you used upon Nexmo instance creation will be
162 * included in the claims for the JWT, however this can be overridden by passing
163 * an application_id as part of the claims.
164 *
165 * @param {Object} claims - name/value pair claims to sign within the JWT
166 *
167 * @returns {String} the generated token
168 */
169
170
171 _createClass(Nexmo, [{
172 key: "generateJwt",
173 value: function generateJwt() {
174 var claims = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
175
176 if (claims.application_id === undefined) {
177 claims.application_id = this.credentials.applicationId;
178 }
179 return Nexmo.generateJwt(this.credentials.privateKey, claims);
180 }
181 }]);
182
183 return Nexmo;
184}();
185
186/**
187 * Generate a JSON Web Token (JWT).
188 *
189 * @param {String|Buffer} privateKey - the path to the private key certificate
190 * to be used when signing the claims.
191 * @param {Object} claims - name/value pair claims to sign within the JWT
192 *
193 * @returns {String} the generated token
194 */
195
196
197Nexmo.generateJwt = function (privateKey, claims) {
198 if (!(privateKey instanceof Buffer)) {
199 if (!_fs2.default.existsSync(privateKey)) {
200 throw new Error("File \"" + privateKey + "\" not found.");
201 } else {
202 privateKey = _fs2.default.readFileSync(privateKey);
203 }
204 }
205 return jwtGeneratorInstance.generate(privateKey, claims);
206};
207
208exports.default = Nexmo;
209module.exports = exports["default"];
210//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Nexmo.js"],"names":["jwtGeneratorInstance","Nexmo","credentials","options","debug","parse","logger","userAgent","packageDetails","require","join","__dirname","version","process","replace","e","console","warn","appendToUserAgent","httpClient","Object","assign","host","api","rest","message","voice","number","verify","numberInsight","applications","account","calls","files","conversion","media","redact","app","claims","application_id","undefined","applicationId","generateJwt","privateKey","Buffer","existsSync","Error","readFileSync","generate"],"mappings":"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","file":"Nexmo.js","sourcesContent":["import fs from \"fs\";\nimport path from \"path\";\n\nimport Credentials from \"./Credentials\";\nimport JwtGenerator from \"./JwtGenerator\";\nimport Message from \"./Message\";\nimport Voice from \"./Voice\";\nimport Number from \"./Number\";\nimport Verify from \"./Verify\";\nimport NumberInsight from \"./NumberInsight\";\nimport App from \"./App\";\nimport Account from \"./Account\";\nimport CallsResource from \"./CallsResource\";\nimport FilesResource from \"./FilesResource\";\nimport Conversion from \"./Conversion\";\nimport Media from \"./Media\";\nimport Redact from \"./Redact\";\nimport HttpClient from \"./HttpClient\";\nimport NullLogger from \"./NullLogger\";\nimport ConsoleLogger from \"./ConsoleLogger\";\n\nconst jwtGeneratorInstance = new JwtGenerator();\n\nclass Nexmo {\n  /**\n   * @param {Credentials} credentials - Nexmo API credentials\n   * @param {string} credentials.apiKey - the Nexmo API key\n   * @param {string} credentials.apiSecret - the Nexmo API secret\n   * @param {Object} options - Additional options\n   * @param {boolean} options.debug - `true` to turn on debug logging\n   * @param {Object} options.logger - Set a custom logger.\n   * @param {string} options.appendToUserAgent - A value to append to the user agent.\n   *                    The value will be prefixed with a `/`\n   */\n  constructor(credentials, options = { debug: false }) {\n    this.credentials = Credentials.parse(credentials);\n    this.options = options;\n\n    // If no logger has been supplied but debug has been set\n    // default to using the ConsoleLogger\n    if (!this.options.logger && this.options.debug) {\n      this.options.logger = new ConsoleLogger();\n    } else if (!this.options.logger) {\n      // Swallow the logging\n      this.options.logger = new NullLogger();\n    }\n\n    let userAgent = \"nexmo-node/UNKNOWN node/UNKNOWN\";\n    try {\n      var packageDetails = require(path.join(__dirname, \"..\", \"package.json\"));\n      userAgent = `nexmo-node/${\n        packageDetails.version\n      } node/${process.version.replace(\"v\", \"\")}`;\n    } catch (e) {\n      console.warn(\"Could not load package details\");\n    }\n    this.options.userAgent = userAgent;\n    if (this.options.appendToUserAgent) {\n      this.options.userAgent += ` ${this.options.appendToUserAgent}`;\n    }\n\n    // This is legacy, everything should use rest or api going forward\n    this.options.httpClient = new HttpClient(\n      Object.assign({ host: \"rest.nexmo.com\" }, this.options),\n      this.credentials\n    );\n\n    // We have two different hosts, so we use two different HttpClients\n    this.options.api = new HttpClient(\n      Object.assign({ host: \"api.nexmo.com\" }, this.options),\n      this.credentials\n    );\n    this.options.rest = new HttpClient(\n      Object.assign({ host: \"rest.nexmo.com\" }, this.options),\n      this.credentials\n    );\n\n    this.message = new Message(this.credentials, this.options);\n    this.voice = new Voice(this.credentials, this.options);\n    this.number = new Number(this.credentials, this.options);\n    this.verify = new Verify(this.credentials, this.options);\n    this.numberInsight = new NumberInsight(this.credentials, this.options);\n    this.applications = new App(this.credentials, this.options);\n    this.account = new Account(this.credentials, this.options);\n    this.calls = new CallsResource(this.credentials, this.options);\n    this.files = new FilesResource(this.credentials, this.options);\n    this.conversion = new Conversion(this.credentials, this.options);\n    this.media = new Media(this.credentials, this.options);\n    this.redact = new Redact(this.credentials, this.options);\n\n    /**\n     * @deprecated Please use nexmo.applications\n     */\n    this.app = this.applications;\n  }\n\n  /**\n   * Generate a JSON Web Token (JWT).\n   *\n   * The private key used upon Nexmo instance construction will be used to sign\n   * the JWT. The application_id you used upon Nexmo instance creation will be\n   * included in the claims for the JWT, however this can be overridden by passing\n   * an application_id as part of the claims.\n   *\n   * @param {Object} claims - name/value pair claims to sign within the JWT\n   *\n   * @returns {String} the generated token\n   */\n  generateJwt(claims = {}) {\n    if (claims.application_id === undefined) {\n      claims.application_id = this.credentials.applicationId;\n    }\n    return Nexmo.generateJwt(this.credentials.privateKey, claims);\n  }\n}\n\n/**\n * Generate a JSON Web Token (JWT).\n *\n * @param {String|Buffer} privateKey - the path to the private key certificate\n *          to be used when signing the claims.\n * @param {Object} claims - name/value pair claims to sign within the JWT\n *\n * @returns {String} the generated token\n */\nNexmo.generateJwt = (privateKey, claims) => {\n  if (!(privateKey instanceof Buffer)) {\n    if (!fs.existsSync(privateKey)) {\n      throw new Error(`File \"${privateKey}\" not found.`);\n    } else {\n      privateKey = fs.readFileSync(privateKey);\n    }\n  }\n  return jwtGeneratorInstance.generate(privateKey, claims);\n};\n\nexport default Nexmo;\n"]}
\No newline at end of file