name-password-strategy.service.js 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Injectable } from '@angular/core';
  7. import { NbAuthIllegalTokenError, NbAuthResult, NbAuthStrategy } from '@nebular/auth';
  8. import { of as observableOf } from 'rxjs';
  9. import { switchMap, map, catchError, concatAll } from 'rxjs/operators';
  10. import { HttpClient, HttpErrorResponse } from '@angular/common/http';
  11. import { ActivatedRoute } from '@angular/router';
  12. import { namePasswordStrategyOptions } from './name-password-strategy-option';
  13. import * as JSEncrypt from 'jsencrypt';
  14. var ResultError = /** @class */ (function () {
  15. function ResultError(message) {
  16. this.message = message;
  17. }
  18. return ResultError;
  19. }());
  20. export { ResultError };
  21. if (false) {
  22. /** @type {?} */
  23. ResultError.prototype.message;
  24. }
  25. var NamePasswordStrategyService = /** @class */ (function (_super) {
  26. tslib_1.__extends(NamePasswordStrategyService, _super);
  27. function NamePasswordStrategyService(http, route) {
  28. var _this = _super.call(this) || this;
  29. _this.http = http;
  30. _this.route = route;
  31. _this.defaultOptions = namePasswordStrategyOptions;
  32. return _this;
  33. }
  34. /**
  35. * @param {?} options
  36. * @return {?}
  37. */
  38. NamePasswordStrategyService.setup = /**
  39. * @param {?} options
  40. * @return {?}
  41. */
  42. function (options) {
  43. return [NamePasswordStrategyService, options];
  44. };
  45. /**
  46. * @param {?=} data
  47. * @return {?}
  48. */
  49. NamePasswordStrategyService.prototype.authenticate = /**
  50. * @param {?=} data
  51. * @return {?}
  52. */
  53. function (data) {
  54. var _this = this;
  55. /** @type {?} */
  56. var module = 'login';
  57. /** @type {?} */
  58. var method = this.getOption(module + ".method");
  59. /** @type {?} */
  60. var url = this.getActionEndpoint(module);
  61. /** @type {?} */
  62. var requireValidToken = this.getOption(module + ".requireValidToken");
  63. return this.getEncryptPassword(data.loginPassword).pipe(map((/**
  64. * @param {?} body
  65. * @return {?}
  66. */
  67. function (body) {
  68. body.loginID = data.loginId;
  69. return _this.http.request(method, url, { body: body, observe: 'response' })
  70. .pipe(map((/**
  71. * @param {?} res
  72. * @return {?}
  73. */
  74. function (res) {
  75. if (_this.getOption(module + ".alwaysFail")) {
  76. throw _this.createFailResponse(data);
  77. }
  78. else if (!_this.getOption('success.getter')(module, res, _this.options)) {
  79. throw new ResultError(_this.getOption('messages.getter')(module, res, _this.options));
  80. }
  81. return res;
  82. })), map((/**
  83. * @param {?} res
  84. * @return {?}
  85. */
  86. function (res) {
  87. return new NbAuthResult(true, res, _this.getOption(module + ".redirect.success"), [], _this.getOption('messages.getter')(module, res, _this.options));
  88. })), catchError((/**
  89. * @param {?} res
  90. * @return {?}
  91. */
  92. function (res) {
  93. return _this.handleResponseError(res, module);
  94. })));
  95. })), concatAll());
  96. };
  97. /**
  98. * @return {?}
  99. */
  100. NamePasswordStrategyService.prototype.logout = /**
  101. * @return {?}
  102. */
  103. function () {
  104. var _this = this;
  105. /** @type {?} */
  106. var module = 'logout';
  107. /** @type {?} */
  108. var method = this.getOption(module + ".method");
  109. /** @type {?} */
  110. var url = this.getActionEndpoint(module);
  111. return observableOf({})
  112. .pipe(switchMap((/**
  113. * @param {?} res
  114. * @return {?}
  115. */
  116. function (res) {
  117. if (!url) {
  118. return observableOf(res);
  119. }
  120. return _this.http.request(method, url, { observe: 'response' });
  121. })), map((/**
  122. * @param {?} res
  123. * @return {?}
  124. */
  125. function (res) {
  126. if (_this.getOption(module + ".alwaysFail")) {
  127. throw _this.createFailResponse();
  128. }
  129. return res;
  130. })), map((/**
  131. * @param {?} res
  132. * @return {?}
  133. */
  134. function (res) {
  135. return new NbAuthResult(true, res, _this.getOption(module + ".redirect.success"), [], _this.getOption('messages.getter')(module, res, _this.options));
  136. })), catchError((/**
  137. * @param {?} res
  138. * @return {?}
  139. */
  140. function (res) {
  141. return _this.handleResponseError(res, module);
  142. })));
  143. };
  144. /**
  145. * @param {?=} data
  146. * @return {?}
  147. */
  148. NamePasswordStrategyService.prototype.refreshToken = /**
  149. * @param {?=} data
  150. * @return {?}
  151. */
  152. function (data) {
  153. return undefined;
  154. };
  155. /**
  156. * @param {?=} data
  157. * @return {?}
  158. */
  159. NamePasswordStrategyService.prototype.register = /**
  160. * @param {?=} data
  161. * @return {?}
  162. */
  163. function (data) {
  164. return undefined;
  165. };
  166. /**
  167. * @param {?=} data
  168. * @return {?}
  169. */
  170. NamePasswordStrategyService.prototype.requestPassword = /**
  171. * @param {?=} data
  172. * @return {?}
  173. */
  174. function (data) {
  175. return undefined;
  176. };
  177. /**
  178. * @param {?=} data
  179. * @return {?}
  180. */
  181. NamePasswordStrategyService.prototype.resetPassword = /**
  182. * @param {?=} data
  183. * @return {?}
  184. */
  185. function (data) {
  186. var _this = this;
  187. /** @type {?} */
  188. var module = 'resetPass';
  189. /** @type {?} */
  190. var method = this.getOption(module + ".method");
  191. /** @type {?} */
  192. var url = this.getActionEndpoint(module);
  193. return this.getEncryptPassword(data.loginPasswordNew + '-' + data.loginPasswordOld).pipe(map((/**
  194. * @param {?} body
  195. * @return {?}
  196. */
  197. function (body) {
  198. body.passwordData = body.loginPassword;
  199. return _this.http.request(method, url, { body: body, observe: 'response' })
  200. .pipe(map((/**
  201. * @param {?} res
  202. * @return {?}
  203. */
  204. function (res) {
  205. if (_this.getOption(module + ".alwaysFail")) {
  206. throw _this.createFailResponse(data);
  207. }
  208. else if (!_this.getOption('success.getter')(module, res, _this.options)) {
  209. throw new ResultError(_this.getOption('messages.getter')(module, res, _this.options));
  210. }
  211. return res;
  212. })), map((/**
  213. * @param {?} res
  214. * @return {?}
  215. */
  216. function (res) {
  217. return new NbAuthResult(true, res, _this.getOption(module + ".redirect.success"), [], _this.getOption('messages.getter')(module, res, _this.options));
  218. })), catchError((/**
  219. * @param {?} res
  220. * @return {?}
  221. */
  222. function (res) {
  223. return _this.handleResponseError(res, module);
  224. })));
  225. })), concatAll());
  226. };
  227. /**
  228. * @param {?=} data
  229. * @return {?}
  230. */
  231. NamePasswordStrategyService.prototype.createUser = /**
  232. * @param {?=} data
  233. * @return {?}
  234. */
  235. function (data) {
  236. var _this = this;
  237. /** @type {?} */
  238. var module = 'createUser';
  239. /** @type {?} */
  240. var method = this.getOption(module + ".method");
  241. /** @type {?} */
  242. var url = this.getActionEndpoint(module);
  243. return this.getEncryptPassword(data.loginPassword).pipe(map((/**
  244. * @param {?} body
  245. * @return {?}
  246. */
  247. function (body) {
  248. body.userName = data.userName;
  249. body.loginID = data.loginID;
  250. return _this.http.request(method, url, { body: body, observe: 'response' })
  251. .pipe(map((/**
  252. * @param {?} res
  253. * @return {?}
  254. */
  255. function (res) {
  256. if (_this.getOption(module + ".alwaysFail")) {
  257. throw _this.createFailResponse(data);
  258. }
  259. else if (!_this.getOption('success.getter')(module, res, _this.options)) {
  260. throw new ResultError(_this.getOption('messages.getter')(module, res, _this.options));
  261. }
  262. return res;
  263. })), map((/**
  264. * @param {?} res
  265. * @return {?}
  266. */
  267. function (res) {
  268. return new NbAuthResult(true, res, _this.getOption(module + ".redirect.success"), [], _this.getOption('messages.getter')(module, res, _this.options));
  269. })), catchError((/**
  270. * @param {?} res
  271. * @return {?}
  272. */
  273. function (res) {
  274. return _this.handleResponseError(res, module);
  275. })));
  276. })), concatAll());
  277. };
  278. /**
  279. * @param {?=} data
  280. * @return {?}
  281. */
  282. NamePasswordStrategyService.prototype.updatePasswordForAdmin = /**
  283. * @param {?=} data
  284. * @return {?}
  285. */
  286. function (data) {
  287. var _this = this;
  288. /** @type {?} */
  289. var module = 'updatePasswordForAdmin';
  290. /** @type {?} */
  291. var method = this.getOption(module + ".method");
  292. /** @type {?} */
  293. var url = this.getActionEndpoint(module);
  294. return this.getEncryptPassword(data.loginPassword).pipe(map((/**
  295. * @param {?} body
  296. * @return {?}
  297. */
  298. function (body) {
  299. body.userID = data.userID;
  300. return _this.http.request(method, url, { body: body, observe: 'response' })
  301. .pipe(map((/**
  302. * @param {?} res
  303. * @return {?}
  304. */
  305. function (res) {
  306. if (_this.getOption(module + ".alwaysFail")) {
  307. throw _this.createFailResponse(data);
  308. }
  309. else if (!_this.getOption('success.getter')(module, res, _this.options)) {
  310. throw new ResultError(_this.getOption('messages.getter')(module, res, _this.options));
  311. }
  312. return res;
  313. })), map((/**
  314. * @param {?} res
  315. * @return {?}
  316. */
  317. function (res) {
  318. return new NbAuthResult(true, res, _this.getOption(module + ".redirect.success"), [], _this.getOption('messages.getter')(module, res, _this.options));
  319. })), catchError((/**
  320. * @param {?} res
  321. * @return {?}
  322. */
  323. function (res) {
  324. return _this.handleResponseError(res, module);
  325. })));
  326. })), concatAll());
  327. };
  328. /**
  329. * @param {?} password
  330. * @return {?}
  331. */
  332. NamePasswordStrategyService.prototype.getEncryptPassword = /**
  333. * @param {?} password
  334. * @return {?}
  335. */
  336. function (password) {
  337. var _this = this;
  338. /** @type {?} */
  339. var module = 'getPublicKey';
  340. /** @type {?} */
  341. var method = this.getOption(module + ".method");
  342. /** @type {?} */
  343. var url = this.getActionEndpoint(module);
  344. return this.http.request(method, url, { observe: 'response' })
  345. .pipe(map((/**
  346. * @param {?} res
  347. * @return {?}
  348. */
  349. function (res) {
  350. return encryptPassword(res.body, password);
  351. })), catchError((/**
  352. * @param {?} res
  353. * @return {?}
  354. */
  355. function (res) {
  356. return _this.handleResponseError(res, module);
  357. })));
  358. /**
  359. * @param {?} result
  360. * @param {?} data
  361. * @return {?}
  362. */
  363. function encryptPassword(result, data) {
  364. /** @type {?} */
  365. var now = Date.now();
  366. /** @type {?} */
  367. var encrypt = new JSEncrypt.JSEncrypt();
  368. encrypt.setPublicKey(result.data.publicPEMKey);
  369. /** @type {?} */
  370. var encryptPass = encrypt.encrypt(data + now);
  371. return {
  372. cryptoKeyID: result.data.cryptoKeyID,
  373. utcTimestamp: now,
  374. loginPassword: encryptPass
  375. };
  376. }
  377. };
  378. /**
  379. * @protected
  380. * @param {?} res
  381. * @param {?} module
  382. * @return {?}
  383. */
  384. NamePasswordStrategyService.prototype.handleResponseError = /**
  385. * @protected
  386. * @param {?} res
  387. * @param {?} module
  388. * @return {?}
  389. */
  390. function (res, module) {
  391. /** @type {?} */
  392. var errors = [];
  393. if (res instanceof HttpErrorResponse) {
  394. errors = this.getOption('errors.getter')(module, res, this.options);
  395. }
  396. else if (res instanceof NbAuthIllegalTokenError) {
  397. errors.push(res.message);
  398. }
  399. else if (res instanceof ResultError) {
  400. errors = res.message;
  401. }
  402. else {
  403. errors.push('Something went wrong.');
  404. }
  405. return observableOf(new NbAuthResult(false, res, this.getOption(module + ".redirect.failure"), errors));
  406. };
  407. NamePasswordStrategyService.decorators = [
  408. { type: Injectable }
  409. ];
  410. /** @nocollapse */
  411. NamePasswordStrategyService.ctorParameters = function () { return [
  412. { type: HttpClient },
  413. { type: ActivatedRoute }
  414. ]; };
  415. return NamePasswordStrategyService;
  416. }(NbAuthStrategy));
  417. export { NamePasswordStrategyService };
  418. if (false) {
  419. /**
  420. * @type {?}
  421. * @protected
  422. */
  423. NamePasswordStrategyService.prototype.defaultOptions;
  424. /**
  425. * @type {?}
  426. * @protected
  427. */
  428. NamePasswordStrategyService.prototype.http;
  429. /**
  430. * @type {?}
  431. * @private
  432. */
  433. NamePasswordStrategyService.prototype.route;
  434. }
  435. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"name-password-strategy.service.js","sourceRoot":"ng://ge-admin-auth/","sources":["lib/strategy/name-password-strategy.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport {\r\n  NB_AUTH_OPTIONS,\r\n  NbAuthIllegalTokenError,\r\n  NbAuthResult,\r\n  NbAuthStrategy, NbAuthStrategyClass\r\n} from '@nebular/auth';\r\nimport { Observable, of as observableOf } from 'rxjs';\r\nimport { switchMap, map, catchError, concatAll } from 'rxjs/operators';\r\nimport { HttpClient, HttpErrorResponse, HttpHeaders, HttpResponse, HttpResponseBase } from '@angular/common/http';\r\nimport { throwError as _observableThrow } from 'rxjs/index';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { NamePasswordAuthStrategyOptions, namePasswordStrategyOptions } from './name-password-strategy-option';\r\nimport * as JSEncrypt from 'jsencrypt';\r\n\r\n\r\nexport class ResultError {\r\n  constructor(public message: String[]) {\r\n\r\n  }\r\n}\r\n\r\n@Injectable()\r\nexport class NamePasswordStrategyService extends NbAuthStrategy {\r\n\r\n  static setup(options: NamePasswordAuthStrategyOptions): [NbAuthStrategyClass, NamePasswordAuthStrategyOptions] {\r\n    return [NamePasswordStrategyService, options];\r\n  }\r\n\r\n  protected defaultOptions: NamePasswordAuthStrategyOptions = namePasswordStrategyOptions;\r\n\r\n  constructor(protected http: HttpClient, private route: ActivatedRoute) {\r\n    super();\r\n  }\r\n\r\n  authenticate(data?: any): Observable<NbAuthResult> {\r\n    const module = 'login';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n    const requireValidToken = this.getOption(`${module}.requireValidToken`);\r\n    return this.getEncryptPassword(data.loginPassword).pipe(map((body) => {\r\n      body.loginID = data.loginId;\r\n      return this.http.request(method, url, { body, observe: 'response' })\r\n        .pipe(\r\n          map((res) => {\r\n            if (this.getOption(`${module}.alwaysFail`)) {\r\n              throw this.createFailResponse(data);\r\n            } else if (!this.getOption('success.getter')(module, res, this.options)) {\r\n              throw new ResultError(this.getOption('messages.getter')(module, res, this.options));\r\n            }\r\n            return res;\r\n          }),\r\n          map((res) => {\r\n            return new NbAuthResult(\r\n              true,\r\n              res,\r\n              this.getOption(`${module}.redirect.success`),\r\n              [],\r\n              this.getOption('messages.getter')(module, res, this.options));\r\n          }),\r\n          catchError((res) => {\r\n            return this.handleResponseError(res, module);\r\n          })\r\n        );\r\n    }), concatAll());\r\n\r\n\r\n  }\r\n\r\n\r\n  logout(): Observable<NbAuthResult> {\r\n    const module = 'logout';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n\r\n    return observableOf({})\r\n      .pipe(\r\n        switchMap((res: any) => {\r\n          if (!url) {\r\n            return observableOf(res);\r\n          }\r\n          return this.http.request(method, url, { observe: 'response' });\r\n        }),\r\n        map((res) => {\r\n          if (this.getOption(`${module}.alwaysFail`)) {\r\n            throw this.createFailResponse();\r\n          }\r\n\r\n          return res;\r\n        }),\r\n        map((res) => {\r\n          return new NbAuthResult(\r\n            true,\r\n            res,\r\n            this.getOption(`${module}.redirect.success`),\r\n            [],\r\n            this.getOption('messages.getter')(module, res, this.options));\r\n        }),\r\n        catchError((res) => {\r\n          return this.handleResponseError(res, module);\r\n        })\r\n      );\r\n  }\r\n\r\n  refreshToken(data?: any): Observable<NbAuthResult> {\r\n    return undefined;\r\n  }\r\n\r\n  register(data?: any): Observable<NbAuthResult> {\r\n    return undefined;\r\n  }\r\n\r\n  requestPassword(data?: any): Observable<NbAuthResult> {\r\n    return undefined;\r\n  }\r\n\r\n  resetPassword(data?: any): Observable<NbAuthResult> {\r\n    const module = 'resetPass';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n    return this.getEncryptPassword(data.loginPasswordNew + '-' + data.loginPasswordOld).pipe(map((body) => {\r\n      body.passwordData = body.loginPassword;\r\n      return this.http.request(method, url, { body, observe: 'response' })\r\n        .pipe(\r\n          map((res) => {\r\n            if (this.getOption(`${module}.alwaysFail`)) {\r\n              throw this.createFailResponse(data);\r\n            } else if (!this.getOption('success.getter')(module, res, this.options)) {\r\n              throw new ResultError(this.getOption('messages.getter')(module, res, this.options));\r\n            }\r\n            return res;\r\n          }),\r\n          map((res) => {\r\n            return new NbAuthResult(\r\n              true,\r\n              res,\r\n              this.getOption(`${module}.redirect.success`),\r\n              [],\r\n              this.getOption('messages.getter')(module, res, this.options));\r\n          }),\r\n          catchError((res) => {\r\n            return this.handleResponseError(res, module);\r\n          })\r\n        );\r\n    }), concatAll());\r\n  }\r\n\r\n  createUser(data?: any): Observable<NbAuthResult> {\r\n    const module = 'createUser';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n    return this.getEncryptPassword(data.loginPassword).pipe(map((body) => {\r\n      body.userName = data.userName;\r\n      body.loginID = data.loginID;\r\n      return this.http.request(method, url, { body, observe: 'response' })\r\n        .pipe(\r\n          map((res) => {\r\n            if (this.getOption(`${module}.alwaysFail`)) {\r\n              throw this.createFailResponse(data);\r\n            } else if (!this.getOption('success.getter')(module, res, this.options)) {\r\n              throw new ResultError(this.getOption('messages.getter')(module, res, this.options));\r\n            }\r\n            return res;\r\n          }),\r\n          map((res) => {\r\n            return new NbAuthResult(\r\n              true,\r\n              res,\r\n              this.getOption(`${module}.redirect.success`),\r\n              [],\r\n              this.getOption('messages.getter')(module, res, this.options));\r\n          }),\r\n          catchError((res) => {\r\n            return this.handleResponseError(res, module);\r\n          })\r\n        );\r\n    }), concatAll());\r\n  }\r\n\r\n  updatePasswordForAdmin(data?: any): Observable<NbAuthResult> {\r\n    const module = 'updatePasswordForAdmin';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n    return this.getEncryptPassword(data.loginPassword).pipe(map((body) => {\r\n      body.userID = data.userID;\r\n      return this.http.request(method, url, { body, observe: 'response' })\r\n        .pipe(\r\n          map((res) => {\r\n            if (this.getOption(`${module}.alwaysFail`)) {\r\n              throw this.createFailResponse(data);\r\n            } else if (!this.getOption('success.getter')(module, res, this.options)) {\r\n              throw new ResultError(this.getOption('messages.getter')(module, res, this.options));\r\n            }\r\n            return res;\r\n          }),\r\n          map((res) => {\r\n            return new NbAuthResult(\r\n              true,\r\n              res,\r\n              this.getOption(`${module}.redirect.success`),\r\n              [],\r\n              this.getOption('messages.getter')(module, res, this.options));\r\n          }),\r\n          catchError((res) => {\r\n            return this.handleResponseError(res, module);\r\n          })\r\n        );\r\n    }), concatAll());\r\n  }\r\n\r\n\r\n  getEncryptPassword(password): Observable<any> {\r\n    const module = 'getPublicKey';\r\n    const method = this.getOption(`${module}.method`);\r\n    const url = this.getActionEndpoint(module);\r\n    return this.http.request(method, url, { observe: 'response' })\r\n      .pipe(\r\n        map((res) => {\r\n          return encryptPassword(res.body, password);\r\n        }),\r\n        catchError((res) => {\r\n          return this.handleResponseError(res, module);\r\n        })\r\n      );\r\n\r\n    function encryptPassword(result, data) {\r\n      let now = Date.now();\r\n      let encrypt = new JSEncrypt.JSEncrypt();\r\n      encrypt.setPublicKey(result.data.publicPEMKey);\r\n      let encryptPass = encrypt.encrypt(data + now);\r\n      return {\r\n        cryptoKeyID: result.data.cryptoKeyID,\r\n        utcTimestamp: now,\r\n        loginPassword: encryptPass\r\n      };\r\n    }\r\n  }\r\n\r\n\r\n  protected handleResponseError(res: any, module: string): Observable<NbAuthResult> {\r\n    let errors = [];\r\n    if (res instanceof HttpErrorResponse) {\r\n      errors = this.getOption('errors.getter')(module, res, this.options);\r\n    } else if (res instanceof NbAuthIllegalTokenError) {\r\n      errors.push(res.message);\r\n    } else if (res instanceof ResultError) {\r\n      errors = res.message;\r\n    } else {\r\n      errors.push('Something went wrong.');\r\n    }\r\n    return observableOf(\r\n      new NbAuthResult(\r\n        false,\r\n        res,\r\n        this.getOption(`${module}.redirect.failure`),\r\n        errors\r\n      ));\r\n  }\r\n}\r\n\r\n"]}