@emilgroup/claim-sdk-node 1.19.0 → 1.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -17,11 +17,11 @@ Although this package can be used in both TypeScript and JavaScript, it is inten
17
17
  Navigate to the folder of your consuming project and run one of the following commands:
18
18
 
19
19
  ```
20
- npm install @emilgroup/claim-sdk-node@1.19.0 --save
20
+ npm install @emilgroup/claim-sdk-node@1.20.0 --save
21
21
  ```
22
22
  or
23
23
  ```
24
- yarn add @emilgroup/claim-sdk-node@1.19.0
24
+ yarn add @emilgroup/claim-sdk-node@1.20.0
25
25
  ```
26
26
 
27
27
  And then you can import `ClaimsApi`.
package/base.ts CHANGED
@@ -79,6 +79,7 @@ export class BaseAPI {
79
79
  protected configuration: Configuration;
80
80
  private username?: string;
81
81
  private password?: string;
82
+ private permissions: Array<string> = [];
82
83
 
83
84
  constructor(configuration?: Configuration, protected basePath: string = BASE_PATH, protected axios: AxiosInstance = globalAxios) {
84
85
  if (configuration) {
@@ -149,6 +150,10 @@ export class BaseAPI {
149
150
  this.configuration.basePath = env;
150
151
  }
151
152
 
153
+ getPermissions(): Array<string> {
154
+ return this.permissions;
155
+ }
156
+
152
157
  async authorize(username: string, password: string): Promise<void> {
153
158
  const options: AxiosRequestConfig = {
154
159
  method: 'POST',
@@ -163,20 +168,21 @@ export class BaseAPI {
163
168
 
164
169
  const response = await globalAxios.request<LoginClass>(options);
165
170
 
166
- const { data: { accessToken } } = response;
171
+ const { data: { accessToken, permissions } } = response;
167
172
  this.configuration.username = username;
168
173
  this.configuration.accessToken = `Bearer ${accessToken}`;
174
+ this.permissions = permissions;
169
175
 
170
176
  const refreshToken = this.extractRefreshToken(response)
171
177
  this.configuration.refreshToken = refreshToken;
172
178
  }
173
179
 
174
- async refreshTokenInternal(): Promise<string> {
180
+ async refreshTokenInternal(): Promise<LoginClass> {
175
181
  const { username, refreshToken } = this.configuration;
176
182
 
177
183
 
178
184
  if (!username || !refreshToken) {
179
- return '';
185
+ throw new Error('Failed to refresh token.');
180
186
  }
181
187
 
182
188
  const options: AxiosRequestConfig = {
@@ -190,9 +196,9 @@ export class BaseAPI {
190
196
  withCredentials: true,
191
197
  };
192
198
 
193
- const { data: { accessToken } } = await globalAxios.request<LoginClass>(options);
199
+ const response = await globalAxios.request<LoginClass>(options);
194
200
 
195
- return accessToken;
201
+ return response.data;
196
202
  }
197
203
 
198
204
  private extractRefreshToken(response: AxiosResponse): string {
@@ -221,8 +227,9 @@ export class BaseAPI {
221
227
  if (err.response.status === 401 && !originalConfig._retry) {
222
228
  originalConfig._retry = true;
223
229
  try {
224
- const tokenString = await this.refreshTokenInternal();
230
+ const { accessToken: tokenString, permissions } = await this.refreshTokenInternal();
225
231
  const accessToken = `Bearer ${tokenString}`;
232
+ this.permissions = permissions;
226
233
 
227
234
  originalConfig.headers['Authorization'] = `Bearer ${accessToken}`
228
235
 
@@ -246,8 +253,9 @@ export class BaseAPI {
246
253
  ){
247
254
  _retry_count++;
248
255
  try {
249
- const tokenString = await this.refreshTokenInternal();
256
+ const { accessToken: tokenString, permissions } = await this.refreshTokenInternal();
250
257
  const accessToken = `Bearer ${tokenString}`;
258
+ this.permissions = permissions;
251
259
 
252
260
  _retry = true;
253
261
  originalConfig.headers['Authorization'] = accessToken;
package/dist/base.d.ts CHANGED
@@ -53,14 +53,16 @@ export declare class BaseAPI {
53
53
  protected configuration: Configuration;
54
54
  private username?;
55
55
  private password?;
56
+ private permissions;
56
57
  constructor(configuration?: Configuration, basePath?: string, axios?: AxiosInstance);
57
58
  initialize(env?: Environment): Promise<void>;
58
59
  private loadCredentials;
59
60
  private readConfigFile;
60
61
  private readEnvVariables;
61
62
  selectEnvironment(env: Environment): void;
63
+ getPermissions(): Array<string>;
62
64
  authorize(username: string, password: string): Promise<void>;
63
- refreshTokenInternal(): Promise<string>;
65
+ refreshTokenInternal(): Promise<LoginClass>;
64
66
  private extractRefreshToken;
65
67
  getConfiguration(): Configuration;
66
68
  private attachInterceptor;
package/dist/base.js CHANGED
@@ -150,6 +150,7 @@ var BaseAPI = /** @class */ (function () {
150
150
  if (axios === void 0) { axios = axios_1.default; }
151
151
  this.basePath = basePath;
152
152
  this.axios = axios;
153
+ this.permissions = [];
153
154
  if (configuration) {
154
155
  this.configuration = configuration;
155
156
  this.basePath = configuration.basePath || this.basePath;
@@ -242,11 +243,14 @@ var BaseAPI = /** @class */ (function () {
242
243
  BaseAPI.prototype.selectEnvironment = function (env) {
243
244
  this.configuration.basePath = env;
244
245
  };
246
+ BaseAPI.prototype.getPermissions = function () {
247
+ return this.permissions;
248
+ };
245
249
  BaseAPI.prototype.authorize = function (username, password) {
246
250
  return __awaiter(this, void 0, void 0, function () {
247
- var options, response, accessToken, refreshToken;
248
- return __generator(this, function (_a) {
249
- switch (_a.label) {
251
+ var options, response, _a, accessToken, permissions, refreshToken;
252
+ return __generator(this, function (_b) {
253
+ switch (_b.label) {
250
254
  case 0:
251
255
  options = {
252
256
  method: 'POST',
@@ -260,10 +264,11 @@ var BaseAPI = /** @class */ (function () {
260
264
  };
261
265
  return [4 /*yield*/, axios_1.default.request(options)];
262
266
  case 1:
263
- response = _a.sent();
264
- accessToken = response.data.accessToken;
267
+ response = _b.sent();
268
+ _a = response.data, accessToken = _a.accessToken, permissions = _a.permissions;
265
269
  this.configuration.username = username;
266
270
  this.configuration.accessToken = "Bearer ".concat(accessToken);
271
+ this.permissions = permissions;
267
272
  refreshToken = this.extractRefreshToken(response);
268
273
  this.configuration.refreshToken = refreshToken;
269
274
  return [2 /*return*/];
@@ -273,13 +278,13 @@ var BaseAPI = /** @class */ (function () {
273
278
  };
274
279
  BaseAPI.prototype.refreshTokenInternal = function () {
275
280
  return __awaiter(this, void 0, void 0, function () {
276
- var _a, username, refreshToken, options, accessToken;
281
+ var _a, username, refreshToken, options, response;
277
282
  return __generator(this, function (_b) {
278
283
  switch (_b.label) {
279
284
  case 0:
280
285
  _a = this.configuration, username = _a.username, refreshToken = _a.refreshToken;
281
286
  if (!username || !refreshToken) {
282
- return [2 /*return*/, ''];
287
+ throw new Error('Failed to refresh token.');
283
288
  }
284
289
  options = {
285
290
  method: 'POST',
@@ -293,8 +298,8 @@ var BaseAPI = /** @class */ (function () {
293
298
  };
294
299
  return [4 /*yield*/, axios_1.default.request(options)];
295
300
  case 1:
296
- accessToken = (_b.sent()).data.accessToken;
297
- return [2 /*return*/, accessToken];
301
+ response = _b.sent();
302
+ return [2 /*return*/, response.data];
298
303
  }
299
304
  });
300
305
  });
@@ -314,26 +319,27 @@ var BaseAPI = /** @class */ (function () {
314
319
  axios.interceptors.response.use(function (res) {
315
320
  return res;
316
321
  }, function (err) { return __awaiter(_this, void 0, void 0, function () {
317
- var originalConfig, tokenString, accessToken, _error_1, tokenString, accessToken, _error_2;
318
- return __generator(this, function (_a) {
319
- switch (_a.label) {
322
+ var originalConfig, _a, tokenString, permissions, accessToken, _error_1, _b, tokenString, permissions, accessToken, _error_2;
323
+ return __generator(this, function (_c) {
324
+ switch (_c.label) {
320
325
  case 0:
321
326
  originalConfig = err.config;
322
327
  if (!err.response) return [3 /*break*/, 5];
323
328
  if (!(err.response.status === 401 && !originalConfig._retry)) return [3 /*break*/, 4];
324
329
  originalConfig._retry = true;
325
- _a.label = 1;
330
+ _c.label = 1;
326
331
  case 1:
327
- _a.trys.push([1, 3, , 4]);
332
+ _c.trys.push([1, 3, , 4]);
328
333
  return [4 /*yield*/, this.refreshTokenInternal()];
329
334
  case 2:
330
- tokenString = _a.sent();
335
+ _a = _c.sent(), tokenString = _a.accessToken, permissions = _a.permissions;
331
336
  accessToken = "Bearer ".concat(tokenString);
337
+ this.permissions = permissions;
332
338
  originalConfig.headers['Authorization'] = "Bearer ".concat(accessToken);
333
339
  this.configuration.accessToken = accessToken;
334
340
  return [2 /*return*/, axios.request(originalConfig)];
335
341
  case 3:
336
- _error_1 = _a.sent();
342
+ _error_1 = _c.sent();
337
343
  if (_error_1.response && _error_1.response.data) {
338
344
  return [2 /*return*/, Promise.reject(_error_1.response.data)];
339
345
  }
@@ -349,19 +355,20 @@ var BaseAPI = /** @class */ (function () {
349
355
  && originalConfig.headers.hasOwnProperty('Authorization')
350
356
  && _retry_count < 4)) return [3 /*break*/, 9];
351
357
  _retry_count++;
352
- _a.label = 6;
358
+ _c.label = 6;
353
359
  case 6:
354
- _a.trys.push([6, 8, , 9]);
360
+ _c.trys.push([6, 8, , 9]);
355
361
  return [4 /*yield*/, this.refreshTokenInternal()];
356
362
  case 7:
357
- tokenString = _a.sent();
363
+ _b = _c.sent(), tokenString = _b.accessToken, permissions = _b.permissions;
358
364
  accessToken = "Bearer ".concat(tokenString);
365
+ this.permissions = permissions;
359
366
  _retry = true;
360
367
  originalConfig.headers['Authorization'] = accessToken;
361
368
  this.configuration.accessToken = accessToken;
362
369
  return [2 /*return*/, axios.request(__assign({}, originalConfig))];
363
370
  case 8:
364
- _error_2 = _a.sent();
371
+ _error_2 = _c.sent();
365
372
  if (_error_2.response && _error_2.response.data) {
366
373
  return [2 /*return*/, Promise.reject(_error_2.response.data)];
367
374
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@emilgroup/claim-sdk-node",
3
- "version": "1.19.0",
3
+ "version": "1.20.0",
4
4
  "description": "OpenAPI client for @emilgroup/claim-sdk-node",
5
5
  "author": "OpenAPI-Generator Contributors",
6
6
  "keywords": [