@authme/identity-verification 2.1.1

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 (84) hide show
  1. package/CHANGELOG.md +943 -0
  2. package/README.md +7 -0
  3. package/assets/locale/en_US.json +132 -0
  4. package/assets/locale/zh_Hant_TW.json +132 -0
  5. package/assets/styles/style.css +806 -0
  6. package/package.json +19 -0
  7. package/src/index.d.ts +4 -0
  8. package/src/index.js +8 -0
  9. package/src/index.js.map +1 -0
  10. package/src/lib/identity-verification-feature-identity-verification.d.ts +26 -0
  11. package/src/lib/identity-verification-feature-identity-verification.js +105 -0
  12. package/src/lib/identity-verification-feature-identity-verification.js.map +1 -0
  13. package/src/lib/interface/config.interface.d.ts +32 -0
  14. package/src/lib/interface/config.interface.js +24 -0
  15. package/src/lib/interface/config.interface.js.map +1 -0
  16. package/src/lib/interface/index.d.ts +1 -0
  17. package/src/lib/interface/index.js +5 -0
  18. package/src/lib/interface/index.js.map +1 -0
  19. package/src/lib/interface/result.model.d.ts +13 -0
  20. package/src/lib/interface/result.model.js +3 -0
  21. package/src/lib/interface/result.model.js.map +1 -0
  22. package/src/lib/lottie/arrow_down.d.ts +215 -0
  23. package/src/lib/lottie/arrow_down.js +203 -0
  24. package/src/lib/lottie/arrow_down.js.map +1 -0
  25. package/src/lib/lottie/arrow_left.d.ts +215 -0
  26. package/src/lib/lottie/arrow_left.js +203 -0
  27. package/src/lib/lottie/arrow_left.js.map +1 -0
  28. package/src/lib/lottie/arrow_right.d.ts +215 -0
  29. package/src/lib/lottie/arrow_right.js +203 -0
  30. package/src/lib/lottie/arrow_right.js.map +1 -0
  31. package/src/lib/lottie/arrow_up.d.ts +215 -0
  32. package/src/lib/lottie/arrow_up.js +203 -0
  33. package/src/lib/lottie/arrow_up.js.map +1 -0
  34. package/src/lib/lottie/card_lr.d.ts +182 -0
  35. package/src/lib/lottie/card_lr.js +1903 -0
  36. package/src/lib/lottie/card_lr.js.map +1 -0
  37. package/src/lib/lottie/card_ud.d.ts +182 -0
  38. package/src/lib/lottie/card_ud.js +1937 -0
  39. package/src/lib/lottie/card_ud.js.map +1 -0
  40. package/src/lib/lottie/index.d.ts +9 -0
  41. package/src/lib/lottie/index.js +13 -0
  42. package/src/lib/lottie/index.js.map +1 -0
  43. package/src/lib/lottie/scan.d.ts +562 -0
  44. package/src/lib/lottie/scan.js +384 -0
  45. package/src/lib/lottie/scan.js.map +1 -0
  46. package/src/lib/lottie/success.d.ts +946 -0
  47. package/src/lib/lottie/success.js +509 -0
  48. package/src/lib/lottie/success.js.map +1 -0
  49. package/src/lib/lottie/tutorial.d.ts +1449 -0
  50. package/src/lib/lottie/tutorial.js +3683 -0
  51. package/src/lib/lottie/tutorial.js.map +1 -0
  52. package/src/lib/module/liveness-verify.module.d.ts +12 -0
  53. package/src/lib/module/liveness-verify.module.js +189 -0
  54. package/src/lib/module/liveness-verify.module.js.map +1 -0
  55. package/src/lib/module/liveness.module.d.ts +12 -0
  56. package/src/lib/module/liveness.module.js +160 -0
  57. package/src/lib/module/liveness.module.js.map +1 -0
  58. package/src/lib/module/mrz.module.d.ts +11 -0
  59. package/src/lib/module/mrz.module.js +142 -0
  60. package/src/lib/module/mrz.module.js.map +1 -0
  61. package/src/lib/module/ocr.module.d.ts +12 -0
  62. package/src/lib/module/ocr.module.js +220 -0
  63. package/src/lib/module/ocr.module.js.map +1 -0
  64. package/src/lib/operator/index.d.ts +16 -0
  65. package/src/lib/operator/index.js +38 -0
  66. package/src/lib/operator/index.js.map +1 -0
  67. package/src/lib/ui/basic.d.ts +13 -0
  68. package/src/lib/ui/basic.js +62 -0
  69. package/src/lib/ui/basic.js.map +1 -0
  70. package/src/lib/ui/index.d.ts +2 -0
  71. package/src/lib/ui/index.js +6 -0
  72. package/src/lib/ui/index.js.map +1 -0
  73. package/src/lib/ui/liveness-flow.d.ts +16 -0
  74. package/src/lib/ui/liveness-flow.js +154 -0
  75. package/src/lib/ui/liveness-flow.js.map +1 -0
  76. package/src/lib/ui/liveness.ui.d.ts +9 -0
  77. package/src/lib/ui/liveness.ui.js +51 -0
  78. package/src/lib/ui/liveness.ui.js.map +1 -0
  79. package/src/lib/ui/ocr-flow.d.ts +73 -0
  80. package/src/lib/ui/ocr-flow.js +664 -0
  81. package/src/lib/ui/ocr-flow.js.map +1 -0
  82. package/src/lib/ui/ocr.ui.d.ts +43 -0
  83. package/src/lib/ui/ocr.ui.js +193 -0
  84. package/src/lib/ui/ocr.ui.js.map +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../libs/identity-verification/feature-identity-verification/src/lib/operator/index.ts"],"names":[],"mappings":";;;AAAA,uCAAsD;AACtD,uCAAyE;AACzE,+BAYc;AAEP,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAE,EAAE;IACtC,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACrB,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACtB,MAAM,QAAQ,GAAG,IAAI,GAAG,GAAG,CAAC;IAC5B,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,OAAO,CAAC,MAAuB,EAAE,EAAE,CACjC,MAAM,CAAC,IAAI,CACT,IAAA,aAAM,EAAC,GAAG,EAAE;QACV,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACjB,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC;QACnB,IAAI,KAAK,GAAG,QAAQ,EAAE;YACpB,IAAI,GAAG,GAAG,GAAG,CAAC,KAAK,GAAG,QAAQ,CAAC,CAAC;SACjC;QACD,OAAO,KAAK,GAAG,QAAQ,CAAC;IAC1B,CAAC,CAAC,CACH,CAAC;AACN,CAAC,CAAC;AAjBW,QAAA,QAAQ,YAiBnB;AAEK,MAAM,SAAS,GAoBpB,CACE,cAA8B,EAC9B,MAAyB,EACzB,KAAuB,EACvB,aAKoB,EACpB,GAAW,EACX,WAAoB,EACpB,SAAgC,EAChC,EAAE,CACJ,CAAC,OAAwB,EAAE,EAAE;IAC3B,IAAI,QAAQ,GAAG,IAAI,CAAC;IACpB,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAA6B,CAAC;IAChE,OAAO,OAAO,CAAC,IAAI,CACjB,IAAA,eAAQ,EAAC,GAAG,EAAE,CACZ,IAAA,sBAAe,GAAE,CAAC,IAAI,CACpB,IAAA,gBAAQ,EAAC,GAAG,CAAC,EACb,IAAA,aAAM,EAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EACtB,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,EAC7B,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,IAAA,kBAAW,EAAC,MAAM,CAAC,CAAC,EAC9B,IAAA,UAAG,EAAC,GAAG,EAAE,CACP,IAAA,mBAAY,EACV,MAAM,EACN,GAAG,EACH,KAAK,EACL,cAAc,EACd,WAAW,EACX,SAAS,CACV,CACF,EACD,IAAA,eAAQ,EAAC,CAAC,SAAS,EAAE,EAAE,CACrB,IAAA,WAAI,EAAC,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CACxD,IAAA,iBAAU,EAAC,CAAC,CAAC,EAAE,EAAE;QACf,uBAAuB;QACvB,IACE,CAAC,YAAY,kBAAW;YACxB,CAAC,CAAC,IAAI,KAAK,gBAAS,CAAC,yBAAyB,EAC9C;YACA,OAAO,YAAK,CAAC;SACd;QACD,MAAM,CAAC,CAAC;IACV,CAAC,CAAC,EACF,IAAA,aAAM,EAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAClB,IAAA,UAAG,EAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;QACf,SAAS;QACT,MAAM;KACP,CAAC,CAAC,EACH,IAAA,UAAG,EAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,CAAC,CAC7B,CACF,CACF,CACF,CACF,CAAC;AACJ,CAAC,CAAC;AA7ES,QAAA,SAAS,aA6ElB"}
@@ -0,0 +1,13 @@
1
+ export interface basicUIConfig {
2
+ haederIcon: string;
3
+ }
4
+ export declare const renderBasicUI: (userConfig?: Partial<basicUIConfig>) => {
5
+ container: HTMLDivElement;
6
+ header: HTMLDivElement;
7
+ headerTitle: HTMLDivElement;
8
+ headerSubtitle: HTMLDivElement;
9
+ headerIcon: HTMLImageElement;
10
+ videoContainer: HTMLDivElement;
11
+ video: HTMLVideoElement;
12
+ closeIcon: HTMLImageElement;
13
+ };
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.renderBasicUI = void 0;
4
+ const util_1 = require("@authme/util");
5
+ const defaultUIConfig = {
6
+ haederIcon: '',
7
+ };
8
+ const renderBasicUI = (userConfig = {}) => {
9
+ const config = Object.assign(Object.assign({}, defaultUIConfig), userConfig);
10
+ // render view
11
+ const body = document.body;
12
+ body.style.margin = '0';
13
+ const container = document.createElement('div');
14
+ container.classList.add('authme-container');
15
+ body === null || body === void 0 ? void 0 : body.appendChild(container);
16
+ // header container
17
+ const header = document.createElement('div');
18
+ header.classList.add('authme-header');
19
+ // header Title
20
+ const headerTitle = document.createElement('div');
21
+ headerTitle.classList.add('authme-header__title');
22
+ // header Subtitle
23
+ const headerSubtitle = document.createElement('div');
24
+ headerSubtitle.classList.add('authme-header__subtitle');
25
+ // header icon
26
+ let headerIcon = document.createElement('img');
27
+ headerIcon = document.createElement('img');
28
+ headerIcon.classList.add('authme-header__icon');
29
+ headerIcon.src =
30
+ '';
31
+ header.appendChild(headerIcon);
32
+ header.appendChild(headerTitle);
33
+ header.appendChild(headerSubtitle);
34
+ container.appendChild(header);
35
+ // Video
36
+ const videoContainer = document.createElement('div');
37
+ videoContainer.classList.add('video-container');
38
+ const closeIcon = document.createElement('img');
39
+ closeIcon.classList.add('video-container__close');
40
+ closeIcon.src = util_1.Icon.CloseIcon;
41
+ const video = document.createElement('video');
42
+ video.autoplay = true;
43
+ video.muted = true;
44
+ video.playsInline = true;
45
+ video.loop = true;
46
+ video.setAttribute('webkit-playsinline', '');
47
+ videoContainer.appendChild(video);
48
+ videoContainer.appendChild(closeIcon);
49
+ container.appendChild(videoContainer);
50
+ return {
51
+ container,
52
+ header,
53
+ headerTitle,
54
+ headerSubtitle,
55
+ headerIcon,
56
+ videoContainer,
57
+ video,
58
+ closeIcon,
59
+ };
60
+ };
61
+ exports.renderBasicUI = renderBasicUI;
62
+ //# sourceMappingURL=basic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"basic.js","sourceRoot":"","sources":["../../../../../../../libs/identity-verification/feature-identity-verification/src/lib/ui/basic.ts"],"names":[],"mappings":";;;AAAA,uCAAoC;AAMpC,MAAM,eAAe,GAAkB;IACrC,UAAU,EAAE,EAAE;CACf,CAAC;AAEK,MAAM,aAAa,GAAG,CAAC,aAAqC,EAAE,EAAE,EAAE;IACvE,MAAM,MAAM,mCAAQ,eAAe,GAAK,UAAU,CAAE,CAAC;IACrD,cAAc;IACd,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;IAC3B,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC;IAExB,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChD,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;IAC5C,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,WAAW,CAAC,SAAS,CAAC,CAAC;IAE7B,mBAAmB;IACnB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC7C,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAEtC,eAAe;IACf,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAClD,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;IAElD,kBAAkB;IAClB,MAAM,cAAc,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACrD,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;IAExD,cAAc;IACd,IAAI,UAAU,GAAqB,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACjE,UAAU,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC3C,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;IAChD,UAAU,CAAC,GAAG;QACZ,wsdAAwsd,CAAC;IAE3sd,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IAC/B,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IAChC,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IACnC,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAE9B,QAAQ;IACR,MAAM,cAAc,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IACrD,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChD,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IAClD,SAAS,CAAC,GAAG,GAAG,WAAI,CAAC,SAAS,CAAC;IAE/B,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC9C,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC;IACtB,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;IACnB,KAAK,CAAC,WAAW,GAAG,IAAI,CAAC;IACzB,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;IAClB,KAAK,CAAC,YAAY,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAC;IAE7C,cAAc,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAClC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IACtC,SAAS,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAEtC,OAAO;QACL,SAAS;QACT,MAAM;QACN,WAAW;QACX,cAAc;QACd,UAAU;QACV,cAAc;QACd,KAAK;QACL,SAAS;KACV,CAAC;AACJ,CAAC,CAAC;AA9DW,QAAA,aAAa,iBA8DxB"}
@@ -0,0 +1,2 @@
1
+ export * from './liveness-flow';
2
+ export * from './ocr-flow';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./liveness-flow"), exports);
5
+ tslib_1.__exportStar(require("./ocr-flow"), exports);
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../libs/identity-verification/feature-identity-verification/src/lib/ui/index.ts"],"names":[],"mappings":";;;AAAA,0DAAgC;AAChC,qDAA2B"}
@@ -0,0 +1,16 @@
1
+ import { FasResult } from '@authme/liveness';
2
+ import { Observable } from 'rxjs';
3
+ import { LivenessConfig, LivenessEngineConfig } from '@authme/identity-verification';
4
+ export declare function startLiveness(config: {
5
+ livenessConfig: LivenessConfig;
6
+ init: () => Promise<LivenessEngineConfig>;
7
+ onStart: (width: number, height: number) => Promise<any>;
8
+ onFrame: (data: Uint8ClampedArray, base64: {
9
+ jpg: string;
10
+ png: string;
11
+ }) => Promise<FasResult>;
12
+ setFrameSize: (width: number, height: number) => void;
13
+ getSelectedImage: () => Uint8Array | Uint8ClampedArray | null;
14
+ onSuccess: () => Promise<any>;
15
+ onDestroy: () => Promise<void>;
16
+ }): Observable<boolean>;
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.startLiveness = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const liveness_1 = require("@authme/liveness");
6
+ const rxjs_1 = require("rxjs");
7
+ const util_1 = require("@authme/util");
8
+ const basic_1 = require("./basic");
9
+ const liveness_ui_1 = require("./liveness.ui");
10
+ const operator_1 = require("../operator");
11
+ const core_1 = require("@authme/core");
12
+ function startLiveness(config) {
13
+ const translateService = (0, core_1.getTranslateInstance)();
14
+ const unsubscribe$ = new rxjs_1.Subject();
15
+ let livenessConfig = null;
16
+ let isValidScreenSize = true;
17
+ // render view
18
+ const { container, videoContainer, video, closeIcon, headerTitle } = (0, basic_1.renderBasicUI)({
19
+ haederIcon: config.livenessConfig.icon,
20
+ });
21
+ const { statusText, faceMask } = (0, liveness_ui_1.renderLivenessUI)({
22
+ container,
23
+ videoContainer,
24
+ video,
25
+ });
26
+ const canvas = document.createElement('canvas');
27
+ const requestCamera$ = (0, rxjs_1.from)((0, util_1.requestCamera)(video, (0, util_1.videoConstraintsFactory)(!(0, util_1.isMobileOrTablet)(), 'user'), 'front')).pipe((0, rxjs_1.tap)(() => (0, util_1.showElement)(videoContainer)), (0, rxjs_1.catchError)((error) => {
28
+ if (error instanceof OverconstrainedError) {
29
+ alert(translateService.translate('camera.error.notFound'));
30
+ }
31
+ else {
32
+ alert(translateService.translate('camera.error.notFound'));
33
+ }
34
+ return (0, rxjs_1.throwError)(() => new core_1.AuthmeError(core_1.ErrorCode.CAMERA_NOT_SUPPORT));
35
+ }));
36
+ const init$ = (0, rxjs_1.from)(config.init()).pipe((0, rxjs_1.tap)((config) => (livenessConfig = config)));
37
+ const applyTextByResult = (result) => {
38
+ switch (result.eStatus) {
39
+ case liveness_1.FasRecognitionResult.NoFace:
40
+ statusText.textContent = translateService.translate('liveness.error.noFace');
41
+ setBorderStatus('error');
42
+ break;
43
+ case liveness_1.FasRecognitionResult.FaceNotAtCenter:
44
+ statusText.textContent = translateService.translate('liveness.error.faceNotAtCenter');
45
+ setBorderStatus('error');
46
+ break;
47
+ case liveness_1.FasRecognitionResult.FaceTooSmall:
48
+ statusText.textContent = translateService.translate('liveness.error.faceTooSmall');
49
+ setBorderStatus('error');
50
+ break;
51
+ case liveness_1.FasRecognitionResult.FaceTooLarge:
52
+ statusText.textContent = translateService.translate('liveness.error.faceTooLarge');
53
+ setBorderStatus('error');
54
+ break;
55
+ case liveness_1.FasRecognitionResult.NeedFaceToCamera:
56
+ statusText.textContent = translateService.translate('liveness.error.needFaceToCamera');
57
+ setBorderStatus('error');
58
+ break;
59
+ case liveness_1.FasRecognitionResult.FaceMasked:
60
+ statusText.textContent = translateService.translate('liveness.error.faceMasked');
61
+ setBorderStatus('error');
62
+ break;
63
+ case liveness_1.FasRecognitionResult.NeedOpenMouth:
64
+ statusText.textContent = translateService.translate('liveness.error.needOpenMouth');
65
+ setBorderStatus(null);
66
+ break;
67
+ case liveness_1.FasRecognitionResult.NeedCloseMouth:
68
+ statusText.textContent = translateService.translate('liveness.error.needCloseMouth');
69
+ setBorderStatus(null);
70
+ break;
71
+ case liveness_1.FasRecognitionResult.NeedSmile:
72
+ statusText.textContent = translateService.translate('liveness.error.needSmile');
73
+ setBorderStatus(null);
74
+ break;
75
+ case liveness_1.FasRecognitionResult.NeedOpenEyes:
76
+ statusText.textContent = translateService.translate('liveness.error.needOpenEyes');
77
+ setBorderStatus('error');
78
+ break;
79
+ case liveness_1.FasRecognitionResult.NeedMoreFrame:
80
+ statusText.textContent = translateService.translate('liveness.needMoreFrame');
81
+ setBorderStatus('pass');
82
+ break;
83
+ case liveness_1.FasRecognitionResult.Error:
84
+ statusText.textContent = translateService.translate('verify.error.serverError');
85
+ (0, util_1.showErrorMessage)(translateService.translate('verify.error.serverError'), true);
86
+ break;
87
+ default:
88
+ break;
89
+ }
90
+ };
91
+ // Register Event
92
+ (0, rxjs_1.fromEvent)(window, 'offline')
93
+ .pipe((0, rxjs_1.switchMap)(() => (0, util_1.asyncOnLineShowErrorMessage)(translateService.translate('network.error.offline'), true)), (0, rxjs_1.takeUntil)(unsubscribe$))
94
+ .subscribe();
95
+ (0, rxjs_1.fromEvent)(window, 'resize')
96
+ .pipe((0, rxjs_1.throttleTime)(100), (0, rxjs_1.switchMap)(() => (0, util_1.getCanvasSize)(video)), (0, rxjs_1.tap)((canvasSizeInfo) => {
97
+ config.setFrameSize(canvasSizeInfo.canvasWidth, canvasSizeInfo.canvasHeight);
98
+ const maskHeight = window.outerHeight * 0.48;
99
+ const maskWidth = Math.round(maskHeight * 0.72).toString();
100
+ faceMask.style.width = `${maskWidth}px`;
101
+ }), (0, rxjs_1.takeUntil)(unsubscribe$))
102
+ .subscribe();
103
+ (0, rxjs_1.fromEvent)(closeIcon, 'click')
104
+ .pipe((0, rxjs_1.switchMap)(() => reset()), (0, rxjs_1.takeUntil)(unsubscribe$))
105
+ .subscribe();
106
+ (0, rxjs_1.merge)((0, rxjs_1.fromEvent)(window, 'resize'), (0, rxjs_1.of)(0))
107
+ .pipe((0, rxjs_1.map)(() => window.innerWidth >= 330 && window.innerHeight >= 500), (0, rxjs_1.filter)((x) => x !== isValidScreenSize), (0, rxjs_1.tap)((x) => (isValidScreenSize = x)), (0, rxjs_1.tap)((x) => x
108
+ ? (0, util_1.hidePopup)()
109
+ : (0, util_1.showPopup)(translateService.translate('error.screenSize.title'), translateService.translate('error.screenSize.content'), false)), (0, rxjs_1.takeUntil)(unsubscribe$))
110
+ .subscribe();
111
+ // Start
112
+ (0, util_1.startSpinner)(translateService.translate('general.loading'));
113
+ headerTitle.textContent = translateService.translate('liveness.header.liveness');
114
+ return (0, rxjs_1.combineLatest)([requestCamera$, init$]).pipe((0, rxjs_1.tap)(() => (0, util_1.stopSpinner)()), (0, rxjs_1.switchMap)(() => (0, rxjs_1.from)((0, util_1.waitTime)(1)).pipe((0, rxjs_1.tap)(() => (videoContainer.style.zIndex = '101')))), (0, rxjs_1.switchMap)(() => (0, rxjs_1.from)((0, util_1.getCanvasSize)(video))), (0, rxjs_1.switchMap)((canvasSizeInfo) => (0, rxjs_1.from)(config.onStart(canvasSizeInfo.canvasWidth, canvasSizeInfo.canvasHeight)).pipe((0, operator_1.sendFrame)(canvasSizeInfo, canvas, video, config.onFrame, livenessConfig.fasMaxFps, true, 'all'), (0, rxjs_1.tap)(({ result }) => applyTextByResult(result)), (0, rxjs_1.filter)(({ result }) => (result.eStatus === liveness_1.FasRecognitionResult.Pass &&
115
+ result.eStage === liveness_1.EAuthMeFASServiceStage.Done) ||
116
+ result.eStatus === liveness_1.FasRecognitionResult.Failed), (0, rxjs_1.map)((data) => {
117
+ var _a, _b;
118
+ return (Object.assign(Object.assign({}, data), { isSuccess: ((_a = data === null || data === void 0 ? void 0 : data.result) === null || _a === void 0 ? void 0 : _a.eStatus) === liveness_1.FasRecognitionResult.Pass &&
119
+ ((_b = data === null || data === void 0 ? void 0 : data.result) === null || _b === void 0 ? void 0 : _b.eStage) === liveness_1.EAuthMeFASServiceStage.Done }));
120
+ }), (0, rxjs_1.take)(1), (0, rxjs_1.switchMap)((resp) => resp.isSuccess
121
+ ? (0, rxjs_1.of)(resp)
122
+ : (0, rxjs_1.of)(resp).pipe((0, rxjs_1.tap)(() => (0, util_1.showErrorMessage)(translateService.translate('verify.error.timeout'))), (0, rxjs_1.switchMap)(() => (0, util_1.waitTime)(2000)), (0, rxjs_1.tap)(() => (0, util_1.hideErrorMessage)()), (0, rxjs_1.map)(() => resp))), (0, rxjs_1.switchMap)((resp) => window.navigator.onLine
123
+ ? (0, rxjs_1.of)(resp)
124
+ : (0, rxjs_1.from)((0, util_1.asyncOnLineShowErrorMessage)(translateService.translate('network.error.offline'), true)).pipe((0, rxjs_1.map)(() => resp))), (0, rxjs_1.tap)(() => (0, util_1.startSpinner)(translateService.translate('liveness.uploading'))), (0, rxjs_1.switchMap)(() => config.onSuccess()))), (0, rxjs_1.takeUntil)(unsubscribe$), (0, rxjs_1.finalize)(() => {
125
+ (0, util_1.stopSpinner)();
126
+ reset();
127
+ }));
128
+ function setBorderStatus(status) {
129
+ faceMask.classList.remove('pass');
130
+ faceMask.classList.remove('error');
131
+ if (status) {
132
+ faceMask.classList.add(status);
133
+ }
134
+ }
135
+ function reset() {
136
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
137
+ try {
138
+ video.srcObject
139
+ .getTracks()
140
+ .forEach((stream) => stream.stop());
141
+ }
142
+ catch (error) {
143
+ // no video, ignore
144
+ }
145
+ yield config.onDestroy();
146
+ video.srcObject = null;
147
+ document.body.removeChild(container);
148
+ unsubscribe$.next();
149
+ unsubscribe$.complete();
150
+ });
151
+ }
152
+ }
153
+ exports.startLiveness = startLiveness;
154
+ //# sourceMappingURL=liveness-flow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"liveness-flow.js","sourceRoot":"","sources":["../../../../../../../libs/identity-verification/feature-identity-verification/src/lib/ui/liveness-flow.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export declare const renderLivenessUI: (config: {
2
+ container: HTMLElement;
3
+ videoContainer: HTMLElement;
4
+ video: HTMLVideoElement;
5
+ }) => {
6
+ titleText: HTMLDivElement;
7
+ statusText: HTMLDivElement;
8
+ faceMask: HTMLDivElement;
9
+ };
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.renderLivenessUI = void 0;
4
+ const core_1 = require("@authme/core");
5
+ const renderLivenessUI = (config) => {
6
+ const translateService = (0, core_1.getTranslateInstance)();
7
+ const createTextPanel = () => {
8
+ const ele = document.createElement('div');
9
+ ele.classList.add('text-panel');
10
+ return ele;
11
+ };
12
+ const createTextTitle = () => {
13
+ const ele = document.createElement('div');
14
+ ele.classList.add('text-title');
15
+ return ele;
16
+ };
17
+ const createTextHint = () => {
18
+ const ele = document.createElement('div');
19
+ ele.classList.add('text-hint');
20
+ return ele;
21
+ };
22
+ config.container.classList.add('liveness-container');
23
+ const faceMask = document.createElement('div');
24
+ faceMask.classList.add('face-mask');
25
+ config.videoContainer.appendChild(faceMask);
26
+ //TODO: setup mask width/height
27
+ const maskHeight = window.outerHeight * 0.48;
28
+ const maskWidth = Math.round(maskHeight * 0.72).toString();
29
+ faceMask.style.width = `${maskWidth}px`;
30
+ // text panel
31
+ const titleTextPanel = createTextPanel();
32
+ titleTextPanel.classList.add('title');
33
+ const titleText = createTextTitle();
34
+ const statusTextPanel = createTextPanel();
35
+ statusTextPanel.classList.add('status');
36
+ const statusText = createTextHint();
37
+ titleTextPanel.appendChild(titleText);
38
+ statusTextPanel.appendChild(statusText);
39
+ config.videoContainer.appendChild(titleTextPanel);
40
+ config.videoContainer.appendChild(statusTextPanel);
41
+ // Set init text
42
+ titleText.textContent = translateService.translate('liveness.title');
43
+ statusText.textContent = translateService.translate('liveness.error.noFace');
44
+ return {
45
+ titleText,
46
+ statusText,
47
+ faceMask,
48
+ };
49
+ };
50
+ exports.renderLivenessUI = renderLivenessUI;
51
+ //# sourceMappingURL=liveness.ui.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"liveness.ui.js","sourceRoot":"","sources":["../../../../../../../libs/identity-verification/feature-identity-verification/src/lib/ui/liveness.ui.ts"],"names":[],"mappings":";;;AAAA,uCAAoD;AAE7C,MAAM,gBAAgB,GAAG,CAAC,MAIhC,EAAE,EAAE;IACH,MAAM,gBAAgB,GAAG,IAAA,2BAAoB,GAAE,CAAC;IAChD,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAChC,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;IAEF,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAChC,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAC/B,OAAO,GAAG,CAAC;IACb,CAAC,CAAC;IAEF,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC;IAErD,MAAM,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC/C,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IACpC,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IAE5C,+BAA+B;IAC/B,MAAM,UAAU,GAAG,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC;IAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC3D,QAAQ,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,SAAS,IAAI,CAAC;IAExC,aAAa;IACb,MAAM,cAAc,GAAG,eAAe,EAAE,CAAC;IACzC,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IACtC,MAAM,SAAS,GAAG,eAAe,EAAE,CAAC;IACpC,MAAM,eAAe,GAAG,eAAe,EAAE,CAAC;IAC1C,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACxC,MAAM,UAAU,GAAG,cAAc,EAAE,CAAC;IACpC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IACtC,eAAe,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IACxC,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;IAClD,MAAM,CAAC,cAAc,CAAC,WAAW,CAAC,eAAe,CAAC,CAAC;IAEnD,gBAAgB;IAChB,SAAS,CAAC,WAAW,GAAG,gBAAgB,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACrE,UAAU,CAAC,WAAW,GAAG,gBAAgB,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;IAE7E,OAAO;QACL,SAAS;QACT,UAAU;QACV,QAAQ;KACT,CAAC;AACJ,CAAC,CAAC;AAxDW,QAAA,gBAAgB,oBAwD3B"}
@@ -0,0 +1,73 @@
1
+ import { EAuthMeCardClass, CardOCRResult, IDCardAntiFraudResult, MRZResult } from '@authme/id-recognition';
2
+ import { Observable } from 'rxjs';
3
+ import { IdRecognitionConfig, OcrEngineConfig } from '../interface';
4
+ import { AuthmeOCRResult } from '../interface/result.model';
5
+ export declare function startOCR(config: {
6
+ init: (width: number, height: number) => Promise<OcrEngineConfig>;
7
+ ocrConfig: IdRecognitionConfig;
8
+ ocrStart: (points: [
9
+ [
10
+ number,
11
+ number
12
+ ],
13
+ [
14
+ number,
15
+ number
16
+ ],
17
+ [
18
+ number,
19
+ number
20
+ ],
21
+ [
22
+ number,
23
+ number
24
+ ]
25
+ ], type: EAuthMeCardClass, retry?: boolean) => Promise<boolean>;
26
+ acceptTypes: EAuthMeCardClass[];
27
+ recognition: (img: Uint8ClampedArray) => Promise<CardOCRResult | MRZResult>;
28
+ confirmImage: (type: EAuthMeCardClass) => Promise<boolean>;
29
+ antiFraudStart: (points: [
30
+ [
31
+ number,
32
+ number
33
+ ],
34
+ [
35
+ number,
36
+ number
37
+ ],
38
+ [
39
+ number,
40
+ number
41
+ ],
42
+ [
43
+ number,
44
+ number
45
+ ]
46
+ ]) => Promise<boolean>;
47
+ onAntiFraudFrame: (data: Uint8ClampedArray) => Promise<IDCardAntiFraudResult>;
48
+ setFrameSize: (width: number, height: number, points?: [
49
+ [
50
+ number,
51
+ number
52
+ ],
53
+ [
54
+ number,
55
+ number
56
+ ],
57
+ [
58
+ number,
59
+ number
60
+ ],
61
+ [
62
+ number,
63
+ number
64
+ ]
65
+ ]) => Promise<void>;
66
+ onSuccess: () => Promise<{
67
+ scanId: string;
68
+ details: {
69
+ [key: string]: string;
70
+ };
71
+ }>;
72
+ onDestroy: () => Promise<void>;
73
+ }): Observable<AuthmeOCRResult>;