@bravobit/bb-foundation 0.21.6 → 0.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (261) hide show
  1. package/auth/lib/auth.interceptor.d.ts +1 -1
  2. package/auth/lib/auth.module.d.ts +4 -5
  3. package/auth/lib/auth.service.d.ts +4 -7
  4. package/auth/lib/directives/abstract.directive.d.ts +12 -0
  5. package/auth/lib/directives/authenticated.directive.d.ts +7 -4
  6. package/auth/lib/directives/permission.directive.d.ts +11 -11
  7. package/auth/lib/guards/anonymous.guard.d.ts +8 -5
  8. package/auth/lib/guards/authenticated.guard.d.ts +8 -5
  9. package/auth/lib/guards/permission.guard.d.ts +15 -0
  10. package/auth/lib/interfaces/config.interface.d.ts +14 -8
  11. package/auth/lib/interfaces/permission.interface.d.ts +6 -0
  12. package/auth/lib/interfaces/provider.interface.d.ts +10 -3
  13. package/auth/lib/permissions/permissions.handler.d.ts +9 -0
  14. package/auth/lib/permissions/permissions.service.d.ts +16 -0
  15. package/auth/lib/providers/email.provider.d.ts +2 -8
  16. package/auth/lib/providers/verify.provider.d.ts +2 -6
  17. package/auth/public_api.d.ts +4 -4
  18. package/controls/lib/checkbox/checkbox/checkbox.component.d.ts +5 -1
  19. package/controls/lib/control-error/control-error/control-error.animation.d.ts +1 -0
  20. package/controls/lib/control-error/control-error/control-error.component.d.ts +17 -0
  21. package/controls/lib/control-error/control-error-submit.directive.d.ts +15 -0
  22. package/controls/lib/control-error/control-error.defaults.d.ts +2 -0
  23. package/controls/lib/control-error/control-error.interface.d.ts +12 -0
  24. package/controls/lib/control-error/control-error.module.d.ts +9 -0
  25. package/controls/lib/controls.interfaces.d.ts +4 -0
  26. package/controls/lib/controls.module.d.ts +7 -2
  27. package/controls/lib/form-control/form-control/form-control.component.d.ts +31 -0
  28. package/controls/lib/form-control/form-control-addon/form-control-addon.component.d.ts +6 -0
  29. package/controls/lib/form-control/form-control-input.directive.d.ts +35 -0
  30. package/controls/lib/form-control/form-control.module.d.ts +11 -0
  31. package/controls/public_api.d.ts +9 -0
  32. package/dashboard/lib/dashboard/dashboard.component.d.ts +2 -1
  33. package/dialog/lib/dialog-confirm/dialog-confirm.component.d.ts +10 -5
  34. package/dialog/lib/dialog-container/dialog-container.animations.d.ts +1 -0
  35. package/dialog/lib/dialog-container/dialog-container.component.d.ts +5 -7
  36. package/dialog/lib/dialog-header/dialog-header.component.d.ts +1 -3
  37. package/dialog/lib/dialog-modal/dialog-modal.component.d.ts +7 -3
  38. package/dialog/lib/dialog-overlay/dialog-overlay.animations.d.ts +1 -0
  39. package/dialog/lib/dialog-overlay/dialog-overlay.component.d.ts +5 -7
  40. package/dialog/lib/dialog.service.d.ts +4 -3
  41. package/elements/lib/directives/focus-trap.directive.d.ts +1 -1
  42. package/elements/lib/directives/focus.directive.d.ts +1 -3
  43. package/elements/lib/pipes/file-image.pipe.d.ts +2 -1
  44. package/esm2020/auth/lib/auth.interceptor.mjs +9 -12
  45. package/esm2020/auth/lib/auth.module.mjs +7 -17
  46. package/esm2020/auth/lib/auth.service.mjs +29 -55
  47. package/esm2020/auth/lib/directives/abstract.directive.mjs +40 -0
  48. package/esm2020/auth/lib/directives/authenticated.directive.mjs +25 -14
  49. package/esm2020/auth/lib/directives/permission.directive.mjs +24 -46
  50. package/esm2020/auth/lib/guards/anonymous.guard.mjs +28 -19
  51. package/esm2020/auth/lib/guards/authenticated.guard.mjs +31 -20
  52. package/esm2020/auth/lib/guards/permission.guard.mjs +53 -0
  53. package/esm2020/auth/lib/helpers/jwt.helper.mjs +7 -7
  54. package/esm2020/auth/lib/interfaces/config.interface.mjs +1 -1
  55. package/esm2020/auth/lib/interfaces/permission.interface.mjs +2 -0
  56. package/esm2020/auth/lib/interfaces/provider.interface.mjs +1 -1
  57. package/esm2020/auth/lib/permissions/permissions.handler.mjs +33 -0
  58. package/esm2020/auth/lib/permissions/permissions.service.mjs +64 -0
  59. package/esm2020/auth/lib/providers/email.provider.mjs +8 -9
  60. package/esm2020/auth/lib/providers/verify.provider.mjs +8 -5
  61. package/esm2020/auth/public_api.mjs +5 -5
  62. package/esm2020/collections/lib/collections.module.mjs +4 -4
  63. package/esm2020/collections/lib/components/collections-pager/collections-pager.component.mjs +3 -3
  64. package/esm2020/collections/lib/components/collections-viewer/collections-viewer.component.mjs +3 -3
  65. package/esm2020/collections/lib/components/collections.directive.mjs +12 -12
  66. package/esm2020/controls/lib/checkbox/checkbox/checkbox.component.mjs +19 -6
  67. package/esm2020/controls/lib/checkbox/checkbox-group/checkbox-group.component.mjs +4 -4
  68. package/esm2020/controls/lib/checkbox/checkbox.module.mjs +4 -4
  69. package/esm2020/controls/lib/control-error/control-error/control-error.animation.mjs +14 -0
  70. package/esm2020/controls/lib/control-error/control-error/control-error.component.mjs +63 -0
  71. package/esm2020/controls/lib/control-error/control-error-submit.directive.mjs +47 -0
  72. package/esm2020/controls/lib/control-error/control-error.defaults.mjs +26 -0
  73. package/esm2020/controls/lib/control-error/control-error.interface.mjs +3 -0
  74. package/esm2020/controls/lib/control-error/control-error.module.mjs +19 -0
  75. package/esm2020/controls/lib/controls.interfaces.mjs +2 -0
  76. package/esm2020/controls/lib/controls.module.mjs +45 -8
  77. package/esm2020/controls/lib/form-control/form-control/form-control.component.mjs +94 -0
  78. package/esm2020/controls/lib/form-control/form-control-addon/form-control-addon.component.mjs +22 -0
  79. package/esm2020/controls/lib/form-control/form-control-input.directive.mjs +124 -0
  80. package/esm2020/controls/lib/form-control/form-control.module.mjs +33 -0
  81. package/esm2020/controls/public_api.mjs +10 -1
  82. package/esm2020/dashboard/lib/dashboard/dashboard.component.mjs +7 -6
  83. package/esm2020/dashboard/lib/dashboard-header/dashboard-header.component.mjs +3 -3
  84. package/esm2020/dashboard/lib/dashboard-menu/dashboard-menu.component.mjs +3 -3
  85. package/esm2020/dashboard/lib/dashboard-menu-item/dashboard-menu-item.component.mjs +3 -3
  86. package/esm2020/dashboard/lib/dashboard-sidebar/dashboard-sidebar.component.mjs +3 -3
  87. package/esm2020/dashboard/lib/dashboard-sidebar-group/dashboard-sidebar-group.component.mjs +3 -3
  88. package/esm2020/dashboard/lib/dashboard-sidebar-item/dashboard-sidebar-item.component.mjs +3 -3
  89. package/esm2020/dashboard/lib/dashboard.module.mjs +4 -4
  90. package/esm2020/dialog/lib/dialog-actions/dialog-actions.component.mjs +3 -3
  91. package/esm2020/dialog/lib/dialog-confirm/dialog-confirm.component.mjs +17 -11
  92. package/esm2020/dialog/lib/dialog-container/dialog-container.animations.mjs +29 -0
  93. package/esm2020/dialog/lib/dialog-container/dialog-container.component.mjs +28 -104
  94. package/esm2020/dialog/lib/dialog-header/dialog-header.component.mjs +7 -14
  95. package/esm2020/dialog/lib/dialog-link/dialog-link.component.mjs +4 -4
  96. package/esm2020/dialog/lib/dialog-modal/dialog-modal.component.mjs +29 -8
  97. package/esm2020/dialog/lib/dialog-overlay/dialog-overlay.animations.mjs +26 -0
  98. package/esm2020/dialog/lib/dialog-overlay/dialog-overlay.component.mjs +29 -84
  99. package/esm2020/dialog/lib/dialog.insertion.mjs +3 -3
  100. package/esm2020/dialog/lib/dialog.module.mjs +4 -4
  101. package/esm2020/dialog/lib/dialog.service.mjs +8 -7
  102. package/esm2020/elements/lib/avatar/avatar.component.mjs +8 -6
  103. package/esm2020/elements/lib/button/button.component.mjs +6 -6
  104. package/esm2020/elements/lib/checkbox/checkbox.component.mjs +3 -3
  105. package/esm2020/elements/lib/date-picker/date-picker.component.mjs +3 -3
  106. package/esm2020/elements/lib/directives/addon.directive.mjs +6 -6
  107. package/esm2020/elements/lib/directives/autosize.directive.mjs +3 -3
  108. package/esm2020/elements/lib/directives/focus-trap.directive.mjs +5 -5
  109. package/esm2020/elements/lib/directives/focus.directive.mjs +7 -9
  110. package/esm2020/elements/lib/directives/form-submit.directive.mjs +3 -3
  111. package/esm2020/elements/lib/directives/form-submitter.directive.mjs +3 -3
  112. package/esm2020/elements/lib/directives/input.directive.mjs +6 -6
  113. package/esm2020/elements/lib/directives/template.directive.mjs +3 -3
  114. package/esm2020/elements/lib/dropdown/dropdown.component.mjs +6 -6
  115. package/esm2020/elements/lib/elements.module.mjs +4 -4
  116. package/esm2020/elements/lib/file-picker/file-picker.component.mjs +3 -3
  117. package/esm2020/elements/lib/form-control/form-control.component.mjs +3 -3
  118. package/esm2020/elements/lib/form-error/form-error.component.mjs +3 -3
  119. package/esm2020/elements/lib/form-group/form-group.component.mjs +3 -3
  120. package/esm2020/elements/lib/icon/icon.component.mjs +3 -3
  121. package/esm2020/elements/lib/image-picker/image-picker.component.mjs +3 -3
  122. package/esm2020/elements/lib/pipes/file-image.pipe.mjs +8 -7
  123. package/esm2020/elements/lib/pipes/file-size.pipe.mjs +3 -3
  124. package/esm2020/elements/lib/pipes/relative-time.pipe.mjs +3 -3
  125. package/esm2020/elements/lib/spinner/spinner.component.mjs +3 -3
  126. package/esm2020/elements/lib/tag/tag.component.mjs +3 -3
  127. package/esm2020/http/lib/http.module.mjs +4 -4
  128. package/esm2020/http/lib/interceptors/base-url.interceptor.mjs +3 -3
  129. package/esm2020/http/lib/interceptors/error.interceptor.mjs +3 -3
  130. package/esm2020/lib/core/services/clipboard.service.mjs +5 -5
  131. package/esm2020/lib/core/services/exif.service.mjs +5 -5
  132. package/esm2020/lib/core/services/file-loader.service.mjs +3 -3
  133. package/esm2020/lib/core/services/image-converter.service.mjs +5 -5
  134. package/esm2020/lib/core/services/languages.service.mjs +3 -3
  135. package/esm2020/lib/core/services/network.service.mjs +7 -7
  136. package/esm2020/lib/core/services/patch.service.mjs +7 -7
  137. package/esm2020/localize/lib/localize.module.mjs +4 -4
  138. package/esm2020/localize/lib/localize.pipe.mjs +3 -3
  139. package/esm2020/localize/lib/localize.service.mjs +5 -5
  140. package/esm2020/localize/lib/views/localize-string/localize-string.component.mjs +3 -3
  141. package/esm2020/localize/lib/views/localize-template-or-string.directive.mjs +3 -3
  142. package/esm2020/localize/lib/views/localize-template.directive.mjs +3 -3
  143. package/esm2020/masking/lib/directives/currency-mask.directive.mjs +3 -3
  144. package/esm2020/masking/lib/directives/date-mask.directive.mjs +3 -3
  145. package/esm2020/masking/lib/directives/input-mask.directive.mjs +3 -3
  146. package/esm2020/masking/lib/masking.module.mjs +4 -4
  147. package/esm2020/masking/lib/masking.service.mjs +3 -3
  148. package/esm2020/notifications/lib/notifications-item/notifications-item.component.mjs +5 -5
  149. package/esm2020/notifications/lib/notifications-list/notifications-list.component.mjs +7 -7
  150. package/esm2020/notifications/lib/notifications.module.mjs +4 -4
  151. package/esm2020/notifications/lib/notifications.service.mjs +5 -5
  152. package/esm2020/public_api.mjs +1 -2
  153. package/esm2020/recaptcha/lib/recaptcha/recaptcha.component.mjs +3 -3
  154. package/esm2020/recaptcha/lib/recaptcha-loader.service.mjs +10 -10
  155. package/esm2020/recaptcha/lib/recaptcha.module.mjs +4 -4
  156. package/esm2020/storage/lib/storage.service.mjs +5 -5
  157. package/esm2020/table/lib/components/table/table.component.mjs +9 -9
  158. package/esm2020/table/lib/components/table-cell/table-cell.component.mjs +3 -3
  159. package/esm2020/table/lib/components/table-header-cell/table-header-cell.component.mjs +3 -3
  160. package/esm2020/table/lib/components/table-pager/table-pager.component.mjs +3 -3
  161. package/esm2020/table/lib/table.module.mjs +4 -4
  162. package/esm2020/theming/lib/themes/checkbox-group.theme.mjs +17 -2
  163. package/esm2020/theming/lib/themes/checkbox.theme.mjs +35 -2
  164. package/esm2020/theming/lib/themes/control-error.theme.mjs +11 -0
  165. package/esm2020/theming/lib/themes/form-control-addon.theme.mjs +6 -0
  166. package/esm2020/theming/lib/themes/form-control.theme.mjs +45 -0
  167. package/esm2020/theming/lib/theming.data.mjs +82 -0
  168. package/esm2020/theming/lib/theming.directive.mjs +38 -0
  169. package/esm2020/theming/lib/theming.interface.mjs +2 -3
  170. package/esm2020/theming/lib/theming.module.mjs +12 -34
  171. package/esm2020/theming/lib/utils/theming.variable.mjs +41 -0
  172. package/esm2020/theming/public_api.mjs +6 -3
  173. package/fesm2015/bravobit-bb-foundation-auth.mjs +326 -284
  174. package/fesm2015/bravobit-bb-foundation-auth.mjs.map +1 -1
  175. package/fesm2015/bravobit-bb-foundation-collections.mjs +22 -22
  176. package/fesm2015/bravobit-bb-foundation-controls.mjs +493 -24
  177. package/fesm2015/bravobit-bb-foundation-controls.mjs.map +1 -1
  178. package/fesm2015/bravobit-bb-foundation-dashboard.mjs +29 -28
  179. package/fesm2015/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  180. package/fesm2015/bravobit-bb-foundation-dialog.mjs +185 -233
  181. package/fesm2015/bravobit-bb-foundation-dialog.mjs.map +1 -1
  182. package/fesm2015/bravobit-bb-foundation-elements.mjs +99 -97
  183. package/fesm2015/bravobit-bb-foundation-elements.mjs.map +1 -1
  184. package/fesm2015/bravobit-bb-foundation-http.mjs +10 -10
  185. package/fesm2015/bravobit-bb-foundation-localize.mjs +20 -20
  186. package/fesm2015/bravobit-bb-foundation-localize.mjs.map +1 -1
  187. package/fesm2015/bravobit-bb-foundation-masking.mjs +16 -16
  188. package/fesm2015/bravobit-bb-foundation-notifications.mjs +18 -17
  189. package/fesm2015/bravobit-bb-foundation-notifications.mjs.map +1 -1
  190. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs +16 -16
  191. package/fesm2015/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  192. package/fesm2015/bravobit-bb-foundation-storage.mjs +4 -4
  193. package/fesm2015/bravobit-bb-foundation-storage.mjs.map +1 -1
  194. package/fesm2015/bravobit-bb-foundation-table.mjs +22 -22
  195. package/fesm2015/bravobit-bb-foundation-theming.mjs +251 -128
  196. package/fesm2015/bravobit-bb-foundation-theming.mjs.map +1 -1
  197. package/fesm2015/bravobit-bb-foundation.mjs +33 -73
  198. package/fesm2015/bravobit-bb-foundation.mjs.map +1 -1
  199. package/fesm2020/bravobit-bb-foundation-auth.mjs +306 -277
  200. package/fesm2020/bravobit-bb-foundation-auth.mjs.map +1 -1
  201. package/fesm2020/bravobit-bb-foundation-collections.mjs +22 -22
  202. package/fesm2020/bravobit-bb-foundation-controls.mjs +477 -24
  203. package/fesm2020/bravobit-bb-foundation-controls.mjs.map +1 -1
  204. package/fesm2020/bravobit-bb-foundation-dashboard.mjs +29 -28
  205. package/fesm2020/bravobit-bb-foundation-dashboard.mjs.map +1 -1
  206. package/fesm2020/bravobit-bb-foundation-dialog.mjs +175 -233
  207. package/fesm2020/bravobit-bb-foundation-dialog.mjs.map +1 -1
  208. package/fesm2020/bravobit-bb-foundation-elements.mjs +99 -97
  209. package/fesm2020/bravobit-bb-foundation-elements.mjs.map +1 -1
  210. package/fesm2020/bravobit-bb-foundation-http.mjs +10 -10
  211. package/fesm2020/bravobit-bb-foundation-localize.mjs +20 -20
  212. package/fesm2020/bravobit-bb-foundation-localize.mjs.map +1 -1
  213. package/fesm2020/bravobit-bb-foundation-masking.mjs +16 -16
  214. package/fesm2020/bravobit-bb-foundation-notifications.mjs +17 -17
  215. package/fesm2020/bravobit-bb-foundation-notifications.mjs.map +1 -1
  216. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs +16 -16
  217. package/fesm2020/bravobit-bb-foundation-recaptcha.mjs.map +1 -1
  218. package/fesm2020/bravobit-bb-foundation-storage.mjs +4 -4
  219. package/fesm2020/bravobit-bb-foundation-storage.mjs.map +1 -1
  220. package/fesm2020/bravobit-bb-foundation-table.mjs +22 -22
  221. package/fesm2020/bravobit-bb-foundation-theming.mjs +252 -120
  222. package/fesm2020/bravobit-bb-foundation-theming.mjs.map +1 -1
  223. package/fesm2020/bravobit-bb-foundation.mjs +32 -70
  224. package/fesm2020/bravobit-bb-foundation.mjs.map +1 -1
  225. package/lib/core/services/clipboard.service.d.ts +2 -2
  226. package/lib/core/services/exif.service.d.ts +1 -1
  227. package/lib/core/services/image-converter.service.d.ts +1 -1
  228. package/lib/core/services/network.service.d.ts +4 -4
  229. package/lib/core/services/patch.service.d.ts +4 -4
  230. package/localize/lib/localize.service.d.ts +1 -1
  231. package/notifications/lib/notifications-item/notifications-item.component.d.ts +1 -1
  232. package/notifications/lib/notifications.service.d.ts +1 -1
  233. package/package.json +4 -4
  234. package/public_api.d.ts +0 -1
  235. package/recaptcha/lib/recaptcha-loader.service.d.ts +3 -3
  236. package/storage/lib/storage.service.d.ts +1 -1
  237. package/theming/lib/themes/checkbox-group.theme.d.ts +14 -3
  238. package/theming/lib/themes/checkbox.theme.d.ts +30 -17
  239. package/theming/lib/themes/control-error.theme.d.ts +9 -0
  240. package/theming/lib/themes/form-control-addon.theme.d.ts +5 -0
  241. package/theming/lib/themes/form-control.theme.d.ts +32 -0
  242. package/theming/lib/theming.data.d.ts +17 -0
  243. package/theming/lib/theming.directive.d.ts +13 -0
  244. package/theming/lib/theming.interface.d.ts +19 -8
  245. package/theming/lib/theming.module.d.ts +3 -9
  246. package/theming/lib/utils/theming.variable.d.ts +16 -0
  247. package/theming/public_api.d.ts +5 -2
  248. package/auth/lib/directives/role.directive.d.ts +0 -16
  249. package/auth/lib/helpers/mapper.helper.d.ts +0 -23
  250. package/auth/lib/interfaces/mapper.interface.d.ts +0 -19
  251. package/auth/lib/permissions.service.d.ts +0 -14
  252. package/esm2020/auth/lib/directives/role.directive.mjs +0 -37
  253. package/esm2020/auth/lib/helpers/mapper.helper.mjs +0 -35
  254. package/esm2020/auth/lib/interfaces/mapper.interface.mjs +0 -2
  255. package/esm2020/auth/lib/permissions.service.mjs +0 -56
  256. package/esm2020/lib/core/services/platform.service.mjs +0 -42
  257. package/esm2020/theming/lib/themes/theme.mjs +0 -34
  258. package/esm2020/theming/lib/theming.service.mjs +0 -77
  259. package/lib/core/services/platform.service.d.ts +0 -18
  260. package/theming/lib/themes/theme.d.ts +0 -12
  261. package/theming/lib/theming.service.d.ts +0 -22
@@ -1,20 +1,18 @@
1
- import { AfterViewInit, ChangeDetectorRef, ComponentFactoryResolver, ComponentRef, ElementRef, Type } from '@angular/core';
2
- import { AnimationEvent } from '@angular/animations';
1
+ import { ComponentRef, ElementRef, OnDestroy, OnInit, Type } from '@angular/core';
3
2
  import { Subject } from 'rxjs';
4
3
  import { BbDialogInsertion } from '../dialog.insertion';
4
+ import { AnimationEvent } from '@angular/animations';
5
5
  import * as i0 from "@angular/core";
6
- export declare class BbDialogContainer implements AfterViewInit {
6
+ export declare class BbDialogContainer implements OnInit, OnDestroy {
7
7
  private _elementRef;
8
- private _changeDetection;
9
- private _componentFactoryResolver;
10
8
  insertion: BbDialogInsertion;
11
9
  componentRef: ComponentRef<any> | null;
12
10
  childComponentType: Type<any> | null;
13
11
  overlayClicked$: Subject<void>;
14
12
  private _subscription;
15
13
  get onOverlayClicked(): import("rxjs").Observable<void>;
16
- constructor(_elementRef: ElementRef, _changeDetection: ChangeDetectorRef, _componentFactoryResolver: ComponentFactoryResolver);
17
- ngAfterViewInit(): void;
14
+ constructor(_elementRef: ElementRef);
15
+ ngOnInit(): void;
18
16
  ngOnDestroy(): void;
19
17
  onAnimationDone(event: AnimationEvent): void;
20
18
  private listenForClicks;
@@ -1,9 +1,7 @@
1
1
  import { EventEmitter } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class BbDialogHeader {
4
- iconName: string | null;
5
- iconColor: string;
6
4
  closeRequested: EventEmitter<void>;
7
5
  static ɵfac: i0.ɵɵFactoryDeclaration<BbDialogHeader, never>;
8
- static ɵcmp: i0.ɵɵComponentDeclaration<BbDialogHeader, "[bb-dialog-header]", never, { "iconName": "iconName"; "iconColor": "iconColor"; }, { "closeRequested": "closeRequested"; }, never, ["*", "[bb-dialog-link]"], false>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<BbDialogHeader, "[bb-dialog-header]", never, {}, { "closeRequested": "closeRequested"; }, never, ["*", "[bb-dialog-link]"], false>;
9
7
  }
@@ -1,12 +1,16 @@
1
- import { OnInit } from '@angular/core';
1
+ import { OnInit, Renderer2 } from '@angular/core';
2
2
  import { Patch } from '@bravobit/bb-foundation';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class BbDialogModal implements OnInit {
5
5
  private _patch;
6
+ private _renderer;
7
+ private _document?;
6
8
  maxWidth: string | null;
7
9
  onOverlayClickedEvent(event: MouseEvent): void;
8
- constructor(_patch: Patch);
10
+ constructor(_patch: Patch, _renderer: Renderer2, _document?: Document);
9
11
  ngOnInit(): void;
10
- static ɵfac: i0.ɵɵFactoryDeclaration<BbDialogModal, never>;
12
+ ngOnDestroy(): void;
13
+ private allowGlobalOverflow;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<BbDialogModal, [null, null, { optional: true; }]>;
11
15
  static ɵcmp: i0.ɵɵComponentDeclaration<BbDialogModal, "[bb-dialog-modal]", never, { "maxWidth": "maxWidth"; }, {}, never, ["[bb-dialog-header]", "*", "[bb-dialog-actions]"], false>;
12
16
  }
@@ -0,0 +1 @@
1
+ export declare const bbDialogOverlayAnimation: import("@angular/animations").AnimationTriggerMetadata;
@@ -1,22 +1,20 @@
1
- import { AfterViewInit, ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy } from '@angular/core';
1
+ import { ChangeDetectorRef, ElementRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import { AnimationEvent } from '@angular/animations';
3
3
  import * as i0 from "@angular/core";
4
- export declare class BbDialogOverlay implements AfterViewInit, OnDestroy {
4
+ export declare class BbDialogOverlay implements OnInit, OnDestroy {
5
5
  private _elementRef;
6
6
  private _changeDetection;
7
- animations: boolean;
8
7
  closeRequested: EventEmitter<void>;
9
- private _state;
8
+ state: 'open' | 'close';
10
9
  private _closed$;
11
10
  private _subscription;
12
- get state(): "none" | "open" | "close";
13
11
  constructor(_elementRef: ElementRef, _changeDetection: ChangeDetectorRef);
14
- ngAfterViewInit(): void;
12
+ ngOnInit(): void;
15
13
  ngOnDestroy(): void;
16
14
  onKeyEvent(event: KeyboardEvent): void;
17
15
  onAnimationDone(event: AnimationEvent): void;
18
16
  close(): Promise<void>;
19
17
  private listenForClicks;
20
18
  static ɵfac: i0.ɵɵFactoryDeclaration<BbDialogOverlay, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<BbDialogOverlay, "bb-dialog-overlay", never, { "animations": "animations"; }, { "closeRequested": "closeRequested"; }, never, ["[bb-dialog-modal]"], false>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<BbDialogOverlay, "bb-dialog-overlay", never, {}, { "closeRequested": "closeRequested"; }, never, ["[bb-dialog-modal]"], false>;
22
20
  }
@@ -1,4 +1,4 @@
1
- import { ApplicationRef, ComponentFactoryResolver, Injector, Type } from '@angular/core';
1
+ import { ApplicationRef, ComponentFactoryResolver, Injector, TemplateRef, Type } from '@angular/core';
2
2
  import { BbDialogConfig } from './dialog.interfaces';
3
3
  import { BbDialogRef } from './dialog.ref';
4
4
  import * as i0 from "@angular/core";
@@ -7,10 +7,11 @@ export declare class Dialog {
7
7
  private _applicationRef;
8
8
  private _componentFactoryResolver;
9
9
  constructor(_injector: Injector, _applicationRef: ApplicationRef, _componentFactoryResolver: ComponentFactoryResolver);
10
- open<T = any>(componentType: Type<any>, config: BbDialogConfig): BbDialogRef<T>;
11
- confirm(title: string, description: string, options?: {
10
+ open<T = any>(componentType: Type<any>, config?: BbDialogConfig): BbDialogRef<T>;
11
+ confirm(title: string, description: string | TemplateRef<any>, options?: {
12
12
  cancelButtonText?: string;
13
13
  confirmButtonText?: string;
14
+ width?: string;
14
15
  }): BbDialogRef<boolean>;
15
16
  private createDialog;
16
17
  private deleteDialog;
@@ -1,5 +1,5 @@
1
1
  import { ElementRef } from '@angular/core';
2
- import { Platform } from '@bravobit/bb-foundation';
2
+ import { Platform } from '@angular/cdk/platform';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class BbFocusTrap {
5
5
  private _platform;
@@ -1,11 +1,9 @@
1
1
  import { AfterViewInit, ElementRef, NgZone } from '@angular/core';
2
- import { Platform } from '@bravobit/bb-foundation';
3
2
  import * as i0 from "@angular/core";
4
3
  export declare class BbFocus implements AfterViewInit {
5
4
  private _zone;
6
- private _platform;
7
5
  private _elementRef;
8
- constructor(_zone: NgZone, _platform: Platform, _elementRef: ElementRef);
6
+ constructor(_zone: NgZone, _elementRef: ElementRef);
9
7
  private get nativeElement();
10
8
  ngAfterViewInit(): void;
11
9
  private focus;
@@ -1,6 +1,7 @@
1
- import { ImageConverter, Platform } from '@bravobit/bb-foundation';
1
+ import { ImageConverter } from '@bravobit/bb-foundation';
2
2
  import { DomSanitizer } from '@angular/platform-browser';
3
3
  import { PipeTransform } from '@angular/core';
4
+ import { Platform } from '@angular/cdk/platform';
4
5
  import * as i0 from "@angular/core";
5
6
  export declare class BbFileImage implements PipeTransform {
6
7
  private _platform;
@@ -12,14 +12,15 @@ export class AuthInterceptor {
12
12
  this._auth = _auth;
13
13
  this._config = _config;
14
14
  // Readonly data.
15
- this._authHeaderString = 'Authorization';
15
+ this._authHeaderString = this._config?.http?.header ?? 'Authorization';
16
+ this._authScheme = this._config?.http?.scheme ?? 'Bearer';
16
17
  // Data.
17
18
  this.isRefreshing = false;
18
19
  this.refreshingAccessToken$ = new BehaviorSubject(null);
19
20
  this.getAccessToken = (request) => {
20
21
  // Get the token based on header.
21
- if (request.headers.has('Authorization')) {
22
- return request.headers.get('Authorization');
22
+ if (request.headers.has(this._authHeaderString)) {
23
+ return request.headers.get(this._authHeaderString);
23
24
  }
24
25
  // Return the default access token.
25
26
  return this._auth.session.accessToken;
@@ -34,13 +35,9 @@ export class AuthInterceptor {
34
35
  }
35
36
  // Add the auth header to the request.
36
37
  return request.clone({
37
- setHeaders: { [this._authHeaderString]: this.getFullAuthorizationHeader(accessToken) }
38
+ setHeaders: { [this._authHeaderString]: `${this._authScheme} ${accessToken}` }
38
39
  });
39
40
  };
40
- this.getFullAuthorizationHeader = (token) => {
41
- const authScheme = this._config?.scheme ?? 'Bearer';
42
- return [authScheme, token].join(' ');
43
- };
44
41
  }
45
42
  intercept(request, next) {
46
43
  // 1. Check if the user wants to use the authorization for this request.
@@ -83,11 +80,11 @@ export class AuthInterceptor {
83
80
  return of(null);
84
81
  }
85
82
  }
86
- AuthInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthInterceptor, deps: [{ token: i1.Auth }, { token: i2.AuthConfig, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
87
- AuthInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthInterceptor });
88
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthInterceptor, decorators: [{
83
+ AuthInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthInterceptor, deps: [{ token: i1.Auth }, { token: i2.AuthConfig, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
84
+ AuthInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthInterceptor });
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthInterceptor, decorators: [{
89
86
  type: Injectable
90
87
  }], ctorParameters: function () { return [{ type: i1.Auth }, { type: i2.AuthConfig, decorators: [{
91
88
  type: Optional
92
89
  }] }]; } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpErrorResponse, HttpHandler, HttpInterceptor, HttpRequest} from '@angular/common/http';\nimport {catchError, filter, finalize, switchMap, take} from 'rxjs/operators';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthConfig} from './interfaces/config.interface';\nimport {HttpError} from '@bravobit/bb-foundation/http';\nimport {BehaviorSubject, of, throwError} from 'rxjs';\nimport {Injectable, Optional} from '@angular/core';\nimport {Auth} from './auth.service';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n    // Readonly data.\n    private readonly _authHeaderString: string = 'Authorization';\n\n    // Data.\n    isRefreshing: boolean = false;\n    refreshingAccessToken$ = new BehaviorSubject<string | null>(null);\n\n    constructor(private _auth: Auth,\n                @Optional() private _config: AuthConfig) {\n    }\n\n    intercept(request: HttpRequest<unknown>, next: HttpHandler) {\n        // 1. Check if the user wants to use the authorization for this request.\n        if (!request.context.get(USE_AUTHORIZATION)) {\n            return next.handle(request);\n        }\n\n        // 2. Compose the new request.\n        const accessToken = this.getAccessToken(request);\n        const newRequest = this.addAuthorizationHeader(request, accessToken);\n\n        // 3. Handle all errors.\n        return next.handle(newRequest).pipe(\n            catchError(error => {\n                // Handle the HTTP401 error.\n                if ((error instanceof HttpErrorResponse || error instanceof HttpError) && error?.status === 401) {\n                    return this.handle401Error(request, next);\n                }\n\n                // Just re-throw the parsed error.\n                return throwError(() => error);\n            })\n        );\n    }\n\n    private handle401Error(request: HttpRequest<unknown>, next: HttpHandler) {\n        // If already refreshing wait for the refresh token to complete.\n        if (this.isRefreshing) {\n            return this.refreshingAccessToken$.pipe(\n                filter(accessToken => accessToken !== null),\n                take(1),\n                switchMap(accessToken => next.handle(this.addAuthorizationHeader(request, accessToken)))\n            );\n        }\n\n        // Set the refreshing to true.\n        this.isRefreshing = true;\n        this.refreshingAccessToken$.next(null);\n\n        return this._auth.refresh().pipe(\n            switchMap(newAccessToken => {\n                if (!newAccessToken) {\n                    return throwError(() => new Error('No refresh token was available.'));\n                }\n\n                this.refreshingAccessToken$.next(newAccessToken);\n                return next.handle(this.addAuthorizationHeader(request, newAccessToken));\n            }),\n            catchError(() => this.logoutUser()),\n            finalize(() => this.isRefreshing = false)\n        );\n    }\n\n    private logoutUser() {\n        // Handle the refresh error.\n        this._auth.clearAndRedirect();\n\n        // Return null as data.\n        return of(null);\n    }\n\n    private getAccessToken = (request: HttpRequest<unknown>) => {\n        // Get the token based on header.\n        if (request.headers.has('Authorization')) {\n            return request.headers.get('Authorization');\n        }\n\n        // Return the default access token.\n        return this._auth.session.accessToken;\n    };\n\n    private addAuthorizationHeader = (request: HttpRequest<unknown>, accessToken: string | null = null) => {\n        // Remove auth header when we do not have\n        // an access token.\n        if (!accessToken) {\n            return request.clone({\n                headers: request.headers.delete(this._authHeaderString)\n            });\n        }\n\n        // Add the auth header to the request.\n        return request.clone({\n            setHeaders: {[this._authHeaderString]: this.getFullAuthorizationHeader(accessToken)}\n        });\n    };\n\n    private getFullAuthorizationHeader = (token: string) => {\n        const authScheme = this._config?.scheme ?? 'Bearer';\n        return [authScheme, token].join(' ');\n    };\n\n}\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpErrorResponse, HttpHandler, HttpInterceptor, HttpRequest} from '@angular/common/http';\nimport {catchError, filter, finalize, switchMap, take} from 'rxjs/operators';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthConfig} from './interfaces/config.interface';\nimport {HttpError} from '@bravobit/bb-foundation/http';\nimport {BehaviorSubject, of, throwError} from 'rxjs';\nimport {Injectable, Optional} from '@angular/core';\nimport {Auth} from './auth.service';\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n    // Readonly data.\n    private readonly _authHeaderString: string = this._config?.http?.header ?? 'Authorization';\n    private readonly _authScheme: string = this._config?.http?.scheme ?? 'Bearer';\n\n    // Data.\n    isRefreshing: boolean = false;\n    refreshingAccessToken$ = new BehaviorSubject<string | null>(null);\n\n    constructor(private _auth: Auth,\n                @Optional() private _config: AuthConfig) {\n    }\n\n    intercept(request: HttpRequest<unknown>, next: HttpHandler) {\n        // 1. Check if the user wants to use the authorization for this request.\n        if (!request.context.get(USE_AUTHORIZATION)) {\n            return next.handle(request);\n        }\n\n        // 2. Compose the new request.\n        const accessToken = this.getAccessToken(request);\n        const newRequest = this.addAuthorizationHeader(request, accessToken);\n\n        // 3. Handle all errors.\n        return next.handle(newRequest).pipe(\n            catchError(error => {\n                // Handle the HTTP401 error.\n                if ((error instanceof HttpErrorResponse || error instanceof HttpError) && error?.status === 401) {\n                    return this.handle401Error(request, next);\n                }\n\n                // Just re-throw the parsed error.\n                return throwError(() => error);\n            })\n        );\n    }\n\n    private handle401Error(request: HttpRequest<unknown>, next: HttpHandler) {\n        // If already refreshing wait for the refresh token to complete.\n        if (this.isRefreshing) {\n            return this.refreshingAccessToken$.pipe(\n                filter(accessToken => accessToken !== null),\n                take(1),\n                switchMap(accessToken => next.handle(this.addAuthorizationHeader(request, accessToken)))\n            );\n        }\n\n        // Set the refreshing to true.\n        this.isRefreshing = true;\n        this.refreshingAccessToken$.next(null);\n\n        return this._auth.refresh().pipe(\n            switchMap(newAccessToken => {\n                if (!newAccessToken) {\n                    return throwError(() => new Error('No refresh token was available.'));\n                }\n\n                this.refreshingAccessToken$.next(newAccessToken);\n                return next.handle(this.addAuthorizationHeader(request, newAccessToken));\n            }),\n            catchError(() => this.logoutUser()),\n            finalize(() => this.isRefreshing = false)\n        );\n    }\n\n    private logoutUser() {\n        // Handle the refresh error.\n        this._auth.clearAndRedirect();\n\n        // Return null as data.\n        return of(null);\n    }\n\n    private getAccessToken = (request: HttpRequest<unknown>) => {\n        // Get the token based on header.\n        if (request.headers.has(this._authHeaderString)) {\n            return request.headers.get(this._authHeaderString);\n        }\n\n        // Return the default access token.\n        return this._auth.session.accessToken;\n    };\n\n    private addAuthorizationHeader = (request: HttpRequest<unknown>, accessToken: string | null = null) => {\n        // Remove auth header when we do not have\n        // an access token.\n        if (!accessToken) {\n            return request.clone({\n                headers: request.headers.delete(this._authHeaderString)\n            });\n        }\n\n        // Add the auth header to the request.\n        return request.clone({\n            setHeaders: {[this._authHeaderString]: `${this._authScheme} ${accessToken}`}\n        });\n    };\n\n}\n"]}
@@ -2,16 +2,13 @@ import { APP_INITIALIZER, NgModule } from '@angular/core';
2
2
  import { HTTP_INTERCEPTORS, HttpClientModule } from '@angular/common/http';
3
3
  import { BbAuthenticated } from './directives/authenticated.directive';
4
4
  import { BbPermission } from './directives/permission.directive';
5
+ import { Permissions } from './permissions/permissions.service';
5
6
  import { AuthConfig } from './interfaces/config.interface';
6
7
  import { AuthInterceptor } from './auth.interceptor';
7
- import { AuthMapper } from './helpers/mapper.helper';
8
- import { BbRole } from './directives/role.directive';
9
- import { Permissions } from './permissions.service';
10
8
  import { Auth } from './auth.service';
11
9
  import * as i0 from "@angular/core";
12
10
  const DECLARATIONS_EXPORTS = [
13
11
  BbAuthenticated,
14
- BbRole,
15
12
  BbPermission
16
13
  ];
17
14
  export class AuthModule {
@@ -28,27 +25,20 @@ export class AuthModule {
28
25
  };
29
26
  }
30
27
  }
31
- AuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
32
- AuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.5", ngImport: i0, type: AuthModule, declarations: [BbAuthenticated,
33
- BbRole,
28
+ AuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
29
+ AuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.1", ngImport: i0, type: AuthModule, declarations: [BbAuthenticated,
34
30
  BbPermission], imports: [HttpClientModule], exports: [BbAuthenticated,
35
- BbRole,
36
31
  BbPermission] });
37
- AuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthModule, providers: [
38
- { provide: AuthMapper, useClass: AuthMapper }
39
- ], imports: [HttpClientModule] });
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: AuthModule, decorators: [{
32
+ AuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthModule, imports: [HttpClientModule] });
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: AuthModule, decorators: [{
41
34
  type: NgModule,
42
35
  args: [{
43
36
  imports: [HttpClientModule],
44
37
  declarations: [...DECLARATIONS_EXPORTS],
45
- exports: [...DECLARATIONS_EXPORTS],
46
- providers: [
47
- { provide: AuthMapper, useClass: AuthMapper }
48
- ]
38
+ exports: [...DECLARATIONS_EXPORTS]
49
39
  }]
50
40
  }] });
51
41
  export function initializeAuth(auth) {
52
42
  return auth.initialize();
53
43
  }
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYi1mb3VuZGF0aW9uL2F1dGgvc3JjL2xpYi9hdXRoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZUFBZSxFQUF1QixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFDLGlCQUFpQixFQUFFLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDekUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMvRCxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDekQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUNuRCxPQUFPLEVBQUMsTUFBTSxFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDbkQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ2xELE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFFcEMsTUFBTSxvQkFBb0IsR0FBRztJQUN6QixlQUFlO0lBQ2YsTUFBTTtJQUNOLFlBQVk7Q0FDZixDQUFDO0FBVUYsTUFBTSxPQUFPLFVBQVU7SUFFbkIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFtQjtRQUM5QixPQUFPO1lBQ0gsUUFBUSxFQUFFLFVBQVU7WUFDcEIsU0FBUyxFQUFFO2dCQUNQLElBQUk7Z0JBQ0osV0FBVztnQkFDWCxFQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBQztnQkFDdkMsRUFBQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFDO2dCQUNwRSxFQUFDLFVBQVUsRUFBRSxjQUFjLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFDO2FBQ3BGO1NBQ0osQ0FBQztJQUNOLENBQUM7O3VHQWJRLFVBQVU7d0dBQVYsVUFBVSxpQkFibkIsZUFBZTtRQUNmLE1BQU07UUFDTixZQUFZLGFBSUYsZ0JBQWdCLGFBTjFCLGVBQWU7UUFDZixNQUFNO1FBQ04sWUFBWTt3R0FXSCxVQUFVLGFBSlI7UUFDUCxFQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBQztLQUM5QyxZQUxTLGdCQUFnQjsyRkFPakIsVUFBVTtrQkFSdEIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDM0IsWUFBWSxFQUFFLENBQUMsR0FBRyxvQkFBb0IsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsR0FBRyxvQkFBb0IsQ0FBQztvQkFDbEMsU0FBUyxFQUFFO3dCQUNQLEVBQUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFDO3FCQUM5QztpQkFDSjs7QUFrQkQsTUFBTSxVQUFVLGNBQWMsQ0FBQyxJQUFVO0lBQ3JDLE9BQU8sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0FBQzdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0FQUF9JTklUSUFMSVpFUiwgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtIVFRQX0lOVEVSQ0VQVE9SUywgSHR0cENsaWVudE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHtCYkF1dGhlbnRpY2F0ZWR9IGZyb20gJy4vZGlyZWN0aXZlcy9hdXRoZW50aWNhdGVkLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0JiUGVybWlzc2lvbn0gZnJvbSAnLi9kaXJlY3RpdmVzL3Blcm1pc3Npb24uZGlyZWN0aXZlJztcbmltcG9ydCB7QXV0aENvbmZpZ30gZnJvbSAnLi9pbnRlcmZhY2VzL2NvbmZpZy5pbnRlcmZhY2UnO1xuaW1wb3J0IHtBdXRoSW50ZXJjZXB0b3J9IGZyb20gJy4vYXV0aC5pbnRlcmNlcHRvcic7XG5pbXBvcnQge0F1dGhNYXBwZXJ9IGZyb20gJy4vaGVscGVycy9tYXBwZXIuaGVscGVyJztcbmltcG9ydCB7QmJSb2xlfSBmcm9tICcuL2RpcmVjdGl2ZXMvcm9sZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtQZXJtaXNzaW9uc30gZnJvbSAnLi9wZXJtaXNzaW9ucy5zZXJ2aWNlJztcbmltcG9ydCB7QXV0aH0gZnJvbSAnLi9hdXRoLnNlcnZpY2UnO1xuXG5jb25zdCBERUNMQVJBVElPTlNfRVhQT1JUUyA9IFtcbiAgICBCYkF1dGhlbnRpY2F0ZWQsXG4gICAgQmJSb2xlLFxuICAgIEJiUGVybWlzc2lvblxuXTtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbSHR0cENsaWVudE1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uREVDTEFSQVRJT05TX0VYUE9SVFNdLFxuICAgIGV4cG9ydHM6IFsuLi5ERUNMQVJBVElPTlNfRVhQT1JUU10sXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtwcm92aWRlOiBBdXRoTWFwcGVyLCB1c2VDbGFzczogQXV0aE1hcHBlcn1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIEF1dGhNb2R1bGUge1xuXG4gICAgc3RhdGljIGZvclJvb3QoY29uZmlnPzogQXV0aENvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QXV0aE1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IEF1dGhNb2R1bGUsXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICAgICAgICBBdXRoLFxuICAgICAgICAgICAgICAgIFBlcm1pc3Npb25zLFxuICAgICAgICAgICAgICAgIHtwcm92aWRlOiBBdXRoQ29uZmlnLCB1c2VWYWx1ZTogY29uZmlnfSxcbiAgICAgICAgICAgICAgICB7cHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBBdXRoSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlfSxcbiAgICAgICAgICAgICAgICB7dXNlRmFjdG9yeTogaW5pdGlhbGl6ZUF1dGgsIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUiwgZGVwczogW0F1dGhdLCBtdWx0aTogdHJ1ZX1cbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG5cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVBdXRoKGF1dGg6IEF1dGgpIHtcbiAgICByZXR1cm4gYXV0aC5pbml0aWFsaXplKCk7XG59XG4iXX0=
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYi1mb3VuZGF0aW9uL2F1dGgvc3JjL2xpYi9hdXRoLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsZUFBZSxFQUF1QixRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDN0UsT0FBTyxFQUFDLGlCQUFpQixFQUFFLGdCQUFnQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDekUsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHNDQUFzQyxDQUFDO0FBQ3JFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUMvRCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDOUQsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQ3pELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLEVBQUMsSUFBSSxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBRXBDLE1BQU0sb0JBQW9CLEdBQUc7SUFDekIsZUFBZTtJQUNmLFlBQVk7Q0FDZixDQUFDO0FBT0YsTUFBTSxPQUFPLFVBQVU7SUFFbkIsTUFBTSxDQUFDLE9BQU8sQ0FBQyxNQUFrQjtRQUM3QixPQUFPO1lBQ0gsUUFBUSxFQUFFLFVBQVU7WUFDcEIsU0FBUyxFQUFFO2dCQUNQLElBQUk7Z0JBQ0osV0FBVztnQkFDWCxFQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBQztnQkFDdkMsRUFBQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFDO2dCQUNwRSxFQUFDLFVBQVUsRUFBRSxjQUFjLEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFDO2FBQ3BGO1NBQ0osQ0FBQztJQUNOLENBQUM7O3VHQWJRLFVBQVU7d0dBQVYsVUFBVSxpQkFUbkIsZUFBZTtRQUNmLFlBQVksYUFJRixnQkFBZ0IsYUFMMUIsZUFBZTtRQUNmLFlBQVk7d0dBUUgsVUFBVSxZQUpULGdCQUFnQjsyRkFJakIsVUFBVTtrQkFMdEIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDM0IsWUFBWSxFQUFFLENBQUMsR0FBRyxvQkFBb0IsQ0FBQztvQkFDdkMsT0FBTyxFQUFFLENBQUMsR0FBRyxvQkFBb0IsQ0FBQztpQkFDckM7O0FBa0JELE1BQU0sVUFBVSxjQUFjLENBQUMsSUFBVTtJQUNyQyxPQUFPLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUM3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBUFBfSU5JVElBTElaRVIsIE1vZHVsZVdpdGhQcm92aWRlcnMsIE5nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7SFRUUF9JTlRFUkNFUFRPUlMsIEh0dHBDbGllbnRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7QmJBdXRoZW50aWNhdGVkfSBmcm9tICcuL2RpcmVjdGl2ZXMvYXV0aGVudGljYXRlZC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtCYlBlcm1pc3Npb259IGZyb20gJy4vZGlyZWN0aXZlcy9wZXJtaXNzaW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1Blcm1pc3Npb25zfSBmcm9tICcuL3Blcm1pc3Npb25zL3Blcm1pc3Npb25zLnNlcnZpY2UnO1xuaW1wb3J0IHtBdXRoQ29uZmlnfSBmcm9tICcuL2ludGVyZmFjZXMvY29uZmlnLmludGVyZmFjZSc7XG5pbXBvcnQge0F1dGhJbnRlcmNlcHRvcn0gZnJvbSAnLi9hdXRoLmludGVyY2VwdG9yJztcbmltcG9ydCB7QXV0aH0gZnJvbSAnLi9hdXRoLnNlcnZpY2UnO1xuXG5jb25zdCBERUNMQVJBVElPTlNfRVhQT1JUUyA9IFtcbiAgICBCYkF1dGhlbnRpY2F0ZWQsXG4gICAgQmJQZXJtaXNzaW9uXG5dO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtIdHRwQ2xpZW50TW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFsuLi5ERUNMQVJBVElPTlNfRVhQT1JUU10sXG4gICAgZXhwb3J0czogWy4uLkRFQ0xBUkFUSU9OU19FWFBPUlRTXVxufSlcbmV4cG9ydCBjbGFzcyBBdXRoTW9kdWxlIHtcblxuICAgIHN0YXRpYyBmb3JSb290KGNvbmZpZzogQXV0aENvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QXV0aE1vZHVsZT4ge1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgbmdNb2R1bGU6IEF1dGhNb2R1bGUsXG4gICAgICAgICAgICBwcm92aWRlcnM6IFtcbiAgICAgICAgICAgICAgICBBdXRoLFxuICAgICAgICAgICAgICAgIFBlcm1pc3Npb25zLFxuICAgICAgICAgICAgICAgIHtwcm92aWRlOiBBdXRoQ29uZmlnLCB1c2VWYWx1ZTogY29uZmlnfSxcbiAgICAgICAgICAgICAgICB7cHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBBdXRoSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlfSxcbiAgICAgICAgICAgICAgICB7dXNlRmFjdG9yeTogaW5pdGlhbGl6ZUF1dGgsIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUiwgZGVwczogW0F1dGhdLCBtdWx0aTogdHJ1ZX1cbiAgICAgICAgICAgIF1cbiAgICAgICAgfTtcbiAgICB9XG5cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGluaXRpYWxpemVBdXRoKGF1dGg6IEF1dGgpIHtcbiAgICByZXR1cm4gYXV0aC5pbml0aWFsaXplKCk7XG59XG4iXX0=
@@ -10,16 +10,14 @@ import { map, tap } from 'rxjs/operators';
10
10
  import { Router } from '@angular/router';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "@bravobit/bb-foundation/storage";
13
- import * as i2 from "./helpers/mapper.helper";
14
- import * as i3 from "@bravobit/bb-foundation";
15
- import * as i4 from "@angular/common/http";
16
- import * as i5 from "./interfaces/config.interface";
17
- import * as i6 from "@angular/platform-browser";
18
- import * as i7 from "@bravobit/bb-foundation/http";
13
+ import * as i2 from "@angular/cdk/platform";
14
+ import * as i3 from "@angular/common/http";
15
+ import * as i4 from "./interfaces/config.interface";
16
+ import * as i5 from "@angular/platform-browser";
17
+ import * as i6 from "@bravobit/bb-foundation/http";
19
18
  export class Auth {
20
- constructor(_storage, _mapper, _injector, _platform, _httpClient, _config, _state, _httpConfig) {
19
+ constructor(_storage, _injector, _platform, _httpClient, _config, _state, _httpConfig) {
21
20
  this._storage = _storage;
22
- this._mapper = _mapper;
23
21
  this._injector = _injector;
24
22
  this._platform = _platform;
25
23
  this._httpClient = _httpClient;
@@ -77,14 +75,15 @@ export class Auth {
77
75
  async signIn(provider, as) {
78
76
  const { accessToken, refreshToken, user, ...result } = await provider.authenticate(this._httpClient);
79
77
  // Check if the role matches.
80
- if (as && !as.includes(this._mapper.role(user))) {
78
+ const role = this._config?.permissions?.getRole?.(user) ?? user?.role ?? null;
79
+ if (as && !as.includes(role)) {
81
80
  throw new Error('Invalid role.');
82
81
  }
83
82
  // Validate if the provider is one of the available
84
83
  // providers then return the user object and the provider.
85
84
  const apiProvider = result?.provider ?? null;
86
85
  const apiVerifyToken = result?.verifyToken ?? null;
87
- const availableProviders = ['email', 'sms', 'totp'];
86
+ const availableProviders = this._config?.providers ?? ['email', 'sms', 'totp'];
88
87
  if (availableProviders.includes(apiProvider)) {
89
88
  return { user, provider: apiProvider, verifyToken: apiVerifyToken };
90
89
  }
@@ -115,11 +114,10 @@ export class Auth {
115
114
  const url = this.getUrl('auth/register');
116
115
  const result$ = this._httpClient.post(url, data, options);
117
116
  const result = await firstValueFrom(result$);
118
- // Map to the correct response.
119
- const { accessToken, refreshToken, user } = this._mapper.toRegister(result);
120
117
  // Set the tokens in storage.
121
- this.setTokens(accessToken, refreshToken);
118
+ this.setTokens(result?.token, result?.refresh_token);
122
119
  // Set the user in storage.
120
+ const user = result?.user;
123
121
  this.session.setUser(user);
124
122
  // Return the user.
125
123
  return user;
@@ -136,10 +134,11 @@ export class Auth {
136
134
  // invalidate it in the backend.
137
135
  try {
138
136
  const url = this.getUrl('auth/logout');
137
+ const headerName = this._config?.http?.header ?? 'Authorization';
139
138
  const observable$ = this._httpClient.get(url, {
140
- headers: { Authorization: refreshToken }
139
+ headers: { [headerName]: refreshToken }
141
140
  });
142
- firstValueFrom(observable$).then(_ => _);
141
+ firstValueFrom(observable$).then(_ => _).catch(_ => _);
143
142
  }
144
143
  catch {
145
144
  // Do nothing because the tokens will be deleted anyways from the session.
@@ -155,14 +154,14 @@ export class Auth {
155
154
  return of(null);
156
155
  }
157
156
  // Perform the refresh call.
158
- const scheme = this._config?.scheme ?? 'Bearer';
157
+ const headerName = this._config?.http?.header ?? 'Authorization';
158
+ const scheme = this._config?.http?.scheme ?? 'Bearer';
159
159
  const url = this.getUrl('auth/refresh');
160
- const context = new HttpContext()
161
- .set(USE_AUTHORIZATION, false);
160
+ const context = new HttpContext().set(USE_AUTHORIZATION, false);
162
161
  return this._httpClient.get(url, {
163
- headers: { Authorization: `${scheme} ${refreshToken}` },
162
+ headers: { [headerName]: `${scheme} ${refreshToken}` },
164
163
  context: context
165
- }).pipe(map(data => this._mapper.toRefresh(data)), tap(({ accessToken, refreshToken }) => this.setTokens(accessToken, refreshToken)), map(({ accessToken }) => accessToken));
164
+ }).pipe(tap(({ token, refresh_token }) => this.setTokens(token, refresh_token)), map(({ token }) => token));
166
165
  }
167
166
  async requestPassword(email, extraParams = {}) {
168
167
  const url = this.getUrl('auth/reset');
@@ -174,40 +173,15 @@ export class Auth {
174
173
  const observable$ = this._httpClient.post(url, { ...extraParams, token, password: newPassword });
175
174
  return firstValueFrom(observable$);
176
175
  }
177
- guard(type, redirectUrl) {
178
- let newUrl = null;
179
- // Get the correct new url.
180
- switch (type) {
181
- case 'authenticated':
182
- newUrl = this._config?.loggedInUrl ?? null;
183
- break;
184
- case 'unauthenticated':
185
- newUrl = this._config?.redirectUrl ?? null;
186
- break;
187
- }
188
- // Append a redirect url if the user is deemed
189
- // unauthenticated.
190
- if (type === 'unauthenticated') {
191
- const setRedirectOnFailedAuth = this._config?.setRedirectOnFailedAuth ?? true;
192
- if (setRedirectOnFailedAuth && redirectUrl && newUrl) {
193
- newUrl += `?redirectUrl=${redirectUrl}`;
194
- }
195
- }
196
- // Parse the url if it exists.
197
- if (this.router && newUrl) {
198
- return this.router.parseUrl(newUrl);
199
- }
200
- // Return false if the user is not allowed.
201
- return false;
202
- }
203
176
  clearAndRedirect() {
204
177
  // 1. Delete the tokens from the session.
205
178
  this.session.clear();
206
179
  // 2. Compose the route url.
207
- const redirectUrl = this._config?.redirectUrl ?? null;
180
+ const redirectUrl = this._config?.redirects.unauthenticated ?? null;
208
181
  // 3. Route back if the user provided a redirect url.
209
182
  if (this.router && redirectUrl) {
210
- this.router.navigate([redirectUrl]).then(_ => _);
183
+ const commands = Array.isArray(redirectUrl) ? redirectUrl : [redirectUrl];
184
+ this.router.navigate(commands).then(_ => _);
211
185
  }
212
186
  }
213
187
  setTokens(accessToken, refreshToken) {
@@ -267,15 +241,15 @@ export class Auth {
267
241
  .join('/');
268
242
  }
269
243
  }
270
- Auth.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: Auth, deps: [{ token: i1.Storage }, { token: i2.AuthMapper }, { token: i0.Injector }, { token: i3.Platform }, { token: i4.HttpClient }, { token: i5.AuthConfig, optional: true }, { token: i6.TransferState, optional: true }, { token: i7.HttpConfig, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
271
- Auth.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: Auth });
272
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.5", ngImport: i0, type: Auth, decorators: [{
244
+ Auth.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: Auth, deps: [{ token: i1.Storage }, { token: i0.Injector }, { token: i2.Platform }, { token: i3.HttpClient }, { token: i4.AuthConfig, optional: true }, { token: i5.TransferState, optional: true }, { token: i6.HttpConfig, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
245
+ Auth.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: Auth });
246
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: Auth, decorators: [{
273
247
  type: Injectable
274
- }], ctorParameters: function () { return [{ type: i1.Storage }, { type: i2.AuthMapper }, { type: i0.Injector }, { type: i3.Platform }, { type: i4.HttpClient }, { type: i5.AuthConfig, decorators: [{
248
+ }], ctorParameters: function () { return [{ type: i1.Storage }, { type: i0.Injector }, { type: i2.Platform }, { type: i3.HttpClient }, { type: i4.AuthConfig, decorators: [{
275
249
  type: Optional
276
- }] }, { type: i6.TransferState, decorators: [{
250
+ }] }, { type: i5.TransferState, decorators: [{
277
251
  type: Optional
278
- }] }, { type: i7.HttpConfig, decorators: [{
252
+ }] }, { type: i6.HttpConfig, decorators: [{
279
253
  type: Optional
280
254
  }] }]; } });
281
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpClient, HttpContext, HttpHeaders, HttpParams} from '@angular/common/http';\nimport {AuthProvider, AuthSignInResponse} from './interfaces/provider.interface';\nimport {makeStateKey, StateKey, TransferState} from '@angular/platform-browser';\nimport {Storage, StorageOption} from '@bravobit/bb-foundation/storage';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthVerifyProvider} from './providers/verify.provider';\nimport {Injectable, Injector, Optional} from '@angular/core';\nimport {AuthEmailProvider} from './providers/email.provider';\nimport {AuthConfig} from './interfaces/config.interface';\nimport {HttpConfig} from '@bravobit/bb-foundation/http';\nimport {firstValueFrom, Observable, of} from 'rxjs';\nimport {AuthMapper} from './helpers/mapper.helper';\nimport {Platform} from '@bravobit/bb-foundation';\nimport {AuthSession} from './auth.session';\nimport {map, tap} from 'rxjs/operators';\nimport {Router} from '@angular/router';\n\n@Injectable()\nexport class Auth {\n\n    // Readonly data.\n    private readonly _authStateKey: StateKey<any | null> = makeStateKey(`bbAuthStateKey`);\n    private readonly _httpAlias: string | null = this._httpConfig?.defaultAlias ?? null;\n\n    readonly session: AuthSession;\n    readonly user: Observable<any | null>;\n\n    private _refreshHandler: number | null = null;\n\n    constructor(private _storage: Storage,\n                private _mapper: AuthMapper,\n                private _injector: Injector,\n                private _platform: Platform,\n                private _httpClient: HttpClient,\n                @Optional() private _config?: AuthConfig,\n                @Optional() private _state?: TransferState,\n                @Optional() private _httpConfig?: HttpConfig) {\n        // We select a storage strategy based on the server/browser.\n        // Only cookies CAN work on the server.\n        const storageStrategy = this._platform.isBrowser\n            ? this._storage.select([StorageOption.Cookie, StorageOption.Local])\n            : this._storage.cookie;\n\n        // Starting the new session.\n        this.session = new AuthSession({\n            id: this._config?.applicationId,\n            storage: storageStrategy\n        });\n        this.user = this.session.user;\n    }\n\n    initialize() {\n        return async () => {\n            // Check if the app should bootstrap the authentication.\n            const shouldBootstrap = this._config?.bootstrap ?? true;\n            if (!shouldBootstrap) {\n                return this.handleAutoRefreshing();\n            }\n\n            // Only retrieve from the server when we are actually authenticated.\n            if (!this.session.authenticated()) {\n                return;\n            }\n\n            // Get the key from the server state.\n            if (this._state && this._state?.hasKey(this._authStateKey)) {\n                const user = this._state?.get(this._authStateKey, null) ?? null;\n                return this.session.setUser(user);\n            }\n\n            // Try to fetch the user from the server.\n            const user$ = this.me();\n            const user = await firstValueFrom(user$, {defaultValue: null});\n\n            // Set the state if exists.\n            if (this._state) {\n                this._state?.set<any>(this._authStateKey, user ?? null);\n            }\n\n            // Save the user in the storage and handle auto refreshing.\n            this.session.setUser(user);\n            this.handleAutoRefreshing();\n        };\n    }\n\n    me<T = any>() {\n        const url = this.getUrl('auth/me');\n        return this._httpClient.get<T>(url);\n    }\n\n    async signIn(provider: AuthProvider, as?: string[]) {\n        const {accessToken, refreshToken, user, ...result} = await provider.authenticate(this._httpClient);\n\n        // Check if the role matches.\n        if (as && !as.includes(this._mapper.role(user))) {\n            throw new Error('Invalid role.');\n        }\n\n        // Validate if the provider is one of the available\n        // providers then return the user object and the provider.\n        const apiProvider = result?.provider ?? null;\n        const apiVerifyToken = result?.verifyToken ?? null;\n        const availableProviders = ['email', 'sms', 'totp'];\n        if (availableProviders.includes(apiProvider)) {\n            return <AuthSignInResponse>{user, provider: apiProvider, verifyToken: apiVerifyToken};\n        }\n\n        // Set the tokens in storage.\n        this.setTokens(accessToken, refreshToken);\n\n        // Set the user in storage.\n        this.session.setUser(user);\n\n        // Return the user.\n        return <AuthSignInResponse>{user};\n    }\n\n    async signInWithEmail(email: string, password: string, as?: string[]) {\n        const url = this.getUrl('auth/login');\n        return this.signIn(new AuthEmailProvider(email, password, url), as);\n    }\n\n    async signInWithVerifyCode(code: string, verifyToken: string) {\n        const url = this.getUrl('auth/verify');\n        return this.signIn(new AuthVerifyProvider(code, verifyToken, url));\n    }\n\n    async resendVerifyCode(verifyToken: string) {\n        const url = this.getUrl('auth/resend');\n        const result$ = this._httpClient.post(url, {\n            verify_token: verifyToken\n        });\n\n        return firstValueFrom(result$);\n    }\n\n    async register<T = any>(data: any, options?: {\n        headers?: HttpHeaders | {\n            [header: string]: string | string[];\n        };\n        params?: HttpParams | {\n            [param: string]: string | number | boolean | ReadonlyArray<string | number | boolean>;\n        };\n    }) {\n        // Execute API call.\n        const url = this.getUrl('auth/register');\n        const result$ = this._httpClient.post(url, data, options);\n        const result = await firstValueFrom(result$);\n\n        // Map to the correct response.\n        const {accessToken, refreshToken, user} = this._mapper.toRegister(result);\n\n        // Set the tokens in storage.\n        this.setTokens(accessToken, refreshToken);\n\n        // Set the user in storage.\n        this.session.setUser(user);\n\n        // Return the user.\n        return <T>user;\n    }\n\n    logout() {\n        // If we don't have a refresh token just clear the session.\n        // Note: We do this because else we try to invalidate\n        // an \"undefined\" refresh token.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return this.session.clear();\n        }\n\n        // We do have a refresh token, so try to\n        // invalidate it in the backend.\n        try {\n            const url = this.getUrl('auth/logout');\n            const observable$ = this._httpClient.get(url, {\n                headers: {Authorization: refreshToken}\n            });\n            firstValueFrom(observable$).then(_ => _);\n        } catch {\n            // Do nothing because the tokens will be deleted anyways from the session.\n        }\n\n        // Delete the tokens from the session.\n        return this.session.clear();\n    }\n\n    refresh() {\n        // If the refresh token does\n        // not exist just return an observable of null.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return of(null);\n        }\n\n        // Perform the refresh call.\n        const scheme = this._config?.scheme ?? 'Bearer';\n\n        const url = this.getUrl('auth/refresh');\n        const context = new HttpContext()\n            .set(USE_AUTHORIZATION, false);\n\n        return this._httpClient.get(url, {\n            headers: {Authorization: `${scheme} ${refreshToken}`},\n            context: context\n        }).pipe(\n            map(data => this._mapper.toRefresh(data)),\n            tap(({accessToken, refreshToken}) => this.setTokens(accessToken, refreshToken)),\n            map(({accessToken}) => accessToken)\n        );\n    }\n\n    async requestPassword(email: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset');\n        const observable$ = this._httpClient.post(url, {...extraParams, email});\n        return firstValueFrom(observable$);\n    }\n\n    async resetPassword(token: string, newPassword: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset-password');\n        const observable$ = this._httpClient.post(url, {...extraParams, token, password: newPassword});\n        return firstValueFrom(observable$);\n    }\n\n    guard(type: string, redirectUrl?: string) {\n        let newUrl: string = null;\n\n        // Get the correct new url.\n        switch (type) {\n            case 'authenticated':\n                newUrl = this._config?.loggedInUrl ?? null;\n                break;\n            case 'unauthenticated':\n                newUrl = this._config?.redirectUrl ?? null;\n                break;\n        }\n\n        // Append a redirect url if the user is deemed\n        // unauthenticated.\n        if (type === 'unauthenticated') {\n            const setRedirectOnFailedAuth = this._config?.setRedirectOnFailedAuth ?? true;\n            if (setRedirectOnFailedAuth && redirectUrl && newUrl) {\n                newUrl += `?redirectUrl=${redirectUrl}`;\n            }\n        }\n\n        // Parse the url if it exists.\n        if (this.router && newUrl) {\n            return this.router.parseUrl(newUrl);\n        }\n\n        // Return false if the user is not allowed.\n        return false;\n    }\n\n    clearAndRedirect() {\n        // 1. Delete the tokens from the session.\n        this.session.clear();\n\n        // 2. Compose the route url.\n        const redirectUrl = this._config?.redirectUrl ?? null;\n\n        // 3. Route back if the user provided a redirect url.\n        if (this.router && redirectUrl) {\n            this.router.navigate([redirectUrl]).then(_ => _);\n        }\n    }\n\n    private setTokens(accessToken: string, refreshToken: string) {\n        // Set the tokens in our session.\n        this.session.setTokens(accessToken, refreshToken);\n\n        // We need to update the auto refresh of the refresh token.\n        this.handleAutoRefreshing();\n    }\n\n    private handleAutoRefreshing() {\n        const shouldAutoRefresh = this._config?.autoRefresh ?? false;\n        if (!shouldAutoRefresh) {\n            return;\n        }\n\n        const expiresAt = this.session.refreshTokenPayload?.expiresAt ?? null;\n        if (expiresAt === null || !this._platform.isBrowser) {\n            return;\n        }\n\n        const differenceInMilliseconds = expiresAt.getTime() - Date.now();\n        const offsetInMilliseconds = 10_000; // 10 seconds.\n\n        // We want to start the refresh 10 seconds before it expires.\n        const actualTiming = differenceInMilliseconds - offsetInMilliseconds;\n        if (actualTiming <= 0) {\n            return;\n        }\n\n        // We need to cap the timings because if\n        // we get large numbers it might cause unwanted results.\n        const maxTiming = 1000 * 60 * 60 * 24; // 24 hours.\n        const cappedTiming = Math.max(1, Math.min(actualTiming, maxTiming));\n        try {\n            if (this._refreshHandler !== null) {\n                clearTimeout?.(this._refreshHandler);\n                this._refreshHandler = null;\n            }\n            this._refreshHandler = setTimeout?.(() => this.autoRefresh(), cappedTiming);\n        } catch {\n            // Just ignore it.\n        }\n    }\n\n    private async autoRefresh() {\n        try {\n            // We just need to wait for it to refresh.\n            const refresh$ = this.refresh();\n            await firstValueFrom(refresh$);\n        } catch {\n            // Something went wrong refreshing, we need to clear.\n            this.clearAndRedirect();\n        }\n    }\n\n    private get router() {\n        return this._injector.get(Router);\n    }\n\n    private getUrl(endpoint: string) {\n        return [this._httpAlias, endpoint]\n            .filter(item => !!item)\n            .join('/');\n    }\n\n}\n"]}
255
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/bb-foundation/auth/src/lib/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpClient, HttpContext, HttpHeaders, HttpParams} from '@angular/common/http';\nimport {AuthProvider, AuthSignInResponse} from './interfaces/provider.interface';\nimport {makeStateKey, StateKey, TransferState} from '@angular/platform-browser';\nimport {Storage, StorageOption} from '@bravobit/bb-foundation/storage';\nimport {USE_AUTHORIZATION} from './tokens/use-authorization.token';\nimport {AuthVerifyProvider} from './providers/verify.provider';\nimport {Injectable, Injector, Optional} from '@angular/core';\nimport {AuthEmailProvider} from './providers/email.provider';\nimport {AuthConfig} from './interfaces/config.interface';\nimport {HttpConfig} from '@bravobit/bb-foundation/http';\nimport {firstValueFrom, Observable, of} from 'rxjs';\nimport {Platform} from '@angular/cdk/platform';\nimport {AuthSession} from './auth.session';\nimport {map, tap} from 'rxjs/operators';\nimport {Router} from '@angular/router';\n\n@Injectable()\nexport class Auth {\n\n    // Readonly data.\n    private readonly _authStateKey: StateKey<any | null> = makeStateKey(`bbAuthStateKey`);\n    private readonly _httpAlias: string | null = this._httpConfig?.defaultAlias ?? null;\n\n    readonly session: AuthSession;\n    readonly user: Observable<any | null>;\n\n    private _refreshHandler: number | null = null;\n\n    constructor(private _storage: Storage,\n                private _injector: Injector,\n                private _platform: Platform,\n                private _httpClient: HttpClient,\n                @Optional() private _config?: AuthConfig,\n                @Optional() private _state?: TransferState,\n                @Optional() private _httpConfig?: HttpConfig) {\n        // We select a storage strategy based on the server/browser.\n        // Only cookies CAN work on the server.\n        const storageStrategy = this._platform.isBrowser\n            ? this._storage.select([StorageOption.Cookie, StorageOption.Local])\n            : this._storage.cookie;\n\n        // Starting the new session.\n        this.session = new AuthSession({\n            id: this._config?.applicationId,\n            storage: storageStrategy\n        });\n        this.user = this.session.user;\n    }\n\n    initialize() {\n        return async () => {\n            // Check if the app should bootstrap the authentication.\n            const shouldBootstrap = this._config?.bootstrap ?? true;\n            if (!shouldBootstrap) {\n                return this.handleAutoRefreshing();\n            }\n\n            // Only retrieve from the server when we are actually authenticated.\n            if (!this.session.authenticated()) {\n                return;\n            }\n\n            // Get the key from the server state.\n            if (this._state && this._state?.hasKey(this._authStateKey)) {\n                const user = this._state?.get(this._authStateKey, null) ?? null;\n                return this.session.setUser(user);\n            }\n\n            // Try to fetch the user from the server.\n            const user$ = this.me();\n            const user = await firstValueFrom(user$, {defaultValue: null});\n\n            // Set the state if exists.\n            if (this._state) {\n                this._state?.set<any>(this._authStateKey, user ?? null);\n            }\n\n            // Save the user in the storage and handle auto refreshing.\n            this.session.setUser(user);\n            this.handleAutoRefreshing();\n        };\n    }\n\n    me<T = any>() {\n        const url = this.getUrl('auth/me');\n        return this._httpClient.get<T>(url);\n    }\n\n    async signIn(provider: AuthProvider, as?: string[]) {\n        const {accessToken, refreshToken, user, ...result} = await provider.authenticate(this._httpClient);\n\n        // Check if the role matches.\n        const role = this._config?.permissions?.getRole?.(user) ?? user?.role ?? null;\n        if (as && !as.includes(role)) {\n            throw new Error('Invalid role.');\n        }\n\n        // Validate if the provider is one of the available\n        // providers then return the user object and the provider.\n        const apiProvider = result?.provider ?? null;\n        const apiVerifyToken = result?.verifyToken ?? null;\n        const availableProviders = this._config?.providers ?? ['email', 'sms', 'totp'];\n        if (availableProviders.includes(apiProvider)) {\n            return <AuthSignInResponse>{user, provider: apiProvider, verifyToken: apiVerifyToken};\n        }\n\n        // Set the tokens in storage.\n        this.setTokens(accessToken, refreshToken);\n\n        // Set the user in storage.\n        this.session.setUser(user);\n\n        // Return the user.\n        return <AuthSignInResponse>{user};\n    }\n\n    async signInWithEmail(email: string, password: string, as?: string[]) {\n        const url = this.getUrl('auth/login');\n        return this.signIn(new AuthEmailProvider(email, password, url), as);\n    }\n\n    async signInWithVerifyCode(code: string, verifyToken: string) {\n        const url = this.getUrl('auth/verify');\n        return this.signIn(new AuthVerifyProvider(code, verifyToken, url));\n    }\n\n    async resendVerifyCode(verifyToken: string) {\n        const url = this.getUrl('auth/resend');\n        const result$ = this._httpClient.post(url, {\n            verify_token: verifyToken\n        });\n\n        return firstValueFrom(result$);\n    }\n\n    async register<T = any>(data: any, options?: {\n        headers?: HttpHeaders | {\n            [header: string]: string | string[];\n        };\n        params?: HttpParams | {\n            [param: string]: string | number | boolean | ReadonlyArray<string | number | boolean>;\n        };\n    }) {\n        // Execute API call.\n        const url = this.getUrl('auth/register');\n        const result$ = this._httpClient.post<{ token: string, refresh_token: string, user: any }>(url, data, options);\n        const result = await firstValueFrom(result$);\n\n        // Set the tokens in storage.\n        this.setTokens(result?.token, result?.refresh_token);\n\n        // Set the user in storage.\n        const user = result?.user;\n        this.session.setUser(user);\n\n        // Return the user.\n        return <T>user;\n    }\n\n    logout() {\n        // If we don't have a refresh token just clear the session.\n        // Note: We do this because else we try to invalidate\n        // an \"undefined\" refresh token.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return this.session.clear();\n        }\n\n        // We do have a refresh token, so try to\n        // invalidate it in the backend.\n        try {\n            const url = this.getUrl('auth/logout');\n            const headerName = this._config?.http?.header ?? 'Authorization';\n            const observable$ = this._httpClient.get(url, {\n                headers: {[headerName]: refreshToken}\n            });\n            firstValueFrom(observable$).then(_ => _).catch(_ => _);\n        } catch {\n            // Do nothing because the tokens will be deleted anyways from the session.\n        }\n\n        // Delete the tokens from the session.\n        return this.session.clear();\n    }\n\n    refresh() {\n        // If the refresh token does\n        // not exist just return an observable of null.\n        const refreshToken = this.session.refreshToken;\n        if (!refreshToken) {\n            return of(null);\n        }\n\n        // Perform the refresh call.\n        const headerName = this._config?.http?.header ?? 'Authorization';\n        const scheme = this._config?.http?.scheme ?? 'Bearer';\n\n        const url = this.getUrl('auth/refresh');\n        const context = new HttpContext().set(USE_AUTHORIZATION, false);\n\n        return this._httpClient.get<{ token: string, refresh_token: string }>(url, {\n            headers: {[headerName]: `${scheme} ${refreshToken}`},\n            context: context\n        }).pipe(\n            tap(({token, refresh_token}) => this.setTokens(token, refresh_token)),\n            map(({token}) => token)\n        );\n    }\n\n    async requestPassword(email: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset');\n        const observable$ = this._httpClient.post(url, {...extraParams, email});\n        return firstValueFrom(observable$);\n    }\n\n    async resetPassword(token: string, newPassword: string, extraParams: { [key: string]: any } = {}) {\n        const url = this.getUrl('auth/reset-password');\n        const observable$ = this._httpClient.post(url, {...extraParams, token, password: newPassword});\n        return firstValueFrom(observable$);\n    }\n\n    clearAndRedirect() {\n        // 1. Delete the tokens from the session.\n        this.session.clear();\n\n        // 2. Compose the route url.\n        const redirectUrl = this._config?.redirects.unauthenticated ?? null;\n\n        // 3. Route back if the user provided a redirect url.\n        if (this.router && redirectUrl) {\n            const commands = Array.isArray(redirectUrl) ? redirectUrl : [redirectUrl];\n            this.router.navigate(commands).then(_ => _);\n        }\n    }\n\n    private setTokens(accessToken: string, refreshToken: string) {\n        // Set the tokens in our session.\n        this.session.setTokens(accessToken, refreshToken);\n\n        // We need to update the auto refresh of the refresh token.\n        this.handleAutoRefreshing();\n    }\n\n    private handleAutoRefreshing() {\n        const shouldAutoRefresh = this._config?.autoRefresh ?? false;\n        if (!shouldAutoRefresh) {\n            return;\n        }\n\n        const expiresAt = this.session.refreshTokenPayload?.expiresAt ?? null;\n        if (expiresAt === null || !this._platform.isBrowser) {\n            return;\n        }\n\n        const differenceInMilliseconds = expiresAt.getTime() - Date.now();\n        const offsetInMilliseconds = 10_000; // 10 seconds.\n\n        // We want to start the refresh 10 seconds before it expires.\n        const actualTiming = differenceInMilliseconds - offsetInMilliseconds;\n        if (actualTiming <= 0) {\n            return;\n        }\n\n        // We need to cap the timings because if\n        // we get large numbers it might cause unwanted results.\n        const maxTiming = 1000 * 60 * 60 * 24; // 24 hours.\n        const cappedTiming = Math.max(1, Math.min(actualTiming, maxTiming));\n        try {\n            if (this._refreshHandler !== null) {\n                clearTimeout?.(this._refreshHandler);\n                this._refreshHandler = null;\n            }\n            this._refreshHandler = setTimeout?.(() => this.autoRefresh(), cappedTiming);\n        } catch {\n            // Just ignore it.\n        }\n    }\n\n    private async autoRefresh() {\n        try {\n            // We just need to wait for it to refresh.\n            const refresh$ = this.refresh();\n            await firstValueFrom(refresh$);\n        } catch {\n            // Something went wrong refreshing, we need to clear.\n            this.clearAndRedirect();\n        }\n    }\n\n    private get router() {\n        return this._injector.get(Router);\n    }\n\n    private getUrl(endpoint: string) {\n        return [this._httpAlias, endpoint]\n            .filter(item => !!item)\n            .join('/');\n    }\n\n}\n"]}