@sunbird-cb/utils-v2 0.0.21 → 0.0.22-ang-9-12

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 (164) hide show
  1. package/bundles/sunbird-cb-utils-v2.umd.js +1284 -2508
  2. package/bundles/sunbird-cb-utils-v2.umd.js.map +1 -1
  3. package/bundles/sunbird-cb-utils-v2.umd.min.js +1 -1
  4. package/bundles/sunbird-cb-utils-v2.umd.min.js.map +1 -1
  5. package/esm2015/lib/components/image-crop/image-crop.component.js +19 -47
  6. package/esm2015/lib/components/image-crop/image-crop.module.js +8 -2
  7. package/esm2015/lib/constants/features.enum.js +555 -555
  8. package/esm2015/lib/constants/instances.enum.js +5 -5
  9. package/esm2015/lib/constants/misc.constants.js +1 -0
  10. package/esm2015/lib/directives/class-change-on-scroll/class-change-on-scroll.directive.js +11 -21
  11. package/esm2015/lib/directives/default-thumbnail/default-thumbnail.directive.js +1 -7
  12. package/esm2015/lib/directives/image-responsive/image-responsive.directive.js +6 -11
  13. package/esm2015/lib/directives/in-view-port/in-view-port.directive.js +9 -12
  14. package/esm2015/lib/directives/navigation/navigation.directive.js +1 -6
  15. package/esm2015/lib/helpers/functions/getStringifiedQueryParams.js +4 -4
  16. package/esm2015/lib/helpers/horizontal-scroller/horizontal-scroller.component.js +10 -19
  17. package/esm2015/lib/helpers/horizontal-scroller/horizontal-scroller.module.js +4 -2
  18. package/esm2015/lib/helpers/horizontal-scroller-v2/horizontal-scroller-v2.component.js +15 -31
  19. package/esm2015/lib/helpers/horizontal-scroller-v2/horizontal-scroller-v2.module.js +4 -2
  20. package/esm2015/lib/helpers/logout/logout.component.js +11 -14
  21. package/esm2015/lib/helpers/logout/logout.module.js +3 -2
  22. package/esm2015/lib/models/profile-v3.models.js +2 -104
  23. package/esm2015/lib/pipes/pipe-certificate-image-URL/pipe-certimage-URL.pipe.js +4 -4
  24. package/esm2015/lib/pipes/pipe-concise-date-range/pipe-concise-date-range.pipe.js +1 -7
  25. package/esm2015/lib/pipes/pipe-count-transform/pipe-count-transform.pipe.js +1 -1
  26. package/esm2015/lib/pipes/pipe-coursename/pipe-coursename.pipe.js +1 -1
  27. package/esm2015/lib/pipes/pipe-date-concat/pipe-date-concat.pipe.js +1 -11
  28. package/esm2015/lib/pipes/pipe-duration-transform/pipe-duration-transform.pipe.js +1 -1
  29. package/esm2015/lib/pipes/pipe-filter/pipe-filter.pipe.js +3 -3
  30. package/esm2015/lib/pipes/pipe-filter-search/pipe-filter-search.pipe.js +5 -5
  31. package/esm2015/lib/pipes/pipe-filter-v2/pipe-filter-v2.pipe.js +3 -3
  32. package/esm2015/lib/pipes/pipe-filter-v3/pipe-filter-v3.pipe.js +6 -6
  33. package/esm2015/lib/pipes/pipe-limit-to/pipe-limit-to.pipe.js +1 -1
  34. package/esm2015/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.js +4 -4
  35. package/esm2015/lib/pipes/pipe-name-transform/pipe-name-transform.pipe.js +1 -6
  36. package/esm2015/lib/pipes/pipe-nic-relative/pipe-nic-relative.pipe.js +4 -4
  37. package/esm2015/lib/pipes/pipe-order-by/pipe-order-by.pipe.js +1 -4
  38. package/esm2015/lib/pipes/pipe-ordinal/pipe-ordinal.pipe.js +1 -1
  39. package/esm2015/lib/pipes/pipe-partial-content/pipe-partial-content.pipe.js +1 -1
  40. package/esm2015/lib/pipes/pipe-public-URL/pipe-public-URL.pipe.js +4 -4
  41. package/esm2015/lib/pipes/pipe-safe-sanitizer/pipe-safe-sanitizer.pipe.js +5 -5
  42. package/esm2015/lib/resolvers/explore-detail.resolver.js +17 -19
  43. package/esm2015/lib/resolvers/marketing-offering.resolve.js +10 -10
  44. package/esm2015/lib/resolvers/module-name.resolver.js +2 -5
  45. package/esm2015/lib/resolvers/page-name.resolver.js +2 -2
  46. package/esm2015/lib/resolvers/page.constant.js +1 -1
  47. package/esm2015/lib/resolvers/page.model.js +2 -48
  48. package/esm2015/lib/resolvers/page.resolver.js +16 -17
  49. package/esm2015/lib/resolvers/resolver.model.js +2 -6
  50. package/esm2015/lib/services/auth-keycloak.service.js +35 -35
  51. package/esm2015/lib/services/auth-microsoft.service.js +21 -17
  52. package/esm2015/lib/services/card-content.model.js +1 -21
  53. package/esm2015/lib/services/configurations.model.js +2 -551
  54. package/esm2015/lib/services/configurations.service.js +2 -63
  55. package/esm2015/lib/services/content-strip-multiple.model.js +2 -75
  56. package/esm2015/lib/services/event.model.js +1 -114
  57. package/esm2015/lib/services/event.service.js +31 -24
  58. package/esm2015/lib/services/logger.service.js +8 -13
  59. package/esm2015/lib/services/ms-office.model.js +2 -8
  60. package/esm2015/lib/services/multilingual-translations.service.js +11 -15
  61. package/esm2015/lib/services/nps-grid.service.js +6 -8
  62. package/esm2015/lib/services/subapplication-respond.service.js +16 -20
  63. package/esm2015/lib/services/telemetry.service.js +73 -80
  64. package/esm2015/lib/services/user-preference.model.js +2 -38
  65. package/esm2015/lib/services/user-preference.service.js +23 -15
  66. package/esm2015/lib/services/utility.service.js +16 -27
  67. package/esm2015/lib/services/value.service.js +8 -10
  68. package/esm2015/lib/services/widget-content.model.js +1 -242
  69. package/esm2015/lib/services/widget-content.service.js +29 -21
  70. package/esm2015/lib/services/widget-resolver.model.js +2 -57
  71. package/esm2015/lib/services/widget-search.model.js +2 -126
  72. package/esm2015/public-api.js +96 -88
  73. package/esm2015/sunbird-cb-utils-v2.js +2 -10
  74. package/esm5/lib/components/image-crop/image-crop.component.js +30 -48
  75. package/esm5/lib/components/image-crop/image-crop.module.js +8 -2
  76. package/esm5/lib/constants/features.enum.js +555 -555
  77. package/esm5/lib/constants/instances.enum.js +5 -5
  78. package/esm5/lib/constants/misc.constants.js +1 -0
  79. package/esm5/lib/directives/class-change-on-scroll/class-change-on-scroll.directive.js +14 -24
  80. package/esm5/lib/directives/default-thumbnail/default-thumbnail.directive.js +1 -7
  81. package/esm5/lib/directives/image-responsive/image-responsive.directive.js +6 -11
  82. package/esm5/lib/directives/in-view-port/in-view-port.directive.js +9 -12
  83. package/esm5/lib/directives/navigation/navigation.directive.js +1 -6
  84. package/esm5/lib/helpers/functions/getStringifiedQueryParams.js +4 -4
  85. package/esm5/lib/helpers/horizontal-scroller/horizontal-scroller.component.js +10 -19
  86. package/esm5/lib/helpers/horizontal-scroller/horizontal-scroller.module.js +4 -2
  87. package/esm5/lib/helpers/horizontal-scroller-v2/horizontal-scroller-v2.component.js +15 -31
  88. package/esm5/lib/helpers/horizontal-scroller-v2/horizontal-scroller-v2.module.js +4 -2
  89. package/esm5/lib/helpers/logout/logout.component.js +12 -15
  90. package/esm5/lib/helpers/logout/logout.module.js +3 -2
  91. package/esm5/lib/models/profile-v3.models.js +2 -104
  92. package/esm5/lib/pipes/pipe-certificate-image-URL/pipe-certimage-URL.pipe.js +4 -4
  93. package/esm5/lib/pipes/pipe-concise-date-range/pipe-concise-date-range.pipe.js +1 -7
  94. package/esm5/lib/pipes/pipe-count-transform/pipe-count-transform.pipe.js +1 -1
  95. package/esm5/lib/pipes/pipe-coursename/pipe-coursename.pipe.js +1 -1
  96. package/esm5/lib/pipes/pipe-date-concat/pipe-date-concat.pipe.js +1 -11
  97. package/esm5/lib/pipes/pipe-duration-transform/pipe-duration-transform.pipe.js +1 -1
  98. package/esm5/lib/pipes/pipe-filter/pipe-filter.pipe.js +3 -3
  99. package/esm5/lib/pipes/pipe-filter-search/pipe-filter-search.pipe.js +5 -5
  100. package/esm5/lib/pipes/pipe-filter-v2/pipe-filter-v2.pipe.js +3 -3
  101. package/esm5/lib/pipes/pipe-filter-v3/pipe-filter-v3.pipe.js +9 -9
  102. package/esm5/lib/pipes/pipe-limit-to/pipe-limit-to.pipe.js +1 -1
  103. package/esm5/lib/pipes/pipe-list-filter/pipe-list-filter.pipe.js +4 -4
  104. package/esm5/lib/pipes/pipe-name-transform/pipe-name-transform.pipe.js +1 -6
  105. package/esm5/lib/pipes/pipe-nic-relative/pipe-nic-relative.pipe.js +4 -4
  106. package/esm5/lib/pipes/pipe-order-by/pipe-order-by.pipe.js +1 -4
  107. package/esm5/lib/pipes/pipe-ordinal/pipe-ordinal.pipe.js +1 -1
  108. package/esm5/lib/pipes/pipe-partial-content/pipe-partial-content.pipe.js +13 -3
  109. package/esm5/lib/pipes/pipe-public-URL/pipe-public-URL.pipe.js +4 -4
  110. package/esm5/lib/pipes/pipe-safe-sanitizer/pipe-safe-sanitizer.pipe.js +5 -5
  111. package/esm5/lib/resolvers/explore-detail.resolver.js +17 -19
  112. package/esm5/lib/resolvers/marketing-offering.resolve.js +10 -10
  113. package/esm5/lib/resolvers/module-name.resolver.js +2 -5
  114. package/esm5/lib/resolvers/page-name.resolver.js +2 -2
  115. package/esm5/lib/resolvers/page.constant.js +1 -1
  116. package/esm5/lib/resolvers/page.model.js +2 -48
  117. package/esm5/lib/resolvers/page.resolver.js +36 -22
  118. package/esm5/lib/resolvers/resolver.model.js +2 -6
  119. package/esm5/lib/services/auth-keycloak.service.js +86 -48
  120. package/esm5/lib/services/auth-microsoft.service.js +55 -24
  121. package/esm5/lib/services/card-content.model.js +1 -21
  122. package/esm5/lib/services/configurations.model.js +2 -551
  123. package/esm5/lib/services/configurations.service.js +2 -63
  124. package/esm5/lib/services/content-strip-multiple.model.js +2 -75
  125. package/esm5/lib/services/event.model.js +1 -114
  126. package/esm5/lib/services/event.service.js +66 -28
  127. package/esm5/lib/services/logger.service.js +12 -17
  128. package/esm5/lib/services/ms-office.model.js +2 -8
  129. package/esm5/lib/services/multilingual-translations.service.js +11 -15
  130. package/esm5/lib/services/nps-grid.service.js +6 -8
  131. package/esm5/lib/services/subapplication-respond.service.js +30 -24
  132. package/esm5/lib/services/telemetry.service.js +94 -91
  133. package/esm5/lib/services/user-preference.model.js +2 -38
  134. package/esm5/lib/services/user-preference.service.js +63 -17
  135. package/esm5/lib/services/utility.service.js +23 -34
  136. package/esm5/lib/services/value.service.js +8 -10
  137. package/esm5/lib/services/widget-content.model.js +1 -242
  138. package/esm5/lib/services/widget-content.service.js +69 -23
  139. package/esm5/lib/services/widget-resolver.model.js +2 -57
  140. package/esm5/lib/services/widget-search.model.js +2 -126
  141. package/esm5/public-api.js +96 -88
  142. package/esm5/sunbird-cb-utils-v2.js +2 -10
  143. package/fesm2015/sunbird-cb-utils-v2.js +972 -2207
  144. package/fesm2015/sunbird-cb-utils-v2.js.map +1 -1
  145. package/fesm5/sunbird-cb-utils-v2.js +1262 -2264
  146. package/fesm5/sunbird-cb-utils-v2.js.map +1 -1
  147. package/lib/directives/class-change-on-scroll/class-change-on-scroll.directive.d.ts +3 -3
  148. package/lib/helpers/logout/logout.component.d.ts +2 -2
  149. package/lib/pipes/pipe-order-by/pipe-order-by.pipe.d.ts +4 -4
  150. package/lib/resolvers/page.model.d.ts +1 -1
  151. package/lib/services/auth-keycloak.service.d.ts +9 -9
  152. package/lib/services/auth-microsoft.service.d.ts +2 -2
  153. package/lib/services/configurations.model.d.ts +29 -27
  154. package/lib/services/content-strip-multiple.model.d.ts +7 -6
  155. package/lib/services/event.service.d.ts +2 -0
  156. package/lib/services/logger.service.d.ts +4 -4
  157. package/lib/services/telemetry.service.d.ts +3 -3
  158. package/lib/services/utility.service.d.ts +7 -7
  159. package/lib/services/widget-content.model.d.ts +21 -20
  160. package/package.json +12 -12
  161. package/public-api.d.ts +8 -0
  162. package/sunbird-cb-utils-v2-0.0.22-ang-9-12.tgz +0 -0
  163. package/sunbird-cb-utils-v2.d.ts +0 -8
  164. package/sunbird-cb-utils-v2.metadata.json +1 -1
@@ -1,7 +1,53 @@
1
- import * as tslib_1 from "tslib";
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (_) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
2
48
  import { HttpClient } from '@angular/common/http';
3
49
  import { Injectable } from '@angular/core';
4
- import { KeycloakEventType, KeycloakService } from 'keycloak-angular';
50
+ import { KeycloakEvent, KeycloakEventType, KeycloakInitOptions, KeycloakService } from 'keycloak-angular';
5
51
  import { fromEvent, ReplaySubject } from 'rxjs';
6
52
  import { filter } from 'rxjs/operators';
7
53
  import { AuthMicrosoftService } from './auth-microsoft.service';
@@ -11,13 +57,6 @@ import * as i1 from "@angular/common/http";
11
57
  import * as i2 from "./configurations.service";
12
58
  import * as i3 from "keycloak-angular";
13
59
  import * as i4 from "./auth-microsoft.service";
14
- function IParsedToken() { }
15
- if (false) {
16
- IParsedToken.prototype.email;
17
- IParsedToken.prototype.encEmail;
18
- IParsedToken.prototype.name;
19
- IParsedToken.prototype.preferred_username;
20
- }
21
60
  var storage = localStorage;
22
61
  var storageKey = 'kc';
23
62
  var AuthKeycloakService = (function () {
@@ -28,7 +67,7 @@ var AuthKeycloakService = (function () {
28
67
  this.keycloakSvc = keycloakSvc;
29
68
  this.msAuthSvc = msAuthSvc;
30
69
  this.loginChangeSubject = new ReplaySubject(1);
31
- this.loginChangeSubject.subscribe((function (isLoggedIn) {
70
+ this.loginChangeSubject.subscribe(function (isLoggedIn) {
32
71
  _this.configSvc.isAuthenticated = isLoggedIn;
33
72
  if (isLoggedIn &&
34
73
  _this.configSvc.instanceConfig &&
@@ -39,41 +78,41 @@ var AuthKeycloakService = (function () {
39
78
  userId: _this.userId || '',
40
79
  };
41
80
  }
42
- }));
81
+ });
43
82
  }
44
83
  Object.defineProperty(AuthKeycloakService.prototype, "isLoggedIn$", {
45
84
  get: function () {
46
85
  return this.loginChangeSubject.asObservable();
47
86
  },
48
- enumerable: true,
87
+ enumerable: false,
49
88
  configurable: true
50
89
  });
51
90
  Object.defineProperty(AuthKeycloakService.prototype, "isLoggedIn", {
52
91
  get: function () {
53
92
  return this.keycloakSvc.isLoggedIn();
54
93
  },
55
- enumerable: true,
94
+ enumerable: false,
56
95
  configurable: true
57
96
  });
58
97
  Object.defineProperty(AuthKeycloakService.prototype, "isAuthenticated", {
59
98
  get: function () {
60
99
  return this.keycloakSvc.getKeycloakInstance().authenticated;
61
100
  },
62
- enumerable: true,
101
+ enumerable: false,
63
102
  configurable: true
64
103
  });
65
104
  Object.defineProperty(AuthKeycloakService.prototype, "token", {
66
105
  get: function () {
67
106
  return this.keycloakSvc.getKeycloakInstance().token;
68
107
  },
69
- enumerable: true,
108
+ enumerable: false,
70
109
  configurable: true
71
110
  });
72
111
  Object.defineProperty(AuthKeycloakService.prototype, "sessionId", {
73
112
  get: function () {
74
113
  return this.keycloakSvc.getKeycloakInstance().sessionId;
75
114
  },
76
- enumerable: true,
115
+ enumerable: false,
77
116
  configurable: true
78
117
  });
79
118
  Object.defineProperty(AuthKeycloakService.prototype, "userId", {
@@ -84,36 +123,36 @@ var AuthKeycloakService = (function () {
84
123
  }
85
124
  return (kc.tokenParsed && kc.tokenParsed.sub) || (kc.idTokenParsed && kc.idTokenParsed.sub);
86
125
  },
87
- enumerable: true,
126
+ enumerable: false,
88
127
  configurable: true
89
128
  });
90
129
  Object.defineProperty(AuthKeycloakService.prototype, "userEmail", {
91
130
  get: function () {
92
131
  var kc = this.keycloakSvc.getKeycloakInstance();
93
- var tokenParsed = ((kc.tokenParsed));
94
- var idTokenParsed = ((kc.idTokenParsed));
132
+ var tokenParsed = kc.tokenParsed;
133
+ var idTokenParsed = kc.idTokenParsed;
95
134
  return ((tokenParsed && tokenParsed.email) ||
96
135
  (idTokenParsed && idTokenParsed.email) ||
97
136
  (idTokenParsed && idTokenParsed.encEmail) ||
98
137
  (tokenParsed && tokenParsed.preferred_username) ||
99
138
  (idTokenParsed && idTokenParsed.preferred_username));
100
139
  },
101
- enumerable: true,
140
+ enumerable: false,
102
141
  configurable: true
103
142
  });
104
143
  Object.defineProperty(AuthKeycloakService.prototype, "userName", {
105
144
  get: function () {
106
145
  var kc = this.keycloakSvc.getKeycloakInstance();
107
- return ((kc.tokenParsed && (((kc.tokenParsed))).name) ||
108
- (kc.idTokenParsed && (((kc.idTokenParsed))).name));
146
+ return ((kc.tokenParsed && kc.tokenParsed.name) ||
147
+ (kc.idTokenParsed && kc.idTokenParsed.name));
109
148
  },
110
- enumerable: true,
149
+ enumerable: false,
111
150
  configurable: true
112
151
  });
113
152
  AuthKeycloakService.prototype.initAuth = function () {
114
- return tslib_1.__awaiter(this, void 0, void 0, function () {
153
+ return __awaiter(this, void 0, void 0, function () {
115
154
  var instanceConfig, err_1;
116
- return tslib_1.__generator(this, function (_a) {
155
+ return __generator(this, function (_a) {
117
156
  switch (_a.label) {
118
157
  case 0:
119
158
  if (!this.configSvc.instanceConfig) {
@@ -134,7 +173,7 @@ var AuthKeycloakService = (function () {
134
173
  realm: instanceConfig.keycloak.realm,
135
174
  clientId: instanceConfig.keycloak.clientId,
136
175
  },
137
- initOptions: tslib_1.__assign({}, this.getSavedKcConfig(), { onLoad: instanceConfig.keycloak.onLoad || 'check-sso', checkLoginIframe: false }),
176
+ initOptions: __assign(__assign({}, this.getSavedKcConfig()), { onLoad: instanceConfig.keycloak.onLoad || 'check-sso', checkLoginIframe: false }),
138
177
  enableBearerInterceptor: true,
139
178
  loadUserProfileAtStartUp: false,
140
179
  bearerExcludedUrls: instanceConfig.keycloak.bearerExcludedUrls,
@@ -173,8 +212,8 @@ var AuthKeycloakService = (function () {
173
212
  };
174
213
  AuthKeycloakService.prototype.logout = function (redirectUrl) {
175
214
  if (redirectUrl === void 0) { redirectUrl = this.defaultRedirectUrl; }
176
- return tslib_1.__awaiter(this, void 0, void 0, function () {
177
- return tslib_1.__generator(this, function (_a) {
215
+ return __awaiter(this, void 0, void 0, function () {
216
+ return __generator(this, function (_a) {
178
217
  if (storage.getItem('telemetrySessionId')) {
179
218
  storage.removeItem('telemetrySessionId');
180
219
  }
@@ -191,8 +230,8 @@ var AuthKeycloakService = (function () {
191
230
  });
192
231
  };
193
232
  AuthKeycloakService.prototype.force_logout = function () {
194
- return tslib_1.__awaiter(this, void 0, void 0, function () {
195
- return tslib_1.__generator(this, function (_a) {
233
+ return __awaiter(this, void 0, void 0, function () {
234
+ return __generator(this, function (_a) {
196
235
  switch (_a.label) {
197
236
  case 0:
198
237
  if (!storage.getItem('telemetrySessionId')) return [3, 1];
@@ -228,7 +267,7 @@ var AuthKeycloakService = (function () {
228
267
  };
229
268
  AuthKeycloakService.prototype.addKeycloakEventListener = function () {
230
269
  var _this = this;
231
- this.keycloakSvc.keycloakEvents$.subscribe((function (event) {
270
+ this.keycloakSvc.keycloakEvents$.subscribe(function (event) {
232
271
  switch (event.type) {
233
272
  case KeycloakEventType.OnAuthError:
234
273
  _this.loginChangeSubject.next(false);
@@ -253,23 +292,23 @@ var AuthKeycloakService = (function () {
253
292
  _this.keycloakSvc.updateToken(60);
254
293
  break;
255
294
  }
256
- }));
295
+ });
257
296
  };
258
297
  AuthKeycloakService.prototype.setupGlobalAuthResponder = function () {
259
298
  var _this = this;
260
299
  fromEvent(window, 'message')
261
- .pipe(filter((function (event) {
300
+ .pipe(filter(function (event) {
262
301
  return Boolean(event) &&
263
302
  Boolean(event.data) &&
264
303
  event.data.type === 'AUTH_REQUEST' &&
265
304
  Boolean(event.source && typeof event.source.postMessage === 'function');
266
- })))
267
- .subscribe((function (event) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
305
+ }))
306
+ .subscribe(function (event) { return __awaiter(_this, void 0, void 0, function () {
268
307
  var contentWindow, token, response;
269
- return tslib_1.__generator(this, function (_a) {
308
+ return __generator(this, function (_a) {
270
309
  switch (_a.label) {
271
310
  case 0:
272
- contentWindow = ((event.source));
311
+ contentWindow = event.source;
273
312
  return [4, this.keycloakSvc.getToken()];
274
313
  case 1:
275
314
  token = _a.sent();
@@ -287,7 +326,7 @@ var AuthKeycloakService = (function () {
287
326
  return [2];
288
327
  }
289
328
  });
290
- }); }));
329
+ }); });
291
330
  };
292
331
  AuthKeycloakService.prototype.saveKeycloakConfig = function () {
293
332
  var kc = this.keycloakSvc.getKeycloakInstance();
@@ -325,9 +364,16 @@ var AuthKeycloakService = (function () {
325
364
  return location.origin;
326
365
  }
327
366
  },
328
- enumerable: true,
367
+ enumerable: false,
329
368
  configurable: true
330
369
  });
370
+ AuthKeycloakService.ctorParameters = function () { return [
371
+ { type: HttpClient },
372
+ { type: ConfigurationsService },
373
+ { type: KeycloakService },
374
+ { type: AuthMicrosoftService }
375
+ ]; };
376
+ AuthKeycloakService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AuthKeycloakService_Factory() { return new AuthKeycloakService(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.ConfigurationsService), i0.ɵɵinject(i3.KeycloakService), i0.ɵɵinject(i4.AuthMicrosoftService)); }, token: AuthKeycloakService, providedIn: "root" });
331
377
  AuthKeycloakService.decorators = [
332
378
  { type: Injectable, args: [{
333
379
  providedIn: 'root',
@@ -339,15 +385,7 @@ var AuthKeycloakService = (function () {
339
385
  { type: KeycloakService },
340
386
  { type: AuthMicrosoftService }
341
387
  ]; };
342
- /** @nocollapse */ AuthKeycloakService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function AuthKeycloakService_Factory() { return new AuthKeycloakService(i0.ɵɵinject(i1.HttpClient), i0.ɵɵinject(i2.ConfigurationsService), i0.ɵɵinject(i3.KeycloakService), i0.ɵɵinject(i4.AuthMicrosoftService)); }, token: AuthKeycloakService, providedIn: "root" });
343
388
  return AuthKeycloakService;
344
389
  }());
345
390
  export { AuthKeycloakService };
346
- if (false) {
347
- AuthKeycloakService.prototype.loginChangeSubject;
348
- AuthKeycloakService.prototype.http;
349
- AuthKeycloakService.prototype.configSvc;
350
- AuthKeycloakService.prototype.keycloakSvc;
351
- AuthKeycloakService.prototype.msAuthSvc;
352
- }
353
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-keycloak.service.js","sourceRoot":"ng://@sunbird-cb/utils-v2/","sources":["lib/services/auth-keycloak.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\r\nimport { Injectable } from '@angular/core'\r\nimport { KeycloakEvent, KeycloakEventType, KeycloakInitOptions, KeycloakService } from 'keycloak-angular'\r\nimport { fromEvent, ReplaySubject } from 'rxjs'\r\nimport { filter } from 'rxjs/operators'\r\nimport { AuthMicrosoftService } from './auth-microsoft.service'\r\nimport { ConfigurationsService } from './configurations.service'\r\n\r\ninterface IParsedToken {\r\n  email?: string\r\n  encEmail?: string\r\n  name?: string\r\n  preferred_username?: string\r\n}\r\n\r\nconst storage = localStorage\r\nconst storageKey = 'kc'\r\n// const logoutRedirectUrl = ''\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AuthKeycloakService {\r\n  private loginChangeSubject = new ReplaySubject<boolean>(1)\r\n  constructor(\r\n    private http: HttpClient,\r\n    private configSvc: ConfigurationsService,\r\n    private keycloakSvc: KeycloakService,\r\n    private msAuthSvc: AuthMicrosoftService,\r\n  ) {\r\n    this.loginChangeSubject.subscribe((isLoggedIn: boolean) => {\r\n      this.configSvc.isAuthenticated = isLoggedIn\r\n      if (\r\n        isLoggedIn &&\r\n        this.configSvc.instanceConfig &&\r\n        Boolean(this.configSvc.instanceConfig.disablePidCheck)\r\n      ) {\r\n        this.configSvc.userProfile = {\r\n          email: this.userEmail,\r\n          userName: this.userName,\r\n          userId: this.userId || '',\r\n        }\r\n      }\r\n    })\r\n  }\r\n\r\n  // Getters\r\n  get isLoggedIn$() {\r\n    return this.loginChangeSubject.asObservable()\r\n  }\r\n  get isLoggedIn(): Promise<boolean> {\r\n    return this.keycloakSvc.isLoggedIn()\r\n  }\r\n  get isAuthenticated(): boolean | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().authenticated\r\n  }\r\n  get token(): string | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().token\r\n  }\r\n  get sessionId(): string | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().sessionId\r\n  }\r\n  get userId(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    if (!kc) {\r\n      return\r\n    }\r\n    return (kc.tokenParsed && kc.tokenParsed.sub) || (kc.idTokenParsed && kc.idTokenParsed.sub)\r\n  }\r\n\r\n  get userEmail(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n\r\n    const tokenParsed = kc.tokenParsed as IParsedToken\r\n    const idTokenParsed = kc.idTokenParsed as IParsedToken\r\n    return (\r\n      (tokenParsed && tokenParsed.email) ||\r\n      (idTokenParsed && idTokenParsed.email) ||\r\n      (idTokenParsed && idTokenParsed.encEmail) ||\r\n      (tokenParsed && tokenParsed.preferred_username) ||\r\n      (idTokenParsed && idTokenParsed.preferred_username)\r\n    )\r\n  }\r\n\r\n  get userName(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    return (\r\n      (kc.tokenParsed && (kc.tokenParsed as IParsedToken).name) ||\r\n      (kc.idTokenParsed && (kc.idTokenParsed as IParsedToken).name)\r\n    )\r\n  }\r\n\r\n  async initAuth(): Promise<boolean> {\r\n    if (!this.configSvc.instanceConfig) {\r\n      return false\r\n    }\r\n    const instanceConfig = this.configSvc.instanceConfig\r\n    if (instanceConfig.microsoft.isConfigured) {\r\n      this.msAuthSvc.init({ microsoft: instanceConfig.microsoft })\r\n    }\r\n    try {\r\n      this.setupGlobalAuthResponder()\r\n      this.addKeycloakEventListener()\r\n      return await this.keycloakSvc.init({\r\n        config: {\r\n          url: instanceConfig.keycloak.url,\r\n          realm: instanceConfig.keycloak.realm,\r\n          clientId: instanceConfig.keycloak.clientId,\r\n        },\r\n        initOptions: {\r\n          ...this.getSavedKcConfig(),\r\n          onLoad: instanceConfig.keycloak.onLoad || 'check-sso',\r\n          checkLoginIframe: false,\r\n        },\r\n        enableBearerInterceptor: true,\r\n        loadUserProfileAtStartUp: false,\r\n        bearerExcludedUrls: instanceConfig.keycloak.bearerExcludedUrls,\r\n      })\r\n    } catch (err) {\r\n      return false\r\n    }\r\n  }\r\n\r\n  login(\r\n    idpHint: 'E' | 'N' | 'S' = 'E',\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    return this.keycloakSvc.login({\r\n      idpHint,\r\n      redirectUri: redirectUrl,\r\n    })\r\n  }\r\n  loginV2(\r\n    _idpHint: 'E' | 'N' | 'S' = 'E',\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    if (this.configSvc.instanceConfig) {\r\n      window.location.href = this.configSvc.instanceConfig.keycloak.url + redirectUrl\r\n      return Promise.resolve()\r\n    }\r\n    return Promise.reject()\r\n  }\r\n  register(\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    return this.keycloakSvc.register({\r\n      redirectUri: redirectUrl,\r\n    })\r\n  }\r\n  /**\r\n   * @deprecated this will be depricated\r\n   */\r\n  async logout(redirectUrl = this.defaultRedirectUrl) {\r\n    if (storage.getItem('telemetrySessionId')) {\r\n      storage.removeItem('telemetrySessionId')\r\n    }\r\n    try {\r\n      sessionStorage.clear()\r\n      localStorage.clear()\r\n    } catch {\r\n\r\n    }\r\n    storage.removeItem(storageKey)\r\n    // alert(`${redirectUrl}apis/reset`)\r\n    window.location.href = `${redirectUrl}apis/reset`\r\n    // window.location.href = 'http://localhost:3003/reset'\r\n    //  await this.http.get('/apis/reset').toPromise()\r\n    // setTimeout(window.location.href = `${redirectUrl}apis/reset`, 13000)\r\n    // logoutRedirectUrl = redirectUrl\r\n    // if (this.msAuthSvc.isLogoutRequired) {\r\n    //   this.keycloakSvc.logout(this.msAuthSvc.logoutUrl(redirectUrl))\r\n    // } else {\r\n    // this.keycloakSvc.logout(redirectUrl)\r\n    // }\r\n  }\r\n  async force_logout() {\r\n    if (storage.getItem('telemetrySessionId')) {\r\n      storage.removeItem('telemetrySessionId')\r\n    } else {\r\n      // window.location.href = '/public/home'\r\n      storage.removeItem(storageKey)\r\n      await this.http.get('/apis/reset').toPromise()\r\n      await this.http.get('https://admin-test.ecornell.com/saml/logout.do').toPromise()\r\n    }\r\n    try {\r\n      sessionStorage.clear()\r\n      localStorage.clear()\r\n    } catch {\r\n\r\n    }\r\n    storage.removeItem(storageKey)\r\n    await this.http.get('/apis/reset').toPromise()\r\n    await this.http.get('https://admin-test.ecornell.com/saml/logout.do').toPromise()\r\n  }\r\n  private addKeycloakEventListener() {\r\n    this.keycloakSvc.keycloakEvents$.subscribe((event: KeycloakEvent) => {\r\n      switch (event.type) {\r\n        case KeycloakEventType.OnAuthError:\r\n          this.loginChangeSubject.next(false)\r\n          break\r\n        case KeycloakEventType.OnAuthLogout:\r\n          this.loginChangeSubject.next(false)\r\n          storage.removeItem(storageKey)\r\n          break\r\n        case KeycloakEventType.OnAuthRefreshError:\r\n          break\r\n        case KeycloakEventType.OnAuthRefreshSuccess:\r\n          break\r\n        case KeycloakEventType.OnAuthSuccess:\r\n          break\r\n        case KeycloakEventType.OnReady:\r\n          this.loginChangeSubject.next(event.args)\r\n          if (event.args) {\r\n            this.saveKeycloakConfig()\r\n          }\r\n          break\r\n        case KeycloakEventType.OnTokenExpired:\r\n          this.keycloakSvc.updateToken(60)\r\n          break\r\n      }\r\n    })\r\n  }\r\n\r\n  private setupGlobalAuthResponder() {\r\n    fromEvent<MessageEvent>(window, 'message')\r\n      .pipe(\r\n        filter(\r\n          (event: MessageEvent) =>\r\n            Boolean(event) &&\r\n            Boolean(event.data) &&\r\n            event.data.type === 'AUTH_REQUEST' &&\r\n            Boolean(event.source && typeof event.source.postMessage === 'function'),\r\n        ),\r\n      )\r\n      .subscribe(async (event: MessageEvent) => {\r\n        const contentWindow = event.source as Window\r\n        const token = await this.keycloakSvc.getToken()\r\n        const response = {\r\n          app: 'WEB_PORTAL',\r\n          type: 'AUTH_RESPONSE',\r\n          state: 'NONE',\r\n          plugin: 'NONE',\r\n          data: {\r\n            token,\r\n            id: event.data && event.data.data && event.data.data.id,\r\n          },\r\n        }\r\n        contentWindow.postMessage(response, '*')\r\n      })\r\n  }\r\n\r\n  // Utility Methods\r\n  private saveKeycloakConfig() {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    const kcInitOptions: KeycloakInitOptions = {\r\n      idToken: kc.idToken,\r\n      refreshToken: kc.refreshToken,\r\n      timeSkew: kc.timeSkew,\r\n      token: kc.token,\r\n    }\r\n    storage.setItem(storageKey, JSON.stringify(kcInitOptions))\r\n  }\r\n  private getSavedKcConfig(): KeycloakInitOptions {\r\n    try {\r\n      // const lastSaved = KEYCLOAK_STORAGE.getItem(key);\r\n      const lastSaved = storage.getItem(storageKey)\r\n      if (lastSaved) {\r\n        const processed = JSON.parse(lastSaved)\r\n        if (\r\n          'idToken' in processed &&\r\n          'refreshToken' in processed &&\r\n          'timeSkew' in processed &&\r\n          'token' in processed\r\n        ) {\r\n          return processed\r\n        }\r\n      }\r\n    } catch (e) { }\r\n    return {}\r\n  }\r\n\r\n  private get defaultRedirectUrl(): string {\r\n    try {\r\n      const baseUrl = document.baseURI\r\n      return baseUrl || location.origin\r\n    } catch (error) {\r\n      return location.origin\r\n    }\r\n  }\r\n}\r\n"]}
391
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-keycloak.service.js","sourceRoot":"ng://@sunbird-cb/utils-v2/","sources":["lib/services/auth-keycloak.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http'\r\nimport { Injectable } from '@angular/core'\r\nimport { KeycloakEvent, KeycloakEventType, KeycloakInitOptions, KeycloakService } from 'keycloak-angular'\r\nimport { fromEvent, ReplaySubject } from 'rxjs'\r\nimport { filter } from 'rxjs/operators'\r\nimport { AuthMicrosoftService } from './auth-microsoft.service'\r\nimport { ConfigurationsService } from './configurations.service'\r\n\r\ninterface IParsedToken {\r\n  email?: string\r\n  encEmail?: string\r\n  name?: string\r\n  preferred_username?: string\r\n}\r\n\r\nconst storage = localStorage\r\nconst storageKey = 'kc'\r\n// const logoutRedirectUrl = ''\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AuthKeycloakService {\r\n  private loginChangeSubject = new ReplaySubject<boolean>(1)\r\n  constructor(\r\n    private http: HttpClient,\r\n    private configSvc: ConfigurationsService,\r\n    private keycloakSvc: KeycloakService,\r\n    private msAuthSvc: AuthMicrosoftService,\r\n  ) {\r\n    this.loginChangeSubject.subscribe((isLoggedIn: boolean) => {\r\n      this.configSvc.isAuthenticated = isLoggedIn\r\n      if (\r\n        isLoggedIn &&\r\n        this.configSvc.instanceConfig &&\r\n        Boolean(this.configSvc.instanceConfig.disablePidCheck)\r\n      ) {\r\n        this.configSvc.userProfile = {\r\n          email: this.userEmail,\r\n          userName: this.userName,\r\n          userId: this.userId || '',\r\n        }\r\n      }\r\n    })\r\n  }\r\n\r\n  // Getters\r\n  get isLoggedIn$() {\r\n    return this.loginChangeSubject.asObservable()\r\n  }\r\n  get isLoggedIn(): Promise<boolean> {\r\n    return this.keycloakSvc.isLoggedIn()\r\n  }\r\n  get isAuthenticated(): boolean | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().authenticated\r\n  }\r\n  get token(): string | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().token\r\n  }\r\n  get sessionId(): string | undefined {\r\n    return this.keycloakSvc.getKeycloakInstance().sessionId\r\n  }\r\n  get userId(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    if (!kc) {\r\n      return\r\n    }\r\n    return (kc.tokenParsed && kc.tokenParsed.sub) || (kc.idTokenParsed && kc.idTokenParsed.sub)\r\n  }\r\n\r\n  get userEmail(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n\r\n    const tokenParsed = kc.tokenParsed as IParsedToken\r\n    const idTokenParsed = kc.idTokenParsed as IParsedToken\r\n    return (\r\n      (tokenParsed && tokenParsed.email) ||\r\n      (idTokenParsed && idTokenParsed.email) ||\r\n      (idTokenParsed && idTokenParsed.encEmail) ||\r\n      (tokenParsed && tokenParsed.preferred_username) ||\r\n      (idTokenParsed && idTokenParsed.preferred_username)\r\n    )\r\n  }\r\n\r\n  get userName(): string | undefined {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    return (\r\n      (kc.tokenParsed && (kc.tokenParsed as IParsedToken).name) ||\r\n      (kc.idTokenParsed && (kc.idTokenParsed as IParsedToken).name)\r\n    )\r\n  }\r\n\r\n  async initAuth(): Promise<boolean> {\r\n    if (!this.configSvc.instanceConfig) {\r\n      return false\r\n    }\r\n    const instanceConfig = this.configSvc.instanceConfig\r\n    if (instanceConfig.microsoft.isConfigured) {\r\n      this.msAuthSvc.init({ microsoft: instanceConfig.microsoft })\r\n    }\r\n    try {\r\n      this.setupGlobalAuthResponder()\r\n      this.addKeycloakEventListener()\r\n      return await this.keycloakSvc.init({\r\n        config: {\r\n          url: instanceConfig.keycloak.url,\r\n          realm: instanceConfig.keycloak.realm,\r\n          clientId: instanceConfig.keycloak.clientId,\r\n        },\r\n        initOptions: {\r\n          ...this.getSavedKcConfig(),\r\n          onLoad: instanceConfig.keycloak.onLoad || 'check-sso',\r\n          checkLoginIframe: false,\r\n        },\r\n        enableBearerInterceptor: true,\r\n        loadUserProfileAtStartUp: false,\r\n        bearerExcludedUrls: instanceConfig.keycloak.bearerExcludedUrls,\r\n      })\r\n    } catch (err) {\r\n      return false\r\n    }\r\n  }\r\n\r\n  login(\r\n    idpHint: 'E' | 'N' | 'S' = 'E',\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    return this.keycloakSvc.login({\r\n      idpHint,\r\n      redirectUri: redirectUrl,\r\n    })\r\n  }\r\n  loginV2(\r\n    _idpHint: 'E' | 'N' | 'S' = 'E',\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    if (this.configSvc.instanceConfig) {\r\n      window.location.href = this.configSvc.instanceConfig.keycloak.url + redirectUrl\r\n      return Promise.resolve()\r\n    }\r\n    return Promise.reject()\r\n  }\r\n  register(\r\n    redirectUrl: string = this.defaultRedirectUrl,\r\n  ): Promise<void> {\r\n    return this.keycloakSvc.register({\r\n      redirectUri: redirectUrl,\r\n    })\r\n  }\r\n  /**\r\n   * @deprecated this will be depricated\r\n   */\r\n  async logout(redirectUrl = this.defaultRedirectUrl) {\r\n    if (storage.getItem('telemetrySessionId')) {\r\n      storage.removeItem('telemetrySessionId')\r\n    }\r\n    try {\r\n      sessionStorage.clear()\r\n      localStorage.clear()\r\n    } catch {\r\n\r\n    }\r\n    storage.removeItem(storageKey)\r\n    // alert(`${redirectUrl}apis/reset`)\r\n    window.location.href = `${redirectUrl}apis/reset`\r\n    // window.location.href = 'http://localhost:3003/reset'\r\n    //  await this.http.get('/apis/reset').toPromise()\r\n    // setTimeout(window.location.href = `${redirectUrl}apis/reset`, 13000)\r\n    // logoutRedirectUrl = redirectUrl\r\n    // if (this.msAuthSvc.isLogoutRequired) {\r\n    //   this.keycloakSvc.logout(this.msAuthSvc.logoutUrl(redirectUrl))\r\n    // } else {\r\n    // this.keycloakSvc.logout(redirectUrl)\r\n    // }\r\n  }\r\n  async force_logout() {\r\n    if (storage.getItem('telemetrySessionId')) {\r\n      storage.removeItem('telemetrySessionId')\r\n    } else {\r\n      // window.location.href = '/public/home'\r\n      storage.removeItem(storageKey)\r\n      await this.http.get('/apis/reset').toPromise()\r\n      await this.http.get('https://admin-test.ecornell.com/saml/logout.do').toPromise()\r\n    }\r\n    try {\r\n      sessionStorage.clear()\r\n      localStorage.clear()\r\n    } catch {\r\n\r\n    }\r\n    storage.removeItem(storageKey)\r\n    await this.http.get('/apis/reset').toPromise()\r\n    await this.http.get('https://admin-test.ecornell.com/saml/logout.do').toPromise()\r\n  }\r\n  private addKeycloakEventListener() {\r\n    this.keycloakSvc.keycloakEvents$.subscribe((event: KeycloakEvent) => {\r\n      switch (event.type) {\r\n        case KeycloakEventType.OnAuthError:\r\n          this.loginChangeSubject.next(false)\r\n          break\r\n        case KeycloakEventType.OnAuthLogout:\r\n          this.loginChangeSubject.next(false)\r\n          storage.removeItem(storageKey)\r\n          break\r\n        case KeycloakEventType.OnAuthRefreshError:\r\n          break\r\n        case KeycloakEventType.OnAuthRefreshSuccess:\r\n          break\r\n        case KeycloakEventType.OnAuthSuccess:\r\n          break\r\n        case KeycloakEventType.OnReady:\r\n          this.loginChangeSubject.next(event.args)\r\n          if (event.args) {\r\n            this.saveKeycloakConfig()\r\n          }\r\n          break\r\n        case KeycloakEventType.OnTokenExpired:\r\n          this.keycloakSvc.updateToken(60)\r\n          break\r\n      }\r\n    })\r\n  }\r\n\r\n  private setupGlobalAuthResponder() {\r\n    fromEvent<MessageEvent>(window, 'message')\r\n      .pipe(\r\n        filter(\r\n          (event: MessageEvent) =>\r\n            Boolean(event) &&\r\n            Boolean(event.data) &&\r\n            event.data.type === 'AUTH_REQUEST' &&\r\n            Boolean(event.source && typeof event.source.postMessage === 'function'),\r\n        ),\r\n      )\r\n      .subscribe(async (event: MessageEvent) => {\r\n        const contentWindow = event.source as Window\r\n        const token = await this.keycloakSvc.getToken()\r\n        const response = {\r\n          app: 'WEB_PORTAL',\r\n          type: 'AUTH_RESPONSE',\r\n          state: 'NONE',\r\n          plugin: 'NONE',\r\n          data: {\r\n            token,\r\n            id: event.data && event.data.data && event.data.data.id,\r\n          },\r\n        }\r\n        contentWindow.postMessage(response, '*')\r\n      })\r\n  }\r\n\r\n  // Utility Methods\r\n  private saveKeycloakConfig() {\r\n    const kc = this.keycloakSvc.getKeycloakInstance()\r\n    const kcInitOptions: KeycloakInitOptions = {\r\n      idToken: kc.idToken,\r\n      refreshToken: kc.refreshToken,\r\n      timeSkew: kc.timeSkew,\r\n      token: kc.token,\r\n    }\r\n    storage.setItem(storageKey, JSON.stringify(kcInitOptions))\r\n  }\r\n  private getSavedKcConfig(): KeycloakInitOptions {\r\n    try {\r\n      // const lastSaved = KEYCLOAK_STORAGE.getItem(key);\r\n      const lastSaved = storage.getItem(storageKey)\r\n      if (lastSaved) {\r\n        const processed = JSON.parse(lastSaved)\r\n        if (\r\n          'idToken' in processed &&\r\n          'refreshToken' in processed &&\r\n          'timeSkew' in processed &&\r\n          'token' in processed\r\n        ) {\r\n          return processed\r\n        }\r\n      }\r\n    } catch (e) { }\r\n    return {}\r\n  }\r\n\r\n  private get defaultRedirectUrl(): string {\r\n    try {\r\n      const baseUrl = document.baseURI\r\n      return baseUrl || location.origin\r\n    } catch (error) {\r\n      return location.origin\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,4 +1,39 @@
1
- import * as tslib_1 from "tslib";
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ var __generator = (this && this.__generator) || function (thisArg, body) {
11
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13
+ function verb(n) { return function (v) { return step([n, v]); }; }
14
+ function step(op) {
15
+ if (f) throw new TypeError("Generator is already executing.");
16
+ while (_) try {
17
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
18
+ if (y = 0, t) op = [op[0] & 2, t.value];
19
+ switch (op[0]) {
20
+ case 0: case 1: t = op; break;
21
+ case 4: _.label++; return { value: op[1], done: false };
22
+ case 5: _.label++; y = op[1]; op = [0]; continue;
23
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
24
+ default:
25
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29
+ if (t[2]) _.ops.pop();
30
+ _.trys.pop(); continue;
31
+ }
32
+ op = body.call(thisArg, _);
33
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
+ }
36
+ };
2
37
  import { Injectable } from '@angular/core';
3
38
  import { LoggerService } from './logger.service';
4
39
  import { HttpClient } from '@angular/common/http';
@@ -35,7 +70,7 @@ var AuthMicrosoftService = (function () {
35
70
  get: function () {
36
71
  return Boolean(this.msConfig.isConfigured && this.msConfig.clientId && this.emailUsed);
37
72
  },
38
- enumerable: true,
73
+ enumerable: false,
39
74
  configurable: true
40
75
  });
41
76
  Object.defineProperty(AuthMicrosoftService.prototype, "loginUrl", {
@@ -55,7 +90,7 @@ var AuthMicrosoftService = (function () {
55
90
  }
56
91
  return null;
57
92
  },
58
- enumerable: true,
93
+ enumerable: false,
59
94
  configurable: true
60
95
  });
61
96
  AuthMicrosoftService.prototype.logoutUrl = function (redirectUrl) {
@@ -65,9 +100,9 @@ var AuthMicrosoftService = (function () {
65
100
  return redirectUrl;
66
101
  };
67
102
  AuthMicrosoftService.prototype.init = function (config) {
68
- return tslib_1.__awaiter(this, void 0, void 0, function () {
103
+ return __awaiter(this, void 0, void 0, function () {
69
104
  var queryParams, url;
70
- return tslib_1.__generator(this, function (_a) {
105
+ return __generator(this, function (_a) {
71
106
  switch (_a.label) {
72
107
  case 0:
73
108
  if (!config || !config.microsoft || !config.microsoft.isConfigured) {
@@ -95,9 +130,9 @@ var AuthMicrosoftService = (function () {
95
130
  });
96
131
  };
97
132
  AuthMicrosoftService.prototype.login = function (email) {
98
- return tslib_1.__awaiter(this, void 0, void 0, function () {
133
+ return __awaiter(this, void 0, void 0, function () {
99
134
  var loginUrl;
100
- return tslib_1.__generator(this, function (_a) {
135
+ return __generator(this, function (_a) {
101
136
  if (!this.isValidEmail(email)) {
102
137
  this.loggerSvc.warn("Microsoft Login is not allowed for your emailId (" + email + ")");
103
138
  return [2];
@@ -114,9 +149,9 @@ var AuthMicrosoftService = (function () {
114
149
  });
115
150
  };
116
151
  AuthMicrosoftService.prototype.getToken = function (email) {
117
- return tslib_1.__awaiter(this, void 0, void 0, function () {
152
+ return __awaiter(this, void 0, void 0, function () {
118
153
  var _a, error_1, _b, error_2;
119
- return tslib_1.__generator(this, function (_c) {
154
+ return __generator(this, function (_c) {
120
155
  switch (_c.label) {
121
156
  case 0:
122
157
  if (this.msToken &&
@@ -181,7 +216,7 @@ var AuthMicrosoftService = (function () {
181
216
  }
182
217
  };
183
218
  AuthMicrosoftService.prototype.isValidEmail = function (email) {
184
- return this.msConfig.validEmailExtensions.some((function (ext) { return email.endsWith(ext); }));
219
+ return this.msConfig.validEmailExtensions.some(function (ext) { return email.endsWith(ext); });
185
220
  };
186
221
  AuthMicrosoftService.prototype.isValid = function (accessToken, expiresOn) {
187
222
  if (accessToken && expiresOn) {
@@ -190,9 +225,9 @@ var AuthMicrosoftService = (function () {
190
225
  return false;
191
226
  };
192
227
  AuthMicrosoftService.prototype.exchangeTokenForCode = function (code, redirectUrl) {
193
- return tslib_1.__awaiter(this, void 0, void 0, function () {
228
+ return __awaiter(this, void 0, void 0, function () {
194
229
  var response;
195
- return tslib_1.__generator(this, function (_a) {
230
+ return __generator(this, function (_a) {
196
231
  switch (_a.label) {
197
232
  case 0: return [4, this.http
198
233
  .get(API_ENDPOINTS + "?code=" + code + "&redirectUrl=" + redirectUrl)
@@ -205,9 +240,9 @@ var AuthMicrosoftService = (function () {
205
240
  });
206
241
  };
207
242
  AuthMicrosoftService.prototype.getTokenForEmail = function (email) {
208
- return tslib_1.__awaiter(this, void 0, void 0, function () {
243
+ return __awaiter(this, void 0, void 0, function () {
209
244
  var response;
210
- return tslib_1.__generator(this, function (_a) {
245
+ return __generator(this, function (_a) {
211
246
  switch (_a.label) {
212
247
  case 0: return [4, this.http
213
248
  .get(API_ENDPOINTS.sharePointToken + "?email=" + email)
@@ -227,6 +262,11 @@ var AuthMicrosoftService = (function () {
227
262
  tokenType: token.tokenType,
228
263
  };
229
264
  };
265
+ AuthMicrosoftService.ctorParameters = function () { return [
266
+ { type: LoggerService },
267
+ { type: HttpClient }
268
+ ]; };
269
+ AuthMicrosoftService.ɵprov = i0.ɵɵdefineInjectable({ factory: function AuthMicrosoftService_Factory() { return new AuthMicrosoftService(i0.ɵɵinject(i1.LoggerService), i0.ɵɵinject(i2.HttpClient)); }, token: AuthMicrosoftService, providedIn: "root" });
230
270
  AuthMicrosoftService.decorators = [
231
271
  { type: Injectable, args: [{
232
272
  providedIn: 'root',
@@ -236,16 +276,7 @@ var AuthMicrosoftService = (function () {
236
276
  { type: LoggerService },
237
277
  { type: HttpClient }
238
278
  ]; };
239
- /** @nocollapse */ AuthMicrosoftService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function AuthMicrosoftService_Factory() { return new AuthMicrosoftService(i0.ɵɵinject(i1.LoggerService), i0.ɵɵinject(i2.HttpClient)); }, token: AuthMicrosoftService, providedIn: "root" });
240
279
  return AuthMicrosoftService;
241
280
  }());
242
281
  export { AuthMicrosoftService };
243
- if (false) {
244
- AuthMicrosoftService.prototype.msConfig;
245
- AuthMicrosoftService.prototype.emailUsed;
246
- AuthMicrosoftService.prototype.code;
247
- AuthMicrosoftService.prototype.msToken;
248
- AuthMicrosoftService.prototype.loggerSvc;
249
- AuthMicrosoftService.prototype.http;
250
- }
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-microsoft.service.js","sourceRoot":"ng://@sunbird-cb/utils-v2/","sources":["lib/services/auth-microsoft.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\r\nimport { LoggerService } from './logger.service'\r\nimport { NsInstanceConfig } from './configurations.model'\r\nimport { HttpClient } from '@angular/common/http'\r\nimport { IWsMsTokenModelResponse } from './ms-office.model'\r\n// TODO: Use a url-search-polyfill if the site didnot work in IE 11\r\n\r\nconst msTokenExpiryDuration = 600\r\nconst storageKey = 'msLoginRequested'\r\nconst storage = localStorage\r\n\r\nconst API_ENDPOINTS = {\r\n  sharePointToken: '/apis/protected/v8/user/token',\r\n}\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AuthMicrosoftService {\r\n  private msConfig: NsInstanceConfig.IMicrosoft = {\r\n    clientId: '',\r\n    tenant: '',\r\n    defaultEmailId: '',\r\n    validEmailExtensions: [],\r\n    isConfigured: false,\r\n  }\r\n  private emailUsed: string | null = null\r\n  private code: string | null = null\r\n  private msToken: IWsMsTokenModelResponse = {\r\n    accessToken: '',\r\n    expiresOn: '',\r\n    resource: '',\r\n    tokenType: '',\r\n  }\r\n\r\n  constructor(private loggerSvc: LoggerService, private http: HttpClient) { }\r\n\r\n  get isLogoutRequired(): boolean {\r\n    return Boolean(this.msConfig.isConfigured && this.msConfig.clientId && this.emailUsed)\r\n  }\r\n  get loginUrl(): string | null {\r\n    if (this.msConfig.isConfigured && this.msConfig.clientId) {\r\n      const base = 'https://login.windows.net/common/oauth2/authorize'\r\n      const searchParam = new URLSearchParams({\r\n        response_type: 'code',\r\n        client_id: this.msConfig.clientId,\r\n        redirect_uri: window.location.href,\r\n      })\r\n      const fragment = location.search.substring(1)\r\n      if (fragment) {\r\n        return `${base}?${searchParam.toString()}#${fragment}`\r\n      }\r\n      return `${base}?${searchParam.toString()}`\r\n    }\r\n    return null\r\n  }\r\n  logoutUrl(redirectUrl: string) {\r\n    if (this.isValidEmail(this.emailUsed || '')) {\r\n      return `https://login.microsoftonline.com/common/oauth2/logout?post_logout_redirect_uri=${redirectUrl}`\r\n    }\r\n    return redirectUrl\r\n  }\r\n\r\n  // Behavior Methods\r\n\r\n  async init(config: Pick<NsInstanceConfig.IConfig, 'microsoft'>) {\r\n    if (!config || !config.microsoft || !config.microsoft.isConfigured) {\r\n      this.loggerSvc.warn('Empty/No Configuration passed, ignoring Microsoft Authentication')\r\n    }\r\n    this.msConfig = config.microsoft\r\n    const queryParams = new URLSearchParams(location.search)\r\n    if (queryParams.has('code') && queryParams.has('session_state')) {\r\n      this.code = queryParams.get('code')\r\n      if (!this.code) {\r\n        return\r\n      }\r\n      let url = location.origin + location.pathname\r\n      await this.exchangeTokenForCode(this.code, url)\r\n      if (location.hash) {\r\n        url += location.hash.substring(1)\r\n      }\r\n      history.replaceState(null, '', url)\r\n    }\r\n  }\r\n\r\n  async login(email: string) {\r\n    if (!this.isValidEmail(email)) {\r\n      this.loggerSvc.warn(`Microsoft Login is not allowed for your emailId (${email})`)\r\n      return\r\n    }\r\n    const loginUrl = this.loginUrl\r\n    if (loginUrl) {\r\n      location.assign(loginUrl)\r\n    } else {\r\n      this.loggerSvc.warn('Unable to identify Office Login URL, Ignoring login request')\r\n    }\r\n  }\r\n\r\n  async getToken(email: string): Promise<string> {\r\n    if (\r\n      this.msToken &&\r\n      this.isValid(this.msToken.accessToken, this.msToken.expiresOn) &&\r\n      this.msToken.accessToken\r\n    ) {\r\n      return this.msToken.accessToken\r\n    }\r\n    if (this.isValidEmail(email)) {\r\n      try {\r\n        this.msToken = await this.getTokenForEmail(email)\r\n        if (this.msToken.accessToken) {\r\n          this.emailUsed = email\r\n          return this.msToken.accessToken\r\n        }\r\n      } catch (error) {\r\n        if (!this.code) {\r\n          this.login(email)\r\n        }\r\n      }\r\n    }\r\n    if (this.msConfig.defaultEmailId && this.isValidEmail(this.msConfig.defaultEmailId)) {\r\n      try {\r\n        this.msToken = await this.getTokenForEmail(this.msConfig.defaultEmailId)\r\n        if (this.msToken.accessToken) {\r\n          this.emailUsed = this.msConfig.defaultEmailId\r\n          return this.msToken.accessToken\r\n        }\r\n      } catch (error) { }\r\n    }\r\n    throw new Error('UNABLE TO FETCH MS AUTH TOKEN')\r\n  }\r\n\r\n  loginForSSOEnabledEmbed(email: string) {\r\n    if (!this.isValidEmail(email)) {\r\n      this.loggerSvc.warn('SSO Login request Ignored. Invalid Email Id for SSO Enabled Content')\r\n    }\r\n    let msPrevTS = 0\r\n    try {\r\n      msPrevTS = parseInt(storage.getItem(storageKey) || '0', 10)\r\n    } catch (error) { }\r\n    if (!msPrevTS || (msPrevTS && (Date.now() - msPrevTS) / 1000 > msTokenExpiryDuration)) {\r\n      this.loggerSvc.info(\r\n        `last login exceeded ${msTokenExpiryDuration} duration. Redirecting to O365 login`,\r\n      )\r\n      storage.setItem(storageKey, Date.now().toString())\r\n      this.login(email)\r\n    }\r\n  }\r\n\r\n  isValidEmail(email: string) {\r\n    return this.msConfig.validEmailExtensions.some(ext => email.endsWith(ext))\r\n  }\r\n\r\n  isValid(accessToken: string | undefined, expiresOn: string | undefined): boolean {\r\n    if (accessToken && expiresOn) {\r\n      // TODO: Implement expiredOn and Date comparison based validity\r\n      return true\r\n    }\r\n    return false\r\n  }\r\n\r\n  async exchangeTokenForCode(code: string, redirectUrl: string): Promise<any> {\r\n    const response = await this.http\r\n      .get<IWsMsTokenModelResponse>(`${API_ENDPOINTS}?code=${code}&redirectUrl=${redirectUrl}`)\r\n      .toPromise()\r\n    return this.getInstanceFromResponse(response)\r\n  }\r\n\r\n  async getTokenForEmail(email: string): Promise<any> {\r\n    const response = await this.http\r\n      .get<IWsMsTokenModelResponse>(`${API_ENDPOINTS.sharePointToken}?email=${email}`)\r\n      .toPromise()\r\n    return this.getInstanceFromResponse(response)\r\n  }\r\n\r\n  getInstanceFromResponse(token: IWsMsTokenModelResponse) {\r\n    return {\r\n      accessToken: token.accessToken,\r\n      expiresOn: token.expiresOn,\r\n      resource: token.resource,\r\n      tokenType: token.tokenType,\r\n    }\r\n  }\r\n}\r\n"]}
282
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-microsoft.service.js","sourceRoot":"ng://@sunbird-cb/utils-v2/","sources":["lib/services/auth-microsoft.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\r\nimport { LoggerService } from './logger.service'\r\nimport { NsInstanceConfig } from './configurations.model'\r\nimport { HttpClient } from '@angular/common/http'\r\nimport { IWsMsTokenModelResponse } from './ms-office.model'\r\n// TODO: Use a url-search-polyfill if the site didnot work in IE 11\r\n\r\nconst msTokenExpiryDuration = 600\r\nconst storageKey = 'msLoginRequested'\r\nconst storage = localStorage\r\n\r\nconst API_ENDPOINTS = {\r\n  sharePointToken: '/apis/protected/v8/user/token',\r\n}\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AuthMicrosoftService {\r\n  private msConfig: NsInstanceConfig.IMicrosoft = {\r\n    clientId: '',\r\n    tenant: '',\r\n    defaultEmailId: '',\r\n    validEmailExtensions: [],\r\n    isConfigured: false,\r\n  }\r\n  private emailUsed: string | null = null\r\n  private code: string | null = null\r\n  private msToken: IWsMsTokenModelResponse = {\r\n    accessToken: '',\r\n    expiresOn: '',\r\n    resource: '',\r\n    tokenType: '',\r\n  }\r\n\r\n  constructor(private loggerSvc: LoggerService, private http: HttpClient) { }\r\n\r\n  get isLogoutRequired(): boolean {\r\n    return Boolean(this.msConfig.isConfigured && this.msConfig.clientId && this.emailUsed)\r\n  }\r\n  get loginUrl(): string | null {\r\n    if (this.msConfig.isConfigured && this.msConfig.clientId) {\r\n      const base = 'https://login.windows.net/common/oauth2/authorize'\r\n      const searchParam = new URLSearchParams({\r\n        response_type: 'code',\r\n        client_id: this.msConfig.clientId,\r\n        redirect_uri: window.location.href,\r\n      })\r\n      const fragment = location.search.substring(1)\r\n      if (fragment) {\r\n        return `${base}?${searchParam.toString()}#${fragment}`\r\n      }\r\n      return `${base}?${searchParam.toString()}`\r\n    }\r\n    return null\r\n  }\r\n  logoutUrl(redirectUrl: string) {\r\n    if (this.isValidEmail(this.emailUsed || '')) {\r\n      return `https://login.microsoftonline.com/common/oauth2/logout?post_logout_redirect_uri=${redirectUrl}`\r\n    }\r\n    return redirectUrl\r\n  }\r\n\r\n  // Behavior Methods\r\n\r\n  async init(config: Pick<NsInstanceConfig.IConfig, 'microsoft'>) {\r\n    if (!config || !config.microsoft || !config.microsoft.isConfigured) {\r\n      this.loggerSvc.warn('Empty/No Configuration passed, ignoring Microsoft Authentication')\r\n    }\r\n    this.msConfig = config.microsoft\r\n    const queryParams = new URLSearchParams(location.search)\r\n    if (queryParams.has('code') && queryParams.has('session_state')) {\r\n      this.code = queryParams.get('code')\r\n      if (!this.code) {\r\n        return\r\n      }\r\n      let url = location.origin + location.pathname\r\n      await this.exchangeTokenForCode(this.code, url)\r\n      if (location.hash) {\r\n        url += location.hash.substring(1)\r\n      }\r\n      history.replaceState(null, '', url)\r\n    }\r\n  }\r\n\r\n  async login(email: string) {\r\n    if (!this.isValidEmail(email)) {\r\n      this.loggerSvc.warn(`Microsoft Login is not allowed for your emailId (${email})`)\r\n      return\r\n    }\r\n    const loginUrl = this.loginUrl\r\n    if (loginUrl) {\r\n      location.assign(loginUrl)\r\n    } else {\r\n      this.loggerSvc.warn('Unable to identify Office Login URL, Ignoring login request')\r\n    }\r\n  }\r\n\r\n  async getToken(email: string): Promise<string> {\r\n    if (\r\n      this.msToken &&\r\n      this.isValid(this.msToken.accessToken, this.msToken.expiresOn) &&\r\n      this.msToken.accessToken\r\n    ) {\r\n      return this.msToken.accessToken\r\n    }\r\n    if (this.isValidEmail(email)) {\r\n      try {\r\n        this.msToken = await this.getTokenForEmail(email)\r\n        if (this.msToken.accessToken) {\r\n          this.emailUsed = email\r\n          return this.msToken.accessToken\r\n        }\r\n      } catch (error) {\r\n        if (!this.code) {\r\n          this.login(email)\r\n        }\r\n      }\r\n    }\r\n    if (this.msConfig.defaultEmailId && this.isValidEmail(this.msConfig.defaultEmailId)) {\r\n      try {\r\n        this.msToken = await this.getTokenForEmail(this.msConfig.defaultEmailId)\r\n        if (this.msToken.accessToken) {\r\n          this.emailUsed = this.msConfig.defaultEmailId\r\n          return this.msToken.accessToken\r\n        }\r\n      } catch (error) { }\r\n    }\r\n    throw new Error('UNABLE TO FETCH MS AUTH TOKEN')\r\n  }\r\n\r\n  loginForSSOEnabledEmbed(email: string) {\r\n    if (!this.isValidEmail(email)) {\r\n      this.loggerSvc.warn('SSO Login request Ignored. Invalid Email Id for SSO Enabled Content')\r\n    }\r\n    let msPrevTS = 0\r\n    try {\r\n      msPrevTS = parseInt(storage.getItem(storageKey) || '0', 10)\r\n    } catch (error) { }\r\n    if (!msPrevTS || (msPrevTS && (Date.now() - msPrevTS) / 1000 > msTokenExpiryDuration)) {\r\n      this.loggerSvc.info(\r\n        `last login exceeded ${msTokenExpiryDuration} duration. Redirecting to O365 login`,\r\n      )\r\n      storage.setItem(storageKey, Date.now().toString())\r\n      this.login(email)\r\n    }\r\n  }\r\n\r\n  isValidEmail(email: string) {\r\n    return this.msConfig.validEmailExtensions.some(ext => email.endsWith(ext))\r\n  }\r\n\r\n  isValid(accessToken: string | undefined, expiresOn: string | undefined): boolean {\r\n    if (accessToken && expiresOn) {\r\n      // TODO: Implement expiredOn and Date comparison based validity\r\n      return true\r\n    }\r\n    return false\r\n  }\r\n\r\n  async exchangeTokenForCode(code: string, redirectUrl: string): Promise<any> {\r\n    const response = await this.http\r\n      .get<IWsMsTokenModelResponse>(`${API_ENDPOINTS}?code=${code}&redirectUrl=${redirectUrl}`)\r\n      .toPromise()\r\n    return this.getInstanceFromResponse(response)\r\n  }\r\n\r\n  async getTokenForEmail(email: string): Promise<any> {\r\n    const response = await this.http\r\n      .get<IWsMsTokenModelResponse>(`${API_ENDPOINTS.sharePointToken}?email=${email}`)\r\n      .toPromise()\r\n    return this.getInstanceFromResponse(response)\r\n  }\r\n\r\n  getInstanceFromResponse(token: IWsMsTokenModelResponse) {\r\n    return {\r\n      accessToken: token.accessToken,\r\n      expiresOn: token.expiresOn,\r\n      resource: token.resource,\r\n      tokenType: token.tokenType,\r\n    }\r\n  }\r\n}\r\n"]}