@kolektor/nucleus-identity 0.0.12-pre.7931 → 0.1.0-pre.124

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.
Files changed (63) hide show
  1. package/README.md +7 -0
  2. package/esm2022/index.mjs +7 -0
  3. package/esm2022/kolektor-nucleus-identity.mjs +5 -0
  4. package/esm2022/lib/models/client-registration.mjs +8 -0
  5. package/esm2022/lib/models/device-code.mjs +19 -0
  6. package/esm2022/lib/models/identity.mjs +52 -0
  7. package/esm2022/lib/models/otp.mjs +11 -0
  8. package/esm2022/lib/models/service-principal.mjs +16 -0
  9. package/esm2022/lib/nucleus-identity-config.mjs +7 -0
  10. package/esm2022/lib/nucleus-identity.module.mjs +32 -0
  11. package/esm2022/lib/nucleus-identity.service.mjs +350 -0
  12. package/esm2022/lib/nucleus-token-interceptor.service.mjs +69 -0
  13. package/esm2022/lib/utils/angular-requestor.mjs +44 -0
  14. package/esm2022/lib/utils/authorization-service-configuration.mjs +28 -0
  15. package/esm2022/lib/utils/location.service.mjs +72 -0
  16. package/esm2022/lib/utils/nucleus-authorization-notifier.mjs +15 -0
  17. package/esm2022/lib/utils/oidc-configuration.service.mjs +95 -0
  18. package/esm2022/lib/utils/secrets-store.mjs +120 -0
  19. package/esm2022/lib/utils/token-client.mjs +140 -0
  20. package/{fesm2020 → fesm2022}/kolektor-nucleus-identity.mjs +980 -1012
  21. package/fesm2022/kolektor-nucleus-identity.mjs.map +1 -0
  22. package/index.d.ts +6 -5
  23. package/lib/models/client-registration.d.ts +11 -11
  24. package/lib/models/device-code.d.ts +19 -19
  25. package/lib/models/identity.d.ts +14 -14
  26. package/lib/models/otp.d.ts +14 -14
  27. package/lib/models/service-principal.d.ts +12 -12
  28. package/lib/nucleus-identity-config.d.ts +12 -12
  29. package/lib/nucleus-identity.module.d.ts +9 -9
  30. package/lib/nucleus-identity.service.d.ts +63 -63
  31. package/lib/nucleus-token-interceptor.service.d.ts +19 -19
  32. package/lib/utils/angular-requestor.d.ts +11 -11
  33. package/lib/utils/authorization-service-configuration.d.ts +12 -12
  34. package/lib/utils/location.service.d.ts +25 -25
  35. package/lib/utils/nucleus-authorization-notifier.d.ts +9 -9
  36. package/lib/utils/oidc-configuration.service.d.ts +23 -23
  37. package/lib/utils/secrets-store.d.ts +33 -33
  38. package/lib/utils/token-client.d.ts +23 -23
  39. package/package.json +29 -33
  40. package/esm2020/kolektor-nucleus-identity.mjs +0 -5
  41. package/esm2020/lib/models/client-registration.mjs +0 -8
  42. package/esm2020/lib/models/device-code.mjs +0 -19
  43. package/esm2020/lib/models/identity.mjs +0 -49
  44. package/esm2020/lib/models/otp.mjs +0 -11
  45. package/esm2020/lib/models/service-principal.mjs +0 -16
  46. package/esm2020/lib/nucleus-identity-config.mjs +0 -8
  47. package/esm2020/lib/nucleus-identity.module.mjs +0 -28
  48. package/esm2020/lib/nucleus-identity.service.mjs +0 -341
  49. package/esm2020/lib/nucleus-token-interceptor.service.mjs +0 -64
  50. package/esm2020/lib/utils/angular-requestor.mjs +0 -38
  51. package/esm2020/lib/utils/authorization-service-configuration.mjs +0 -23
  52. package/esm2020/lib/utils/location.service.mjs +0 -72
  53. package/esm2020/lib/utils/nucleus-authorization-notifier.mjs +0 -13
  54. package/esm2020/lib/utils/nucleus-crypto.mjs +0 -68
  55. package/esm2020/lib/utils/oidc-configuration.service.mjs +0 -90
  56. package/esm2020/lib/utils/secrets-store.mjs +0 -120
  57. package/esm2020/lib/utils/token-client.mjs +0 -140
  58. package/esm2020/public-api.mjs +0 -11
  59. package/fesm2015/kolektor-nucleus-identity.mjs +0 -1139
  60. package/fesm2015/kolektor-nucleus-identity.mjs.map +0 -1
  61. package/fesm2020/kolektor-nucleus-identity.mjs.map +0 -1
  62. package/lib/utils/nucleus-crypto.d.ts +0 -9
  63. package/public-api.d.ts +0 -7
@@ -0,0 +1,140 @@
1
+ import { AppAuthError, BaseTokenRequestHandler, BasicQueryStringUtils, GRANT_TYPE_AUTHORIZATION_CODE, GRANT_TYPE_REFRESH_TOKEN, TokenRequest, } from '@openid/appauth';
2
+ import { OidcConfigurationService } from './oidc-configuration.service';
3
+ import { AngularRequestor } from './angular-requestor';
4
+ import { Injectable } from '@angular/core';
5
+ import { DeviceCode } from '../models/device-code';
6
+ import { ClientRegistrationResponse, } from '../models/client-registration';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "./angular-requestor";
9
+ import * as i2 from "./oidc-configuration.service";
10
+ export class TokenClient {
11
+ constructor(requestor, config) {
12
+ this.requestor = requestor;
13
+ this.config = config;
14
+ this._tokenHandler = new BaseTokenRequestHandler(requestor);
15
+ this._utils = new BasicQueryStringUtils();
16
+ }
17
+ async getByAuthorizationCode(redirectUrl, code, codeVerifier) {
18
+ const config = await this.config.getConfiguration();
19
+ const redirectUri = redirectUrl;
20
+ const req = new TokenRequest({
21
+ client_id: this.config.clientId,
22
+ redirect_uri: redirectUri,
23
+ grant_type: GRANT_TYPE_AUTHORIZATION_CODE,
24
+ code,
25
+ extras: codeVerifier ? { code_verifier: codeVerifier } : undefined,
26
+ });
27
+ return await this._tokenHandler.performTokenRequest(config, req);
28
+ }
29
+ async getByRefreshToken(refreshToken) {
30
+ const config = await this.config.getConfiguration();
31
+ const redirectUri = this.config.redirectUrl;
32
+ const req = new TokenRequest({
33
+ client_id: this.config.clientId,
34
+ redirect_uri: redirectUri,
35
+ grant_type: GRANT_TYPE_REFRESH_TOKEN,
36
+ refresh_token: refreshToken,
37
+ });
38
+ return await this._tokenHandler.performTokenRequest(config, req);
39
+ }
40
+ async getByClientCredentials(clientId, clientSecret, scope) {
41
+ const config = await this.config.getConfiguration();
42
+ const req = new TokenRequest({
43
+ client_id: clientId,
44
+ redirect_uri: '',
45
+ grant_type: 'client_credentials',
46
+ extras: {
47
+ client_secret: clientSecret,
48
+ scope,
49
+ },
50
+ });
51
+ return await this._tokenHandler.performTokenRequest(config, req);
52
+ }
53
+ async getBySecret(provider, secret, assertionToken, scope) {
54
+ const config = await this.config.getConfiguration();
55
+ const req = new TokenRequest({
56
+ client_id: this.config.clientId,
57
+ redirect_uri: '',
58
+ grant_type: 'urn:kolektor:nucleus:secret',
59
+ extras: {
60
+ secret_provider: provider,
61
+ secret_value: secret,
62
+ client_assertion_type: 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer',
63
+ client_assertion: assertionToken,
64
+ scope,
65
+ },
66
+ });
67
+ return await this._tokenHandler.performTokenRequest(config, req);
68
+ }
69
+ async getByDeviceCode(deviceCode) {
70
+ const config = await this.config.getConfiguration();
71
+ const req = new TokenRequest({
72
+ client_id: this.config.clientId,
73
+ redirect_uri: '',
74
+ grant_type: 'urn:ietf:params:oauth:grant-type:device_code',
75
+ extras: {
76
+ device_code: deviceCode,
77
+ },
78
+ });
79
+ return await this._tokenHandler.performTokenRequest(config, req);
80
+ }
81
+ async registerServicePrincipal(token) {
82
+ const config = await this.config.getConfiguration();
83
+ const response = await this.requestor.xhr({
84
+ url: config.registrationEndpoint,
85
+ method: 'POST',
86
+ dataType: 'json',
87
+ headers: {
88
+ 'Content-Type': 'application/json',
89
+ Authorization: `Bearer ${token}`,
90
+ },
91
+ // data: this._utils.stringify(map)
92
+ });
93
+ if (response.error === undefined) {
94
+ return new ClientRegistrationResponse(response);
95
+ }
96
+ else {
97
+ throw new AppAuthError(response.error);
98
+ }
99
+ }
100
+ async getRegistrationCode(existingServicePrincipalId = null) {
101
+ const params = {
102
+ custom_action: 'sp_register',
103
+ service_principal_id: existingServicePrincipalId,
104
+ };
105
+ return this.getDeviceCodeInternal(params);
106
+ }
107
+ async getDeviceCode(scope) {
108
+ const params = {
109
+ scope,
110
+ };
111
+ return this.getDeviceCodeInternal(params);
112
+ }
113
+ async getDeviceCodeInternal(params) {
114
+ const config = await this.config.getConfiguration();
115
+ params['client_id'] = this.config.clientId;
116
+ const map = params;
117
+ const response = await this.requestor.xhr({
118
+ url: config.deviceAuthorizationEndpoint,
119
+ method: 'POST',
120
+ dataType: 'json',
121
+ headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
122
+ data: this._utils.stringify(map),
123
+ });
124
+ if (response.error === undefined) {
125
+ return new DeviceCode(response);
126
+ }
127
+ else {
128
+ throw new AppAuthError(response.error);
129
+ }
130
+ }
131
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TokenClient, deps: [{ token: i1.AngularRequestor }, { token: i2.OidcConfigurationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
132
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TokenClient, providedIn: 'root' }); }
133
+ }
134
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TokenClient, decorators: [{
135
+ type: Injectable,
136
+ args: [{
137
+ providedIn: 'root',
138
+ }]
139
+ }], ctorParameters: function () { return [{ type: i1.AngularRequestor }, { type: i2.OidcConfigurationService }]; } });
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token-client.js","sourceRoot":"","sources":["../../../../../../../libs/ng/nucleus-identity/src/lib/utils/token-client.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,uBAAuB,EACvB,qBAAqB,EACrB,6BAA6B,EAC7B,wBAAwB,EAIxB,YAAY,GAEb,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAkB,MAAM,uBAAuB,CAAC;AACnE,OAAO,EACL,0BAA0B,GAE3B,MAAM,+BAA+B,CAAC;;;;AAKvC,MAAM,OAAO,WAAW;IACtB,YACU,SAA2B,EAC3B,MAAgC;QADhC,cAAS,GAAT,SAAS,CAAkB;QAC3B,WAAM,GAAN,MAAM,CAA0B;QAExC,IAAI,CAAC,aAAa,GAAG,IAAI,uBAAuB,CAAC,SAAS,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM,GAAG,IAAI,qBAAqB,EAAE,CAAC;IAC5C,CAAC;IAKM,KAAK,CAAC,sBAAsB,CACjC,WAAmB,EACnB,IAAY,EACZ,YAAqB;QAErB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,MAAM,WAAW,GAAG,WAAW,CAAC;QAChC,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC;YAC3B,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC/B,YAAY,EAAE,WAAW;YACzB,UAAU,EAAE,6BAA6B;YACzC,IAAI;YACJ,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,SAAS;SACnE,CAAC,CAAC;QACH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEM,KAAK,CAAC,iBAAiB,CAAC,YAAoB;QACjD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;QAC5C,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC;YAC3B,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC/B,YAAY,EAAE,WAAW;YACzB,UAAU,EAAE,wBAAwB;YACpC,aAAa,EAAE,YAAY;SAC5B,CAAC,CAAC;QACH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEM,KAAK,CAAC,sBAAsB,CACjC,QAAgB,EAChB,YAAoB,EACpB,KAAa;QAEb,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC;YAC3B,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,EAAE;YAChB,UAAU,EAAE,oBAAoB;YAChC,MAAM,EAAE;gBACN,aAAa,EAAE,YAAY;gBAC3B,KAAK;aACN;SACF,CAAC,CAAC;QACH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEM,KAAK,CAAC,WAAW,CACtB,QAAgB,EAChB,MAAc,EACd,cAAsB,EACtB,KAAa;QAEb,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC;YAC3B,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC/B,YAAY,EAAE,EAAE;YAChB,UAAU,EAAE,6BAA6B;YACzC,MAAM,EAAE;gBACN,eAAe,EAAE,QAAQ;gBACzB,YAAY,EAAE,MAAM;gBACpB,qBAAqB,EACnB,wDAAwD;gBAC1D,gBAAgB,EAAE,cAAc;gBAChC,KAAK;aACN;SACF,CAAC,CAAC;QAEH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEM,KAAK,CAAC,eAAe,CAAC,UAAkB;QAC7C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,YAAY,CAAC;YAC3B,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC/B,YAAY,EAAE,EAAE;YAChB,UAAU,EAAE,8CAA8C;YAC1D,MAAM,EAAE;gBACN,WAAW,EAAE,UAAU;aACxB;SACF,CAAC,CAAC;QACH,OAAO,MAAM,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACnE,CAAC;IAEM,KAAK,CAAC,wBAAwB,CAAC,KAAa;QACjD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QAEpD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,CAEvC;YACA,GAAG,EAAE,MAAM,CAAC,oBAAoB;YAChC,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,MAAM;YAChB,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,UAAU,KAAK,EAAE;aACjC;YACD,mCAAmC;SACpC,CAAC,CAAC;QAEH,IAAK,QAA2B,CAAC,KAAK,KAAK,SAAS,EAAE;YACpD,OAAO,IAAI,0BAA0B,CACnC,QAA0C,CAC3C,CAAC;SACH;aAAM;YACL,MAAM,IAAI,YAAY,CAAE,QAA2B,CAAC,KAAK,CAAC,CAAC;SAC5D;IACH,CAAC;IAEM,KAAK,CAAC,mBAAmB,CAAC,6BAA4C,IAAI;QAC/E,MAAM,MAAM,GAAG;YACb,aAAa,EAAE,aAAa;YAC5B,oBAAoB,EAAE,0BAA0B;SACjD,CAAC;QAEF,OAAO,IAAI,CAAC,qBAAqB,CAAC,MAAmB,CAAC,CAAC;IACzD,CAAC;IAEM,KAAK,CAAC,aAAa,CAAC,KAAa;QACtC,MAAM,MAAM,GAAG;YACb,KAAK;SACN,CAAC;QACF,OAAO,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IAEO,KAAK,CAAC,qBAAqB,CAAC,MAAiB;QACnD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;QAEpD,MAAM,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;QAC3C,MAAM,GAAG,GAAc,MAAM,CAAC;QAE9B,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,GAAG,CAAkC;YACzE,GAAG,EAAE,MAAM,CAAC,2BAA2B;YACvC,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,MAAM;YAChB,OAAO,EAAE,EAAE,cAAc,EAAE,mCAAmC,EAAE;YAChE,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC;SACjC,CAAC,CAAC;QAEH,IAAK,QAA2B,CAAC,KAAK,KAAK,SAAS,EAAE;YACpD,OAAO,IAAI,UAAU,CAAC,QAA0B,CAAC,CAAC;SACnD;aAAM;YACL,MAAM,IAAI,YAAY,CAAE,QAA2B,CAAC,KAAK,CAAC,CAAC;SAC5D;IACH,CAAC;+GA5JU,WAAW;mHAAX,WAAW,cAFV,MAAM;;4FAEP,WAAW;kBAHvB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import {\n  AppAuthError,\n  BaseTokenRequestHandler,\n  BasicQueryStringUtils,\n  GRANT_TYPE_AUTHORIZATION_CODE,\n  GRANT_TYPE_REFRESH_TOKEN,\n  QueryStringUtils,\n  StringMap,\n  TokenErrorJson,\n  TokenRequest,\n  TokenRequestHandler,\n} from '@openid/appauth';\nimport { OidcConfigurationService } from './oidc-configuration.service';\nimport { AngularRequestor } from './angular-requestor';\nimport { Injectable } from '@angular/core';\nimport { DeviceCode, DeviceCodeJson } from '../models/device-code';\nimport {\n  ClientRegistrationResponse,\n  ClientRegistrationResponseJson,\n} from '../models/client-registration';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class TokenClient {\n  constructor(\n    private requestor: AngularRequestor,\n    private config: OidcConfigurationService\n  ) {\n    this._tokenHandler = new BaseTokenRequestHandler(requestor);\n    this._utils = new BasicQueryStringUtils();\n  }\n\n  private _tokenHandler: TokenRequestHandler;\n  private _utils: QueryStringUtils;\n\n  public async getByAuthorizationCode(\n    redirectUrl: string,\n    code: string,\n    codeVerifier?: string\n  ) {\n    const config = await this.config.getConfiguration();\n    const redirectUri = redirectUrl;\n    const req = new TokenRequest({\n      client_id: this.config.clientId,\n      redirect_uri: redirectUri,\n      grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\n      code,\n      extras: codeVerifier ? { code_verifier: codeVerifier } : undefined,\n    });\n    return await this._tokenHandler.performTokenRequest(config, req);\n  }\n\n  public async getByRefreshToken(refreshToken: string) {\n    const config = await this.config.getConfiguration();\n    const redirectUri = this.config.redirectUrl;\n    const req = new TokenRequest({\n      client_id: this.config.clientId,\n      redirect_uri: redirectUri,\n      grant_type: GRANT_TYPE_REFRESH_TOKEN,\n      refresh_token: refreshToken,\n    });\n    return await this._tokenHandler.performTokenRequest(config, req);\n  }\n\n  public async getByClientCredentials(\n    clientId: string,\n    clientSecret: string,\n    scope: string\n  ) {\n    const config = await this.config.getConfiguration();\n    const req = new TokenRequest({\n      client_id: clientId,\n      redirect_uri: '',\n      grant_type: 'client_credentials',\n      extras: {\n        client_secret: clientSecret,\n        scope,\n      },\n    });\n    return await this._tokenHandler.performTokenRequest(config, req);\n  }\n\n  public async getBySecret(\n    provider: string,\n    secret: string,\n    assertionToken: string,\n    scope: string\n  ) {\n    const config = await this.config.getConfiguration();\n    const req = new TokenRequest({\n      client_id: this.config.clientId,\n      redirect_uri: '',\n      grant_type: 'urn:kolektor:nucleus:secret',\n      extras: {\n        secret_provider: provider,\n        secret_value: secret,\n        client_assertion_type:\n          'urn:ietf:params:oauth:client-assertion-type:jwt-bearer',\n        client_assertion: assertionToken,\n        scope,\n      },\n    });\n\n    return await this._tokenHandler.performTokenRequest(config, req);\n  }\n\n  public async getByDeviceCode(deviceCode: string) {\n    const config = await this.config.getConfiguration();\n    const req = new TokenRequest({\n      client_id: this.config.clientId,\n      redirect_uri: '',\n      grant_type: 'urn:ietf:params:oauth:grant-type:device_code',\n      extras: {\n        device_code: deviceCode,\n      },\n    });\n    return await this._tokenHandler.performTokenRequest(config, req);\n  }\n\n  public async registerServicePrincipal(token: string) {\n    const config = await this.config.getConfiguration();\n\n    const response = await this.requestor.xhr<\n      ClientRegistrationResponseJson | TokenErrorJson\n    >({\n      url: config.registrationEndpoint,\n      method: 'POST',\n      dataType: 'json',\n      headers: {\n        'Content-Type': 'application/json',\n        Authorization: `Bearer ${token}`,\n      },\n      // data: this._utils.stringify(map)\n    });\n\n    if ((response as TokenErrorJson).error === undefined) {\n      return new ClientRegistrationResponse(\n        response as ClientRegistrationResponseJson\n      );\n    } else {\n      throw new AppAuthError((response as TokenErrorJson).error);\n    }\n  }\n\n  public async getRegistrationCode(existingServicePrincipalId: string | null = null) {\n    const params = {\n      custom_action: 'sp_register',\n      service_principal_id: existingServicePrincipalId,\n    };\n\n    return this.getDeviceCodeInternal(params as StringMap);\n  }\n\n  public async getDeviceCode(scope: string) {\n    const params = {\n      scope,\n    };\n    return this.getDeviceCodeInternal(params);\n  }\n\n  private async getDeviceCodeInternal(params: StringMap) {\n    const config = await this.config.getConfiguration();\n\n    params['client_id'] = this.config.clientId;\n    const map: StringMap = params;\n\n    const response = await this.requestor.xhr<DeviceCodeJson | TokenErrorJson>({\n      url: config.deviceAuthorizationEndpoint,\n      method: 'POST',\n      dataType: 'json',\n      headers: { 'Content-Type': 'application/x-www-form-urlencoded' },\n      data: this._utils.stringify(map),\n    });\n\n    if ((response as TokenErrorJson).error === undefined) {\n      return new DeviceCode(response as DeviceCodeJson);\n    } else {\n      throw new AppAuthError((response as TokenErrorJson).error);\n    }\n  }\n}\n"]}