@authme/id-recognition 2.4.11 → 2.7.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.
package/index.cjs CHANGED
@@ -2,11 +2,13 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ require('core-js/modules/es.object.assign.js');
5
6
  var engine = require('@authme/engine');
6
7
  require('core-js/modules/es.array.iterator.js');
7
8
  require('core-js/modules/es.object.from-entries.js');
8
9
  require('core-js/modules/web.dom-collections.iterator.js');
9
10
  var core = require('@authme/core');
11
+ var util = require('@authme/util');
10
12
  require('core-js/modules/es.symbol.description.js');
11
13
 
12
14
  exports.ResourceImageType = void 0;
@@ -14,11 +16,36 @@ exports.ResourceImageType = void 0;
14
16
  ResourceImageType["Recognition"] = "Recognition";
15
17
  ResourceImageType["Fraud"] = "Fraud";
16
18
  ResourceImageType["Manual"] = "Manual";
19
+ ResourceImageType["Attach"] = "AttachImage";
17
20
  })(exports.ResourceImageType || (exports.ResourceImageType = {}));
18
21
  exports.CountryCode = void 0;
19
22
  (function (CountryCode) {
20
23
  CountryCode["TWN"] = "TWN";
21
- CountryCode["JPW"] = "JP";
24
+ CountryCode["JPN"] = "JPN";
25
+ CountryCode["ZAF"] = "ZAF";
26
+ CountryCode["USA"] = "USA";
27
+ CountryCode["CHN"] = "CHN";
28
+ CountryCode["PHL"] = "PHL";
29
+ CountryCode["GBR"] = "GBR";
30
+ CountryCode["KOR"] = "KOR";
31
+ CountryCode["HKG"] = "HKG";
32
+ CountryCode["FRA"] = "FRA";
33
+ CountryCode["ESP"] = "ESP";
34
+ CountryCode["MEX"] = "MEX";
35
+ CountryCode["ITA"] = "ITA";
36
+ CountryCode["IND"] = "IND";
37
+ CountryCode["COL"] = "COL";
38
+ CountryCode["RUS"] = "RUS";
39
+ CountryCode["DEU"] = "DEU";
40
+ CountryCode["TUR"] = "TUR";
41
+ CountryCode["CAN"] = "CAN";
42
+ CountryCode["AUS"] = "AUS";
43
+ CountryCode["IDN"] = "IDN";
44
+ CountryCode["MYS"] = "MYS";
45
+ CountryCode["EGY"] = "EGY";
46
+ CountryCode["SAU"] = "SAU";
47
+ CountryCode["NLD"] = "NLD";
48
+ CountryCode["SGP"] = "SGP";
22
49
  })(exports.CountryCode || (exports.CountryCode = {}));
23
50
  exports.IdRecognitionCardType = void 0;
24
51
  (function (IdRecognitionCardType) {
@@ -28,6 +55,14 @@ exports.IdRecognitionCardType = void 0;
28
55
  IdRecognitionCardType["ResidentCard"] = "ResidentCard";
29
56
  IdRecognitionCardType["Passport"] = "Passport";
30
57
  })(exports.IdRecognitionCardType || (exports.IdRecognitionCardType = {}));
58
+ exports.IdRecognitionCardName = void 0;
59
+ (function (IdRecognitionCardName) {
60
+ IdRecognitionCardName["IDCard"] = "sdk.home.selectDocument.idCard";
61
+ IdRecognitionCardName["DriverLicense"] = "sdk.home.selectDocument.driverLicense";
62
+ IdRecognitionCardName["HealthCard"] = "sdk.home.selectDocument.healthCard";
63
+ IdRecognitionCardName["ResidentCard"] = "sdk.home.selectDocument.residentCard";
64
+ IdRecognitionCardName["Passport"] = "sdk.home.selectDocument.passport";
65
+ })(exports.IdRecognitionCardName || (exports.IdRecognitionCardName = {}));
31
66
  exports.ServerSideEAuthMeCardClass = void 0;
32
67
  (function (ServerSideEAuthMeCardClass) {
33
68
  ServerSideEAuthMeCardClass["Invalid"] = "Invalid";
@@ -54,16 +89,22 @@ class CardOCR extends engine.AuthmeEngineModuleBase {
54
89
  this.type = engine.EAuthMeCardClass.Invalid;
55
90
  this.moduleName = engine.EngineModule.CardOCR;
56
91
  }
57
- setType(type, options) {
92
+ setType(type) {
58
93
  this.type = type;
59
94
  return this.engine.run(this.moduleName, 'setType', {
60
- type,
61
- options
95
+ type
62
96
  });
63
97
  }
64
98
  getType() {
65
99
  return this.type;
66
100
  }
101
+ setParams(params) {
102
+ var _a;
103
+ if (((_a = params.type) !== null && _a !== void 0 ? _a : this.type) === engine.EAuthMeCardClass.Invalid) throw new Error('Please set type first');
104
+ return this.engine.run(this.moduleName, 'setParams', Object.assign({
105
+ type: this.type
106
+ }, params));
107
+ }
67
108
  }
68
109
  class IdCardAntiFraudService extends engine.AuthmeEngineModuleBase {
69
110
  constructor(engine$1) {
@@ -122,6 +163,41 @@ const IdTypeConfig = {
122
163
  }
123
164
  };
124
165
 
166
+ const thicknessDefaultConfig = {
167
+ mode: 'manual',
168
+ thicknessWelcomeSetting: {
169
+ welcome: true,
170
+ title: {
171
+ enable: true,
172
+ // text: translateService.translate(
173
+ // 'verify.ocr.welcome.title'
174
+ // ),
175
+ // text: '即將進行厚度檢測',
176
+ text: 'sdk.thickness.detection.guide.subtitle'
177
+ },
178
+ subtitle: {
179
+ enable: true,
180
+ // text: translateService.translate(
181
+ // 'verify.ocr.welcome.subtitle'
182
+ // ),
183
+ // text: '請將卡面傾斜45度角放入畫面框線進行拍攝',
184
+ text: 'sdk.thickness.detection.guide.subtitle.content'
185
+ },
186
+ imageShow: {
187
+ enable: true,
188
+ src: ''
189
+ },
190
+ content: {
191
+ enable: true,
192
+ // text: translateService.translate(
193
+ // 'verify.ocr.welcome.content'
194
+ // ),
195
+ // text: '請在光線充足的環境進行拍攝\n請確保卡面資訊上沒有任何遮蔽物\n避免在白色背景進行拍攝,以確保卡片輪廓清晰',
196
+ text: 'sdk.thickness.detection.guide.content'
197
+ }
198
+ }
199
+ };
200
+
125
201
  const CardTypeMapping = {
126
202
  [exports.IdRecognitionCardType.IDCard]: [engine.EAuthMeCardClass.TWN_IDCard_Front, engine.EAuthMeCardClass.TWN_IDCard_Back],
127
203
  [exports.IdRecognitionCardType.HealthCard]: [engine.EAuthMeCardClass.TWN_HealthCard_Front],
@@ -129,10 +205,112 @@ const CardTypeMapping = {
129
205
  [exports.IdRecognitionCardType.ResidentCard]: [engine.EAuthMeCardClass.TWN_ResidentCard_Front, engine.EAuthMeCardClass.TWN_ResidentCard_Back],
130
206
  [exports.IdRecognitionCardType.DriverLicense]: [engine.EAuthMeCardClass.TWN_DriverLicense_Front, engine.EAuthMeCardClass.TWN_DriverLicense_Back]
131
207
  };
208
+ const CardTypeMap = {
209
+ [exports.IdRecognitionCardType.IDCard]: [exports.ServerSideEAuthMeCardClass.TWN_IDCard_Front, exports.ServerSideEAuthMeCardClass.TWN_IDCard_Back],
210
+ [exports.IdRecognitionCardType.HealthCard]: [exports.ServerSideEAuthMeCardClass.TWN_HealthCard_Front],
211
+ [exports.IdRecognitionCardType.Passport]: ['ALL_PASSPORT_CONTENT'],
212
+ [exports.IdRecognitionCardType.ResidentCard]: [exports.ServerSideEAuthMeCardClass.TWN_ResidentCard_Front, exports.ServerSideEAuthMeCardClass.TWN_ResidentCard_Back],
213
+ [exports.IdRecognitionCardType.DriverLicense]: [exports.ServerSideEAuthMeCardClass.TWN_DriverLicense_Front, exports.ServerSideEAuthMeCardClass.TWN_DriverLicense_Back]
214
+ };
132
215
  const RECOGNITION_COLUMNS_ORDER = Object.fromEntries(['surname', 'givenName', 'name', 'gender', 'dateOfBirth', 'idNumber', 'dateOfIssue', 'issueCity', 'issueReason', 'father', 'mother', 'spouse', 'militaryService', 'placeOfBirth', 'serialNumber', 'expiry', 'controlNo', 'type', 'condition', 'address', 'country', 'documentNumber', 'documentType', 'nationality', 'expiryDate'].map((value, index) => [value, index]));
133
216
  function getCardSubTypes(type, country) {
134
217
  return CardTypeMapping[type];
135
218
  }
219
+ function getCardTypes(type, country) {
220
+ return CardTypeMap[type];
221
+ }
222
+ function cardTypeTitle(cardType) {
223
+ var _a, _b;
224
+ if (cardType == null) {
225
+ return '';
226
+ }
227
+ const cardTypeLower = cardType.toLowerCase();
228
+ const cardTypeMap = {
229
+ idcard: {
230
+ front: 'sdk.ocr.verify.idCardFrontSide',
231
+ back: 'sdk.ocr.verify.idCardBackSide',
232
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
233
+ default: 'sdk.ocr.verify.idCardFrontSide'
234
+ },
235
+ driverlicense: {
236
+ front: 'sdk.ocr.verify.driverFrontSide',
237
+ back: 'sdk.ocr.verify.driverBackSide',
238
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
239
+ default: 'sdk.ocr.verify.driverFrontSide'
240
+ },
241
+ resident: {
242
+ front: 'sdk.ocr.verify.residentCardFrontSide',
243
+ back: 'sdk.ocr.verify.residentCardBackSide',
244
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
245
+ default: 'sdk.ocr.verify.residentCardFrontSide'
246
+ },
247
+ residentcard: {
248
+ front: 'sdk.ocr.verify.residentCardFrontSide',
249
+ back: 'sdk.ocr.verify.residentCardBackSide',
250
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
251
+ default: 'sdk.ocr.verify.residentCardFrontSide'
252
+ }
253
+ };
254
+ const typeSections = cardTypeLower.split('_');
255
+ const cardTypeName = typeSections[1];
256
+ const cardTypeSection = typeSections[2];
257
+ const titleKey = ((_a = cardTypeMap[cardTypeName]) === null || _a === void 0 ? void 0 : _a[cardTypeSection]) || ((_b = cardTypeMap[cardTypeName]) === null || _b === void 0 ? void 0 : _b.default);
258
+ return titleKey || '';
259
+ }
260
+ function cardTypeConfirmTitle(cardType) {
261
+ if (cardType == null) {
262
+ return '';
263
+ }
264
+ const cardTypeLower = cardType.toLowerCase();
265
+ let titleKey = null;
266
+ if (cardTypeLower.indexOf('idcard') != -1) {
267
+ if (cardTypeLower.indexOf('front') !== -1) {
268
+ titleKey = 'sdk.ocr.verify.confirmIdCardFront';
269
+ } else if (cardTypeLower.indexOf('back') !== -1) {
270
+ titleKey = 'sdk.ocr.verify.confirmIdCardBack';
271
+ } else {
272
+ titleKey = 'sdk.ocr.verify.confirmIdCardFront';
273
+ }
274
+ return titleKey;
275
+ }
276
+ if (cardTypeLower.indexOf('driverlicense') != -1) {
277
+ if (cardTypeLower.indexOf('front') !== -1) {
278
+ titleKey = 'sdk.ocr.verify.confirmDriverFront';
279
+ } else if (cardTypeLower.indexOf('back') !== -1) {
280
+ titleKey = 'sdk.ocr.verify.confirmDriverBack';
281
+ } else {
282
+ titleKey = 'sdk.ocr.verify.confirmDriverFront';
283
+ }
284
+ return titleKey;
285
+ }
286
+ if (cardTypeLower.indexOf('resident') != -1) {
287
+ if (cardTypeLower.indexOf('front') !== -1) {
288
+ titleKey = 'sdk.ocr.verify.confirmResidentCardFront';
289
+ } else if (cardTypeLower.indexOf('back') !== -1) {
290
+ titleKey = 'sdk.ocr.verify.confirmResidentCardBack';
291
+ } else {
292
+ titleKey = 'sdk.ocr.verify.confirmResidentCardFront';
293
+ }
294
+ return titleKey;
295
+ }
296
+ return titleKey;
297
+ }
298
+ function mapCardtypeToAuthmeClass(type) {
299
+ // const known_type = Object.keys(EAuthMeCardClass).filter(
300
+ // (key) =>
301
+ // (EAuthMeCardClass as any)[key].toString().toLowerCase() ==
302
+ // ('EAuthMeCardClass_' + type).toLowerCase()
303
+ // )[0];
304
+ // if (known_type == null) {
305
+ // return EAuthMeCardClass.Unknown;
306
+ // }
307
+ // return (EAuthMeCardClass as any)[known_type];
308
+ if (type in engine.EAuthMeCardClass) {
309
+ return engine.EAuthMeCardClass[type];
310
+ } else {
311
+ return engine.EAuthMeCardClass.Unknown;
312
+ }
313
+ }
136
314
  function getRecognitionColumnOrder(column) {
137
315
  var _a;
138
316
  return (_a = RECOGNITION_COLUMNS_ORDER[column]) !== null && _a !== void 0 ? _a : Number.MAX_VALUE;
@@ -150,12 +328,33 @@ const twoWayAuthmeCardClassMap = (() => {
150
328
  };
151
329
  })();
152
330
 
153
- function init(type, country, needConfirm, encrypt = true) {
331
+ var name = "authme/sdk";
332
+ var version$1 = "2.7.1";
333
+ var date = "2024-09-06T02:00:28+0000";
334
+ var packageInfo = {
335
+ name: name,
336
+ version: version$1,
337
+ date: date
338
+ };
339
+
340
+ function init(type, country, needConfirm, cardTypes, encrypt = true) {
341
+ // let useCardTypes: any = getCardSubTypes(type, country).map((c) =>
342
+ // twoWayAuthmeCardClassMap.toServer(c)
343
+ // );
344
+ let useCardTypes = getCardTypes(type);
345
+ if (cardTypes.length) {
346
+ useCardTypes = cardTypes;
347
+ }
154
348
  const body = {
155
- scanType: type === exports.IdRecognitionCardType.Passport ? type : `${country}_${type}`,
156
- cardTypes: getCardSubTypes(type).map(c => twoWayAuthmeCardClassMap.toServer(c)),
349
+ scanType: type === exports.IdRecognitionCardType.Passport ? `ALL_Passport` : `${country}_${type}`,
350
+ cardTypes: useCardTypes,
157
351
  needConfirm,
158
- encrypt
352
+ encrypt,
353
+ clientInfo: {
354
+ os: 'web',
355
+ os_ver: util.osVersion(),
356
+ client_ver: packageInfo.version
357
+ }
159
358
  };
160
359
  return core.sendRequest('/api/identity-verification/id-recognition/v3/init-scan', 'POST', {
161
360
  body: JSON.stringify(body)
@@ -170,6 +369,15 @@ function initScanDocument(scanId, cardType) {
170
369
  body: JSON.stringify(body)
171
370
  });
172
371
  }
372
+ function initScanDocumentResourceBase64(scanId, ResourceId) {
373
+ const body = {
374
+ scanId,
375
+ ResourceId
376
+ };
377
+ return core.sendRequest('/api/identity-verification/id-recognition/v3/init-scan-doc/resource/base64', 'POST', {
378
+ body: JSON.stringify(body)
379
+ });
380
+ }
173
381
  function recognition(documentId, file) {
174
382
  const formData = new FormData();
175
383
  formData.append('scanDocumentId', documentId);
@@ -276,17 +484,6 @@ function saveExtraDoc(params) {
276
484
  });
277
485
  }
278
486
 
279
- var name = "@authme/id-recognition";
280
- var version$1 = "2.4.11";
281
- var peerDependencies = {
282
- "core-js": "^3.6.0"
283
- };
284
- var packageInfo = {
285
- name: name,
286
- version: version$1,
287
- peerDependencies: peerDependencies
288
- };
289
-
290
487
  var _a;
291
488
  var _b, _c;
292
489
  const version = packageInfo.version;
@@ -325,16 +522,22 @@ exports.CardOCR = CardOCR;
325
522
  exports.IdCardAntiFraudService = IdCardAntiFraudService;
326
523
  exports.IdTypeConfig = IdTypeConfig;
327
524
  exports.MRZService = MRZService;
525
+ exports.cardTypeConfirmTitle = cardTypeConfirmTitle;
526
+ exports.cardTypeTitle = cardTypeTitle;
328
527
  exports.confirmScan = confirmScan;
329
528
  exports.finishScanDocument = finishScanDocument;
330
529
  exports.getCardSubTypes = getCardSubTypes;
530
+ exports.getCardTypes = getCardTypes;
331
531
  exports.getRecognitionColumnOrder = getRecognitionColumnOrder;
332
532
  exports.init = init;
333
533
  exports.initScanDocument = initScanDocument;
534
+ exports.initScanDocumentResourceBase64 = initScanDocumentResourceBase64;
535
+ exports.mapCardtypeToAuthmeClass = mapCardtypeToAuthmeClass;
334
536
  exports.recognition = recognition;
335
537
  exports.recognitionEncrypt = recognitionEncrypt;
336
538
  exports.saveExtraDoc = saveExtraDoc;
337
539
  exports.saveResourceImage = saveResourceImage;
540
+ exports.thicknessDefaultConfig = thicknessDefaultConfig;
338
541
  exports.twoWayAuthmeCardClassMap = twoWayAuthmeCardClassMap;
339
542
  exports.uploadFrameBase64 = uploadFrameBase64;
340
543
  exports.version = version;
package/index.js CHANGED
@@ -1,9 +1,11 @@
1
+ import 'core-js/modules/es.object.assign.js';
1
2
  import { AuthmeEngineModuleBase, EAuthMeCardClass, EngineModule } from '@authme/engine';
2
3
  export { EAuthMeCardClass, EAuthMeCardMatchStatus, EAuthMeCardOCRStatus, EAuthMeIDCardAntiFraudStage, EAuthMeIDCardAntiFraudStatus, EAuthMeMRZRecogStatus, EAuthMeMRZServiceStatus } from '@authme/engine';
3
4
  import 'core-js/modules/es.array.iterator.js';
4
5
  import 'core-js/modules/es.object.from-entries.js';
5
6
  import 'core-js/modules/web.dom-collections.iterator.js';
6
7
  import { sendRequest, AuthmeError } from '@authme/core';
8
+ import { osVersion } from '@authme/util';
7
9
  import 'core-js/modules/es.symbol.description.js';
8
10
 
9
11
  var ResourceImageType;
@@ -11,11 +13,36 @@ var ResourceImageType;
11
13
  ResourceImageType["Recognition"] = "Recognition";
12
14
  ResourceImageType["Fraud"] = "Fraud";
13
15
  ResourceImageType["Manual"] = "Manual";
16
+ ResourceImageType["Attach"] = "AttachImage";
14
17
  })(ResourceImageType || (ResourceImageType = {}));
15
18
  var CountryCode;
16
19
  (function (CountryCode) {
17
20
  CountryCode["TWN"] = "TWN";
18
- CountryCode["JPW"] = "JP";
21
+ CountryCode["JPN"] = "JPN";
22
+ CountryCode["ZAF"] = "ZAF";
23
+ CountryCode["USA"] = "USA";
24
+ CountryCode["CHN"] = "CHN";
25
+ CountryCode["PHL"] = "PHL";
26
+ CountryCode["GBR"] = "GBR";
27
+ CountryCode["KOR"] = "KOR";
28
+ CountryCode["HKG"] = "HKG";
29
+ CountryCode["FRA"] = "FRA";
30
+ CountryCode["ESP"] = "ESP";
31
+ CountryCode["MEX"] = "MEX";
32
+ CountryCode["ITA"] = "ITA";
33
+ CountryCode["IND"] = "IND";
34
+ CountryCode["COL"] = "COL";
35
+ CountryCode["RUS"] = "RUS";
36
+ CountryCode["DEU"] = "DEU";
37
+ CountryCode["TUR"] = "TUR";
38
+ CountryCode["CAN"] = "CAN";
39
+ CountryCode["AUS"] = "AUS";
40
+ CountryCode["IDN"] = "IDN";
41
+ CountryCode["MYS"] = "MYS";
42
+ CountryCode["EGY"] = "EGY";
43
+ CountryCode["SAU"] = "SAU";
44
+ CountryCode["NLD"] = "NLD";
45
+ CountryCode["SGP"] = "SGP";
19
46
  })(CountryCode || (CountryCode = {}));
20
47
  var IdRecognitionCardType;
21
48
  (function (IdRecognitionCardType) {
@@ -25,6 +52,14 @@ var IdRecognitionCardType;
25
52
  IdRecognitionCardType["ResidentCard"] = "ResidentCard";
26
53
  IdRecognitionCardType["Passport"] = "Passport";
27
54
  })(IdRecognitionCardType || (IdRecognitionCardType = {}));
55
+ var IdRecognitionCardName;
56
+ (function (IdRecognitionCardName) {
57
+ IdRecognitionCardName["IDCard"] = "sdk.home.selectDocument.idCard";
58
+ IdRecognitionCardName["DriverLicense"] = "sdk.home.selectDocument.driverLicense";
59
+ IdRecognitionCardName["HealthCard"] = "sdk.home.selectDocument.healthCard";
60
+ IdRecognitionCardName["ResidentCard"] = "sdk.home.selectDocument.residentCard";
61
+ IdRecognitionCardName["Passport"] = "sdk.home.selectDocument.passport";
62
+ })(IdRecognitionCardName || (IdRecognitionCardName = {}));
28
63
  var ServerSideEAuthMeCardClass;
29
64
  (function (ServerSideEAuthMeCardClass) {
30
65
  ServerSideEAuthMeCardClass["Invalid"] = "Invalid";
@@ -51,16 +86,22 @@ class CardOCR extends AuthmeEngineModuleBase {
51
86
  this.type = EAuthMeCardClass.Invalid;
52
87
  this.moduleName = EngineModule.CardOCR;
53
88
  }
54
- setType(type, options) {
89
+ setType(type) {
55
90
  this.type = type;
56
91
  return this.engine.run(this.moduleName, 'setType', {
57
- type,
58
- options
92
+ type
59
93
  });
60
94
  }
61
95
  getType() {
62
96
  return this.type;
63
97
  }
98
+ setParams(params) {
99
+ var _a;
100
+ if (((_a = params.type) !== null && _a !== void 0 ? _a : this.type) === EAuthMeCardClass.Invalid) throw new Error('Please set type first');
101
+ return this.engine.run(this.moduleName, 'setParams', Object.assign({
102
+ type: this.type
103
+ }, params));
104
+ }
64
105
  }
65
106
  class IdCardAntiFraudService extends AuthmeEngineModuleBase {
66
107
  constructor(engine) {
@@ -119,6 +160,41 @@ const IdTypeConfig = {
119
160
  }
120
161
  };
121
162
 
163
+ const thicknessDefaultConfig = {
164
+ mode: 'manual',
165
+ thicknessWelcomeSetting: {
166
+ welcome: true,
167
+ title: {
168
+ enable: true,
169
+ // text: translateService.translate(
170
+ // 'verify.ocr.welcome.title'
171
+ // ),
172
+ // text: '即將進行厚度檢測',
173
+ text: 'sdk.thickness.detection.guide.subtitle'
174
+ },
175
+ subtitle: {
176
+ enable: true,
177
+ // text: translateService.translate(
178
+ // 'verify.ocr.welcome.subtitle'
179
+ // ),
180
+ // text: '請將卡面傾斜45度角放入畫面框線進行拍攝',
181
+ text: 'sdk.thickness.detection.guide.subtitle.content'
182
+ },
183
+ imageShow: {
184
+ enable: true,
185
+ src: ''
186
+ },
187
+ content: {
188
+ enable: true,
189
+ // text: translateService.translate(
190
+ // 'verify.ocr.welcome.content'
191
+ // ),
192
+ // text: '請在光線充足的環境進行拍攝\n請確保卡面資訊上沒有任何遮蔽物\n避免在白色背景進行拍攝,以確保卡片輪廓清晰',
193
+ text: 'sdk.thickness.detection.guide.content'
194
+ }
195
+ }
196
+ };
197
+
122
198
  const CardTypeMapping = {
123
199
  [IdRecognitionCardType.IDCard]: [EAuthMeCardClass.TWN_IDCard_Front, EAuthMeCardClass.TWN_IDCard_Back],
124
200
  [IdRecognitionCardType.HealthCard]: [EAuthMeCardClass.TWN_HealthCard_Front],
@@ -126,10 +202,112 @@ const CardTypeMapping = {
126
202
  [IdRecognitionCardType.ResidentCard]: [EAuthMeCardClass.TWN_ResidentCard_Front, EAuthMeCardClass.TWN_ResidentCard_Back],
127
203
  [IdRecognitionCardType.DriverLicense]: [EAuthMeCardClass.TWN_DriverLicense_Front, EAuthMeCardClass.TWN_DriverLicense_Back]
128
204
  };
205
+ const CardTypeMap = {
206
+ [IdRecognitionCardType.IDCard]: [ServerSideEAuthMeCardClass.TWN_IDCard_Front, ServerSideEAuthMeCardClass.TWN_IDCard_Back],
207
+ [IdRecognitionCardType.HealthCard]: [ServerSideEAuthMeCardClass.TWN_HealthCard_Front],
208
+ [IdRecognitionCardType.Passport]: ['ALL_PASSPORT_CONTENT'],
209
+ [IdRecognitionCardType.ResidentCard]: [ServerSideEAuthMeCardClass.TWN_ResidentCard_Front, ServerSideEAuthMeCardClass.TWN_ResidentCard_Back],
210
+ [IdRecognitionCardType.DriverLicense]: [ServerSideEAuthMeCardClass.TWN_DriverLicense_Front, ServerSideEAuthMeCardClass.TWN_DriverLicense_Back]
211
+ };
129
212
  const RECOGNITION_COLUMNS_ORDER = Object.fromEntries(['surname', 'givenName', 'name', 'gender', 'dateOfBirth', 'idNumber', 'dateOfIssue', 'issueCity', 'issueReason', 'father', 'mother', 'spouse', 'militaryService', 'placeOfBirth', 'serialNumber', 'expiry', 'controlNo', 'type', 'condition', 'address', 'country', 'documentNumber', 'documentType', 'nationality', 'expiryDate'].map((value, index) => [value, index]));
130
213
  function getCardSubTypes(type, country) {
131
214
  return CardTypeMapping[type];
132
215
  }
216
+ function getCardTypes(type, country) {
217
+ return CardTypeMap[type];
218
+ }
219
+ function cardTypeTitle(cardType) {
220
+ var _a, _b;
221
+ if (cardType == null) {
222
+ return '';
223
+ }
224
+ const cardTypeLower = cardType.toLowerCase();
225
+ const cardTypeMap = {
226
+ idcard: {
227
+ front: 'sdk.ocr.verify.idCardFrontSide',
228
+ back: 'sdk.ocr.verify.idCardBackSide',
229
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
230
+ default: 'sdk.ocr.verify.idCardFrontSide'
231
+ },
232
+ driverlicense: {
233
+ front: 'sdk.ocr.verify.driverFrontSide',
234
+ back: 'sdk.ocr.verify.driverBackSide',
235
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
236
+ default: 'sdk.ocr.verify.driverFrontSide'
237
+ },
238
+ resident: {
239
+ front: 'sdk.ocr.verify.residentCardFrontSide',
240
+ back: 'sdk.ocr.verify.residentCardBackSide',
241
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
242
+ default: 'sdk.ocr.verify.residentCardFrontSide'
243
+ },
244
+ residentcard: {
245
+ front: 'sdk.ocr.verify.residentCardFrontSide',
246
+ back: 'sdk.ocr.verify.residentCardBackSide',
247
+ thickness: 'sdk.thickness.detection.guide.subtitle.content',
248
+ default: 'sdk.ocr.verify.residentCardFrontSide'
249
+ }
250
+ };
251
+ const typeSections = cardTypeLower.split('_');
252
+ const cardTypeName = typeSections[1];
253
+ const cardTypeSection = typeSections[2];
254
+ const titleKey = ((_a = cardTypeMap[cardTypeName]) === null || _a === void 0 ? void 0 : _a[cardTypeSection]) || ((_b = cardTypeMap[cardTypeName]) === null || _b === void 0 ? void 0 : _b.default);
255
+ return titleKey || '';
256
+ }
257
+ function cardTypeConfirmTitle(cardType) {
258
+ if (cardType == null) {
259
+ return '';
260
+ }
261
+ const cardTypeLower = cardType.toLowerCase();
262
+ let titleKey = null;
263
+ if (cardTypeLower.indexOf('idcard') != -1) {
264
+ if (cardTypeLower.indexOf('front') !== -1) {
265
+ titleKey = 'sdk.ocr.verify.confirmIdCardFront';
266
+ } else if (cardTypeLower.indexOf('back') !== -1) {
267
+ titleKey = 'sdk.ocr.verify.confirmIdCardBack';
268
+ } else {
269
+ titleKey = 'sdk.ocr.verify.confirmIdCardFront';
270
+ }
271
+ return titleKey;
272
+ }
273
+ if (cardTypeLower.indexOf('driverlicense') != -1) {
274
+ if (cardTypeLower.indexOf('front') !== -1) {
275
+ titleKey = 'sdk.ocr.verify.confirmDriverFront';
276
+ } else if (cardTypeLower.indexOf('back') !== -1) {
277
+ titleKey = 'sdk.ocr.verify.confirmDriverBack';
278
+ } else {
279
+ titleKey = 'sdk.ocr.verify.confirmDriverFront';
280
+ }
281
+ return titleKey;
282
+ }
283
+ if (cardTypeLower.indexOf('resident') != -1) {
284
+ if (cardTypeLower.indexOf('front') !== -1) {
285
+ titleKey = 'sdk.ocr.verify.confirmResidentCardFront';
286
+ } else if (cardTypeLower.indexOf('back') !== -1) {
287
+ titleKey = 'sdk.ocr.verify.confirmResidentCardBack';
288
+ } else {
289
+ titleKey = 'sdk.ocr.verify.confirmResidentCardFront';
290
+ }
291
+ return titleKey;
292
+ }
293
+ return titleKey;
294
+ }
295
+ function mapCardtypeToAuthmeClass(type) {
296
+ // const known_type = Object.keys(EAuthMeCardClass).filter(
297
+ // (key) =>
298
+ // (EAuthMeCardClass as any)[key].toString().toLowerCase() ==
299
+ // ('EAuthMeCardClass_' + type).toLowerCase()
300
+ // )[0];
301
+ // if (known_type == null) {
302
+ // return EAuthMeCardClass.Unknown;
303
+ // }
304
+ // return (EAuthMeCardClass as any)[known_type];
305
+ if (type in EAuthMeCardClass) {
306
+ return EAuthMeCardClass[type];
307
+ } else {
308
+ return EAuthMeCardClass.Unknown;
309
+ }
310
+ }
133
311
  function getRecognitionColumnOrder(column) {
134
312
  var _a;
135
313
  return (_a = RECOGNITION_COLUMNS_ORDER[column]) !== null && _a !== void 0 ? _a : Number.MAX_VALUE;
@@ -147,12 +325,33 @@ const twoWayAuthmeCardClassMap = (() => {
147
325
  };
148
326
  })();
149
327
 
150
- function init(type, country, needConfirm, encrypt = true) {
328
+ var name = "authme/sdk";
329
+ var version$1 = "2.7.1";
330
+ var date = "2024-09-06T02:00:28+0000";
331
+ var packageInfo = {
332
+ name: name,
333
+ version: version$1,
334
+ date: date
335
+ };
336
+
337
+ function init(type, country, needConfirm, cardTypes, encrypt = true) {
338
+ // let useCardTypes: any = getCardSubTypes(type, country).map((c) =>
339
+ // twoWayAuthmeCardClassMap.toServer(c)
340
+ // );
341
+ let useCardTypes = getCardTypes(type);
342
+ if (cardTypes.length) {
343
+ useCardTypes = cardTypes;
344
+ }
151
345
  const body = {
152
- scanType: type === IdRecognitionCardType.Passport ? type : `${country}_${type}`,
153
- cardTypes: getCardSubTypes(type).map(c => twoWayAuthmeCardClassMap.toServer(c)),
346
+ scanType: type === IdRecognitionCardType.Passport ? `ALL_Passport` : `${country}_${type}`,
347
+ cardTypes: useCardTypes,
154
348
  needConfirm,
155
- encrypt
349
+ encrypt,
350
+ clientInfo: {
351
+ os: 'web',
352
+ os_ver: osVersion(),
353
+ client_ver: packageInfo.version
354
+ }
156
355
  };
157
356
  return sendRequest('/api/identity-verification/id-recognition/v3/init-scan', 'POST', {
158
357
  body: JSON.stringify(body)
@@ -167,6 +366,15 @@ function initScanDocument(scanId, cardType) {
167
366
  body: JSON.stringify(body)
168
367
  });
169
368
  }
369
+ function initScanDocumentResourceBase64(scanId, ResourceId) {
370
+ const body = {
371
+ scanId,
372
+ ResourceId
373
+ };
374
+ return sendRequest('/api/identity-verification/id-recognition/v3/init-scan-doc/resource/base64', 'POST', {
375
+ body: JSON.stringify(body)
376
+ });
377
+ }
170
378
  function recognition(documentId, file) {
171
379
  const formData = new FormData();
172
380
  formData.append('scanDocumentId', documentId);
@@ -273,21 +481,10 @@ function saveExtraDoc(params) {
273
481
  });
274
482
  }
275
483
 
276
- var name = "@authme/id-recognition";
277
- var version$1 = "2.4.11";
278
- var peerDependencies = {
279
- "core-js": "^3.6.0"
280
- };
281
- var packageInfo = {
282
- name: name,
283
- version: version$1,
284
- peerDependencies: peerDependencies
285
- };
286
-
287
484
  var _a;
288
485
  var _b, _c;
289
486
  const version = packageInfo.version;
290
487
  (_a = (_b = window)[_c = Symbol.for('authme-sdk')]) !== null && _a !== void 0 ? _a : _b[_c] = {};
291
488
  window[Symbol.for('authme-sdk')][packageInfo.name] = version;
292
489
 
293
- export { CardOCR, CountryCode, IdCardAntiFraudService, IdRecognitionCardType, IdType, IdTypeConfig, MRZService, RecognitionFileType, ResourceImageType, ServerSideEAuthMeCardClass, confirmScan, finishScanDocument, getCardSubTypes, getRecognitionColumnOrder, init, initScanDocument, recognition, recognitionEncrypt, saveExtraDoc, saveResourceImage, twoWayAuthmeCardClassMap, uploadFrameBase64, version };
490
+ export { CardOCR, CountryCode, IdCardAntiFraudService, IdRecognitionCardName, IdRecognitionCardType, IdType, IdTypeConfig, MRZService, RecognitionFileType, ResourceImageType, ServerSideEAuthMeCardClass, cardTypeConfirmTitle, cardTypeTitle, confirmScan, finishScanDocument, getCardSubTypes, getCardTypes, getRecognitionColumnOrder, init, initScanDocument, initScanDocumentResourceBase64, mapCardtypeToAuthmeClass, recognition, recognitionEncrypt, saveExtraDoc, saveResourceImage, thicknessDefaultConfig, twoWayAuthmeCardClassMap, uploadFrameBase64, version };
package/package.json CHANGED
@@ -1,10 +1,11 @@
1
1
  {
2
2
  "name": "@authme/id-recognition",
3
- "version": "2.4.11",
3
+ "version": "2.7.1",
4
4
  "peerDependencies": {
5
5
  "core-js": "^3.6.0",
6
- "@authme/core": "2.4.11",
7
- "@authme/engine": "2.4.11"
6
+ "@authme/core": "2.7.1",
7
+ "@authme/util": "2.7.1",
8
+ "@authme/engine": "2.7.1"
8
9
  },
9
10
  "module": "./index.js",
10
11
  "main": "./index.cjs",
@@ -1,9 +1,19 @@
1
- import { CountryCode, IdRecognitionCardType, RecognitionFileType, ResourceImageType, ServerSideEAuthMeCardClass } from '../enum';
1
+ import { CountryCode, IdRecognitionCardType, RecognitionFileType, ResourceImageType } from '../enum';
2
2
  import { InitScanResponse } from '../model';
3
- export declare function init(type: IdRecognitionCardType, country: CountryCode, needConfirm: boolean, encrypt?: boolean): Promise<InitScanResponse>;
4
- export declare function initScanDocument(scanId: string, cardType: `${ServerSideEAuthMeCardClass}`): Promise<{
3
+ import { ScanViewItem, WelcomePageConfig, ThicknessMode } from '../interface';
4
+ interface InitScanDocumentParams {
5
5
  scanDocumentId: string;
6
- }>;
6
+ scanView: ScanViewItem;
7
+ mode: ThicknessMode['mode'];
8
+ welcome: WelcomePageConfig;
9
+ }
10
+ interface InitScanDocumentResourceBase64Params {
11
+ fileId: string;
12
+ data: string;
13
+ }
14
+ export declare function init(type: IdRecognitionCardType, country: CountryCode, needConfirm: boolean, cardTypes: string[], encrypt?: boolean): Promise<InitScanResponse>;
15
+ export declare function initScanDocument(scanId: string, cardType: string): Promise<InitScanDocumentParams>;
16
+ export declare function initScanDocumentResourceBase64(scanId: string, ResourceId: string): Promise<InitScanDocumentResourceBase64Params>;
7
17
  export declare function recognition(documentId: string, file: Blob): Promise<{
8
18
  retry?: boolean;
9
19
  details: {
@@ -35,3 +45,4 @@ export declare function saveExtraDoc(params: {
35
45
  [key: string]: string | null;
36
46
  };
37
47
  }): Promise<any>;
48
+ export {};
@@ -2,11 +2,36 @@ export { EAuthMeCardClass, EAuthMeCardMatchStatus, EAuthMeCardOCRStatus, EAuthMe
2
2
  export declare enum ResourceImageType {
3
3
  Recognition = "Recognition",
4
4
  Fraud = "Fraud",
5
- Manual = "Manual"
5
+ Manual = "Manual",
6
+ Attach = "AttachImage"
6
7
  }
7
8
  export declare enum CountryCode {
8
9
  TWN = "TWN",
9
- JPW = "JP"
10
+ JPN = "JPN",
11
+ ZAF = "ZAF",
12
+ USA = "USA",
13
+ CHN = "CHN",
14
+ PHL = "PHL",
15
+ GBR = "GBR",
16
+ KOR = "KOR",
17
+ HKG = "HKG",
18
+ FRA = "FRA",
19
+ ESP = "ESP",
20
+ MEX = "MEX",
21
+ ITA = "ITA",
22
+ IND = "IND",
23
+ COL = "COL",
24
+ RUS = "RUS",
25
+ DEU = "DEU",
26
+ TUR = "TUR",
27
+ CAN = "CAN",
28
+ AUS = "AUS",
29
+ IDN = "IDN",
30
+ MYS = "MYS",
31
+ EGY = "EGY",
32
+ SAU = "SAU",
33
+ NLD = "NLD",
34
+ SGP = "SGP"
10
35
  }
11
36
  export declare enum IdRecognitionCardType {
12
37
  IDCard = "IDCard",
@@ -15,6 +40,13 @@ export declare enum IdRecognitionCardType {
15
40
  ResidentCard = "ResidentCard",
16
41
  Passport = "Passport"
17
42
  }
43
+ export declare enum IdRecognitionCardName {
44
+ IDCard = "sdk.home.selectDocument.idCard",
45
+ DriverLicense = "sdk.home.selectDocument.driverLicense",
46
+ HealthCard = "sdk.home.selectDocument.healthCard",
47
+ ResidentCard = "sdk.home.selectDocument.residentCard",
48
+ Passport = "sdk.home.selectDocument.passport"
49
+ }
18
50
  export declare enum ServerSideEAuthMeCardClass {
19
51
  Invalid = "Invalid",
20
52
  Unknown = "UnknownCard",
@@ -0,0 +1,65 @@
1
+ export interface ScanViewItem {
2
+ document_type: string;
3
+ content: ContentItem[];
4
+ success: ScanViewSuccess;
5
+ line: ScanViewLine;
6
+ border: ScanViewBorder;
7
+ }
8
+ interface ContentItem {
9
+ type: 'text' | 'svg';
10
+ content: string;
11
+ color: string | null;
12
+ opacity: number;
13
+ }
14
+ interface ScanViewSuccess {
15
+ enable: boolean;
16
+ color: string;
17
+ opacity: number;
18
+ }
19
+ interface ScanViewLine {
20
+ enable: boolean;
21
+ color: string;
22
+ gradient: ScanViewGradient;
23
+ }
24
+ interface ScanViewGradient {
25
+ enable: true;
26
+ color: string;
27
+ opacity: number;
28
+ }
29
+ interface ScanViewBorder {
30
+ enable: boolean;
31
+ type: 'cornered' | 'bordered';
32
+ color: string;
33
+ opacity: number;
34
+ }
35
+ export interface ThicknessMode {
36
+ mode: 'auto' | 'manual';
37
+ }
38
+ export interface WelcomePageConfig {
39
+ welcome: boolean;
40
+ title: WelcomePagTitle;
41
+ subtitle: WelcomePageSubtitle;
42
+ imageShow: WelcomePageImage;
43
+ content: WelcomePageContent;
44
+ }
45
+ interface WelcomePagTitle {
46
+ enable: boolean;
47
+ text: string;
48
+ }
49
+ interface WelcomePageSubtitle {
50
+ enable: boolean;
51
+ text: string;
52
+ }
53
+ interface WelcomePageImage {
54
+ enable: boolean;
55
+ src: string;
56
+ }
57
+ interface WelcomePageContent {
58
+ enable: boolean;
59
+ text: string;
60
+ }
61
+ export declare const thicknessDefaultConfig: {
62
+ mode: ThicknessMode['mode'];
63
+ thicknessWelcomeSetting: WelcomePageConfig;
64
+ };
65
+ export {};
@@ -1 +1,2 @@
1
1
  export * from './id-recognition-type.interface';
2
+ export * from './api-response.interface';
@@ -4,10 +4,9 @@ import { EAuthMeCardClass, EAuthMeIDCardAntiFraudStage } from './enum';
4
4
  export declare class CardOCR extends AuthmeEngineModuleBase<CardOCRResult> {
5
5
  private type;
6
6
  constructor(engine: MlEngine);
7
- setType(type: EAuthMeCardClass, options?: {
8
- [key: string]: unknown;
9
- }): Promise<unknown>;
7
+ setType(type: EAuthMeCardClass): Promise<unknown>;
10
8
  getType(): EAuthMeCardClass;
9
+ setParams(params: any): Promise<unknown>;
11
10
  }
12
11
  export interface Point {
13
12
  x: number;
package/src/lib/util.d.ts CHANGED
@@ -1,5 +1,9 @@
1
1
  import { CountryCode, EAuthMeCardClass, IdRecognitionCardType, ServerSideEAuthMeCardClass } from './enum';
2
2
  export declare function getCardSubTypes(type: IdRecognitionCardType, country: CountryCode): EAuthMeCardClass[];
3
+ export declare function getCardTypes(type: IdRecognitionCardType, country: CountryCode): string[];
4
+ export declare function cardTypeTitle(cardType: string): any;
5
+ export declare function cardTypeConfirmTitle(cardType: string): any;
6
+ export declare function mapCardtypeToAuthmeClass(type: string): any;
3
7
  export declare function getRecognitionColumnOrder(column: string): number;
4
8
  export declare const twoWayAuthmeCardClassMap: {
5
9
  toServer(clientEnum: `${EAuthMeCardClass}`): `${ServerSideEAuthMeCardClass}`;