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