ua-parser-js 2.0.0-alpha.3 → 2.0.0-beta.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.
@@ -0,0 +1,104 @@
1
+ // Type definitions for UAParser.js v2.0.0-beta.1
2
+ // Project: https://github.com/faisalman/ua-parser-js
3
+ // Definitions by: Faisal Salman <https://github.com/faisalman>
4
+
5
+ declare namespace UAParser {
6
+
7
+ interface IData<T> {
8
+ is(val: string): boolean;
9
+ toString(): string;
10
+ withClientHints(): PromiseLike<T> | T;
11
+ withFeatureCheck(): T;
12
+ }
13
+
14
+ interface IBrowser extends IData<IBrowser> {
15
+ name?: string;
16
+ version?: string;
17
+ major?: string;
18
+ }
19
+
20
+ interface ICPU extends IData<ICPU> {
21
+ architecture?: 'ia32' | 'ia64' | 'amd64' | 'arm' | 'arm64' | 'armhf' | 'avr' | 'irix' | 'irix64' | 'mips' | 'mips64' | '68k' | 'ppc' | 'sparc' | 'sparc64';
22
+ }
23
+
24
+ interface IDevice extends IData<IDevice> {
25
+ type?: 'mobile' | 'tablet' | 'console' | 'smarttv' | 'wearable';
26
+ vendor?: string;
27
+ model?: string;
28
+ }
29
+
30
+ interface IEngine extends IData<IEngine> {
31
+ name?: 'Amaya' | 'Blink' | 'EdgeHTML' | 'Flow' | 'Gecko' | 'Goanna' | 'iCab' | 'KHTML' | 'LibWeb' | 'Links' | 'Lynx' | 'NetFront' | 'NetSurf' | 'Presto' | 'Tasman' | 'Trident' | 'w3m' | 'WebKit';
32
+ version?: string;
33
+ }
34
+
35
+ interface IOS extends IData<IOS> {
36
+ name?: string;
37
+ version?: string;
38
+ }
39
+
40
+ interface IResult extends IData<IResult> {
41
+ ua: string;
42
+ browser: IBrowser;
43
+ cpu: ICPU;
44
+ device: IDevice;
45
+ engine: IEngine;
46
+ os: IOS;
47
+ }
48
+
49
+ type RegexMap = ((RegExp | string | (string | RegExp | Function)[])[])[];
50
+
51
+ export function UAParser(uastring?: string, extensions?: Record<string, RegexMap>, headers?: Record<string, string>): IResult;
52
+ export function UAParser(uastring?: string, headers?: Record<string, string>): IResult;
53
+ export function UAParser(extensions?: Record<string, RegexMap>, headers?: Record<string, string>): IResult;
54
+ export function UAParser(headers?: Record<string, string>): IResult;
55
+
56
+ export class UAParser {
57
+
58
+ static readonly BROWSER: {
59
+ NAME: 'name';
60
+ VERSION: 'version';
61
+ MAJOR: 'major';
62
+ };
63
+ static readonly CPU: {
64
+ ARCHITECTURE: 'architecture';
65
+ };
66
+ static readonly DEVICE: {
67
+ TYPE: 'type';
68
+ VENDOR: 'vendor';
69
+ MODEL: 'model';
70
+ CONSOLE: 'console';
71
+ MOBILE: 'mobile';
72
+ SMARTTV: 'smarttv';
73
+ TABLET: 'tablet';
74
+ WEARABLE: 'wearable';
75
+ EMBEDDED: 'embedded';
76
+ };
77
+ static readonly ENGINE: {
78
+ NAME: 'name';
79
+ VERSION: 'version';
80
+ };
81
+ static readonly OS: {
82
+ NAME: 'name';
83
+ VERSION: 'version';
84
+ };
85
+ static readonly VERSION: string;
86
+
87
+ constructor(uastring?: string, extensions?: Record<string, RegexMap>, headers?: Record<string, string>);
88
+ constructor(uastring?: string, headers?: Record<string, string>);
89
+ constructor(extensions?: Record<string, RegexMap>, headers?: Record<string, string>);
90
+ constructor(headers?: Record<string, string>);
91
+
92
+ getUA(): string;
93
+ getBrowser(): IBrowser;
94
+ getCPU(): ICPU;
95
+ getDevice(): IDevice;
96
+ getEngine(): IEngine;
97
+ getOS(): IOS;
98
+ getResult(): IResult;
99
+ setUA(uastring: string): UAParser;
100
+ }
101
+ }
102
+
103
+ export as namespace UAParser;
104
+ export = UAParser;
@@ -1,7 +1,7 @@
1
1
  /////////////////////////////////////////////////////////////////////////////////
2
- /* UAParser.js v2.0.0-alpha.3
2
+ /* UAParser.js v2.0.0-beta.1
3
3
  Copyright © 2012-2023 Faisal Salman <f@faisalman.com>
4
- MIT License *//*
4
+ AGPLv3 License *//*
5
5
  Detect Browser, Engine, OS, CPU, and Device type/model from User-Agent data.
6
6
  Supports browser & node.js environment.
7
7
  Demo : https://faisalman.github.io/ua-parser-js
@@ -20,7 +20,7 @@
20
20
  /////////////
21
21
 
22
22
 
23
- var LIBVERSION = '2.0.0-alpha.3',
23
+ var LIBVERSION = '2.0.0-beta.1',
24
24
  EMPTY = '',
25
25
  UNKNOWN = '?',
26
26
  FUNC_TYPE = 'function',
@@ -43,6 +43,7 @@
43
43
  USER_AGENT = 'user-agent',
44
44
  UA_MAX_LENGTH = 350,
45
45
  BRANDS = 'brands',
46
+ FORMFACTOR = 'formFactor',
46
47
  FULLVERLIST = 'fullVersionList',
47
48
  PLATFORM = 'platform',
48
49
  PLATFORMVER = 'platformVersion',
@@ -51,11 +52,12 @@
51
52
  CH_HEADER_FULL_VER_LIST = CH_HEADER + '-full-version-list',
52
53
  CH_HEADER_ARCH = CH_HEADER + '-arch',
53
54
  CH_HEADER_BITNESS = CH_HEADER + '-' + BITNESS,
55
+ CH_HEADER_FORM_FACTOR = CH_HEADER + '-form-factor',
54
56
  CH_HEADER_MOBILE = CH_HEADER + '-' + MOBILE,
55
57
  CH_HEADER_MODEL = CH_HEADER + '-' + MODEL,
56
58
  CH_HEADER_PLATFORM = CH_HEADER + '-' + PLATFORM,
57
59
  CH_HEADER_PLATFORM_VER = CH_HEADER_PLATFORM + '-version',
58
- CH_ALL_VALUES = [BRANDS, FULLVERLIST, MOBILE, MODEL, PLATFORM, PLATFORMVER, ARCHITECTURE, BITNESS],
60
+ CH_ALL_VALUES = [BRANDS, FULLVERLIST, MOBILE, MODEL, PLATFORM, PLATFORMVER, ARCHITECTURE, FORMFACTOR, BITNESS],
59
61
  UA_BROWSER = 'browser',
60
62
  UA_CPU = 'cpu',
61
63
  UA_DEVICE = 'device',
@@ -127,10 +129,14 @@
127
129
  itemListToArray = function (header) {
128
130
  if (!header) return undefined;
129
131
  var arr = [];
130
- var tokens = strip(/\\?\"/g, header).split(', ');
132
+ var tokens = strip(/\\?\"/g, header).split(',');
131
133
  for (var i = 0; i < tokens.length; i++) {
132
- var token = tokens[i].split(';v=');
133
- arr[i] = { brand : token[0], version : token[1] };
134
+ if (tokens[i].indexOf(';') > -1) {
135
+ var token = trim(tokens[i]).split(';v=');
136
+ arr[i] = { brand : token[0], version : token[1] };
137
+ } else {
138
+ arr[i] = tokens[i];
139
+ }
134
140
  }
135
141
  return arr;
136
142
  },
@@ -155,7 +161,7 @@
155
161
  return str.replace(pattern, EMPTY);
156
162
  },
157
163
  stripQuotes = function (val) {
158
- return typeof val === STR_TYPE ? strip(/\"/g, val) : val;
164
+ return typeof val === STR_TYPE ? strip(/\\?\"/g, val) : val;
159
165
  },
160
166
  trim = function (str, len) {
161
167
  if (typeof(str) === STR_TYPE) {
@@ -237,7 +243,7 @@
237
243
  return (i === UNKNOWN) ? undefined : i;
238
244
  }
239
245
  }
240
- return str;
246
+ return map.hasOwnProperty('*') ? map['*'] : str;
241
247
  };
242
248
 
243
249
  ///////////////
@@ -256,6 +262,16 @@
256
262
  '8.1' : 'NT 6.3',
257
263
  '10' : ['NT 6.4', 'NT 10.0'],
258
264
  'RT' : 'ARM'
265
+ },
266
+
267
+ formFactorMap = {
268
+ 'embedded' : 'Automotive',
269
+ 'mobile' : 'Mobile',
270
+ 'tablet' : ['Tablet', 'EInk'],
271
+ 'smarttv' : 'TV',
272
+ 'wearable' : ['VR', 'XR', 'Watch'],
273
+ '?' : ['Desktop', 'Unknown'],
274
+ '*' : undefined
259
275
  };
260
276
 
261
277
  //////////////
@@ -478,8 +494,10 @@
478
494
  /\b; (\w+) build\/hm\1/i, // Xiaomi Hongmi 'numeric' models
479
495
  /\b(hm[-_ ]?note?[_ ]?(?:\d\w)?) bui/i, // Xiaomi Hongmi
480
496
  /\b(redmi[\-_ ]?(?:note|k)?[\w_ ]+)(?: bui|\))/i, // Xiaomi Redmi
497
+ /oid[^\)]+; (m?[12][0-389][01]\w{3,6}[c-y])( bui|\))/i, // Xiaomi Redmi 'numeric' models
481
498
  /\b(mi[-_ ]?(?:a\d|one|one[_ ]plus|note lte|max|cc)?[_ ]?(?:\d?\w?)[_ ]?(?:plus|se|lite)?)(?: bui|\))/i // Xiaomi Mi
482
499
  ], [[MODEL, /_/g, ' '], [VENDOR, XIAOMI], [TYPE, MOBILE]], [
500
+ /oid[^\)]+; (2\d{4}(283|rpbf)[cgl])( bui|\))/i, // Redmi Pad
483
501
  /\b(mi[-_ ]?(?:pad)(?:[\w_ ]+))(?: bui|\))/i // Mi Pad tablets
484
502
  ],[[MODEL, /_/g, ' '], [VENDOR, XIAOMI], [TYPE, TABLET]], [
485
503
 
@@ -494,7 +512,7 @@
494
512
  ], [MODEL, [VENDOR, 'Vivo'], [TYPE, MOBILE]], [
495
513
 
496
514
  // Realme
497
- /\b(rmx[12]\d{3})(?: bui|;|\))/i
515
+ /\b(rmx[1-3]\d{3})(?: bui|;|\))/i
498
516
  ], [MODEL, [VENDOR, 'Realme'], [TYPE, MOBILE]], [
499
517
 
500
518
  // Motorola
@@ -580,6 +598,10 @@
580
598
  /droid.+; (m[1-5] note) bui/i,
581
599
  /\bmz-([-\w]{2,})/i
582
600
  ], [MODEL, [VENDOR, 'Meizu'], [TYPE, MOBILE]], [
601
+
602
+ // Ulefone
603
+ /; ((?:power )?armor(?:[\w ]{0,8}))(?: bui|\))/i
604
+ ], [MODEL, [VENDOR, 'Ulefone'], [TYPE, MOBILE]], [
583
605
 
584
606
  // MIXED
585
607
  /(blackberry|benq|palm(?=\-)|sonyericsson|acer|asus|dell|meizu|motorola|polytron|infinix|tecno)[-_ ]?([-\w]*)/i,
@@ -930,6 +952,7 @@
930
952
  [PLATFORM, stripQuotes(uach[CH_HEADER_PLATFORM])],
931
953
  [PLATFORMVER, stripQuotes(uach[CH_HEADER_PLATFORM_VER])],
932
954
  [ARCHITECTURE, stripQuotes(uach[CH_HEADER_ARCH])],
955
+ [FORMFACTOR, itemListToArray(uach[CH_HEADER_FORM_FACTOR])],
933
956
  [BITNESS, stripQuotes(uach[CH_HEADER_BITNESS])]
934
957
  ]);
935
958
  } else {
@@ -1011,8 +1034,7 @@
1011
1034
  };
1012
1035
 
1013
1036
  this.parseCH = function () {
1014
- var ua = this.ua,
1015
- uaCH = this.uaCH,
1037
+ var uaCH = this.uaCH,
1016
1038
  rgxMap = this.rgxMap;
1017
1039
 
1018
1040
  switch (this.itemType) {
@@ -1044,6 +1066,18 @@
1044
1066
  if (uaCH[MODEL]) {
1045
1067
  this.set(MODEL, uaCH[MODEL]);
1046
1068
  }
1069
+ if (uaCH[FORMFACTOR]) {
1070
+ var ff;
1071
+ if (typeof uaCH[FORMFACTOR] !== 'string') {
1072
+ var idx = 0;
1073
+ while (!ff && idx < uaCH[FORMFACTOR].length) {
1074
+ ff = strMapper(uaCH[FORMFACTOR][idx++], formFactorMap);
1075
+ }
1076
+ } else {
1077
+ ff = strMapper(uaCH[FORMFACTOR], formFactorMap);
1078
+ }
1079
+ this.set(TYPE, ff);
1080
+ }
1047
1081
  break;
1048
1082
  case UA_OS:
1049
1083
  var osName = uaCH[PLATFORM];
@@ -1,11 +1,11 @@
1
- // Generated ESM version of UAParser.js
1
+ // Generated ESM version of ua-parser-js
2
2
  // DO NOT EDIT THIS FILE!
3
3
  // Source: /src/main/ua-parser.js
4
4
 
5
5
  /////////////////////////////////////////////////////////////////////////////////
6
- /* UAParser.js v2.0.0-alpha.3
6
+ /* UAParser.js v2.0.0-beta.1
7
7
  Copyright © 2012-2023 Faisal Salman <f@faisalman.com>
8
- MIT License *//*
8
+ AGPLv3 License *//*
9
9
  Detect Browser, Engine, OS, CPU, and Device type/model from User-Agent data.
10
10
  Supports browser & node.js environment.
11
11
  Demo : https://faisalman.github.io/ua-parser-js
@@ -22,7 +22,7 @@
22
22
  /////////////
23
23
 
24
24
 
25
- var LIBVERSION = '2.0.0-alpha.3',
25
+ var LIBVERSION = '2.0.0-beta.1',
26
26
  EMPTY = '',
27
27
  UNKNOWN = '?',
28
28
  FUNC_TYPE = 'function',
@@ -45,6 +45,7 @@
45
45
  USER_AGENT = 'user-agent',
46
46
  UA_MAX_LENGTH = 350,
47
47
  BRANDS = 'brands',
48
+ FORMFACTOR = 'formFactor',
48
49
  FULLVERLIST = 'fullVersionList',
49
50
  PLATFORM = 'platform',
50
51
  PLATFORMVER = 'platformVersion',
@@ -53,11 +54,12 @@
53
54
  CH_HEADER_FULL_VER_LIST = CH_HEADER + '-full-version-list',
54
55
  CH_HEADER_ARCH = CH_HEADER + '-arch',
55
56
  CH_HEADER_BITNESS = CH_HEADER + '-' + BITNESS,
57
+ CH_HEADER_FORM_FACTOR = CH_HEADER + '-form-factor',
56
58
  CH_HEADER_MOBILE = CH_HEADER + '-' + MOBILE,
57
59
  CH_HEADER_MODEL = CH_HEADER + '-' + MODEL,
58
60
  CH_HEADER_PLATFORM = CH_HEADER + '-' + PLATFORM,
59
61
  CH_HEADER_PLATFORM_VER = CH_HEADER_PLATFORM + '-version',
60
- CH_ALL_VALUES = [BRANDS, FULLVERLIST, MOBILE, MODEL, PLATFORM, PLATFORMVER, ARCHITECTURE, BITNESS],
62
+ CH_ALL_VALUES = [BRANDS, FULLVERLIST, MOBILE, MODEL, PLATFORM, PLATFORMVER, ARCHITECTURE, FORMFACTOR, BITNESS],
61
63
  UA_BROWSER = 'browser',
62
64
  UA_CPU = 'cpu',
63
65
  UA_DEVICE = 'device',
@@ -129,10 +131,14 @@
129
131
  itemListToArray = function (header) {
130
132
  if (!header) return undefined;
131
133
  var arr = [];
132
- var tokens = strip(/\\?\"/g, header).split(', ');
134
+ var tokens = strip(/\\?\"/g, header).split(',');
133
135
  for (var i = 0; i < tokens.length; i++) {
134
- var token = tokens[i].split(';v=');
135
- arr[i] = { brand : token[0], version : token[1] };
136
+ if (tokens[i].indexOf(';') > -1) {
137
+ var token = trim(tokens[i]).split(';v=');
138
+ arr[i] = { brand : token[0], version : token[1] };
139
+ } else {
140
+ arr[i] = tokens[i];
141
+ }
136
142
  }
137
143
  return arr;
138
144
  },
@@ -157,7 +163,7 @@
157
163
  return str.replace(pattern, EMPTY);
158
164
  },
159
165
  stripQuotes = function (val) {
160
- return typeof val === STR_TYPE ? strip(/\"/g, val) : val;
166
+ return typeof val === STR_TYPE ? strip(/\\?\"/g, val) : val;
161
167
  },
162
168
  trim = function (str, len) {
163
169
  if (typeof(str) === STR_TYPE) {
@@ -239,7 +245,7 @@
239
245
  return (i === UNKNOWN) ? undefined : i;
240
246
  }
241
247
  }
242
- return str;
248
+ return map.hasOwnProperty('*') ? map['*'] : str;
243
249
  };
244
250
 
245
251
  ///////////////
@@ -258,6 +264,16 @@
258
264
  '8.1' : 'NT 6.3',
259
265
  '10' : ['NT 6.4', 'NT 10.0'],
260
266
  'RT' : 'ARM'
267
+ },
268
+
269
+ formFactorMap = {
270
+ 'embedded' : 'Automotive',
271
+ 'mobile' : 'Mobile',
272
+ 'tablet' : ['Tablet', 'EInk'],
273
+ 'smarttv' : 'TV',
274
+ 'wearable' : ['VR', 'XR', 'Watch'],
275
+ '?' : ['Desktop', 'Unknown'],
276
+ '*' : undefined
261
277
  };
262
278
 
263
279
  //////////////
@@ -480,8 +496,10 @@
480
496
  /\b; (\w+) build\/hm\1/i, // Xiaomi Hongmi 'numeric' models
481
497
  /\b(hm[-_ ]?note?[_ ]?(?:\d\w)?) bui/i, // Xiaomi Hongmi
482
498
  /\b(redmi[\-_ ]?(?:note|k)?[\w_ ]+)(?: bui|\))/i, // Xiaomi Redmi
499
+ /oid[^\)]+; (m?[12][0-389][01]\w{3,6}[c-y])( bui|\))/i, // Xiaomi Redmi 'numeric' models
483
500
  /\b(mi[-_ ]?(?:a\d|one|one[_ ]plus|note lte|max|cc)?[_ ]?(?:\d?\w?)[_ ]?(?:plus|se|lite)?)(?: bui|\))/i // Xiaomi Mi
484
501
  ], [[MODEL, /_/g, ' '], [VENDOR, XIAOMI], [TYPE, MOBILE]], [
502
+ /oid[^\)]+; (2\d{4}(283|rpbf)[cgl])( bui|\))/i, // Redmi Pad
485
503
  /\b(mi[-_ ]?(?:pad)(?:[\w_ ]+))(?: bui|\))/i // Mi Pad tablets
486
504
  ],[[MODEL, /_/g, ' '], [VENDOR, XIAOMI], [TYPE, TABLET]], [
487
505
 
@@ -496,7 +514,7 @@
496
514
  ], [MODEL, [VENDOR, 'Vivo'], [TYPE, MOBILE]], [
497
515
 
498
516
  // Realme
499
- /\b(rmx[12]\d{3})(?: bui|;|\))/i
517
+ /\b(rmx[1-3]\d{3})(?: bui|;|\))/i
500
518
  ], [MODEL, [VENDOR, 'Realme'], [TYPE, MOBILE]], [
501
519
 
502
520
  // Motorola
@@ -582,6 +600,10 @@
582
600
  /droid.+; (m[1-5] note) bui/i,
583
601
  /\bmz-([-\w]{2,})/i
584
602
  ], [MODEL, [VENDOR, 'Meizu'], [TYPE, MOBILE]], [
603
+
604
+ // Ulefone
605
+ /; ((?:power )?armor(?:[\w ]{0,8}))(?: bui|\))/i
606
+ ], [MODEL, [VENDOR, 'Ulefone'], [TYPE, MOBILE]], [
585
607
 
586
608
  // MIXED
587
609
  /(blackberry|benq|palm(?=\-)|sonyericsson|acer|asus|dell|meizu|motorola|polytron|infinix|tecno)[-_ ]?([-\w]*)/i,
@@ -932,6 +954,7 @@
932
954
  [PLATFORM, stripQuotes(uach[CH_HEADER_PLATFORM])],
933
955
  [PLATFORMVER, stripQuotes(uach[CH_HEADER_PLATFORM_VER])],
934
956
  [ARCHITECTURE, stripQuotes(uach[CH_HEADER_ARCH])],
957
+ [FORMFACTOR, itemListToArray(uach[CH_HEADER_FORM_FACTOR])],
935
958
  [BITNESS, stripQuotes(uach[CH_HEADER_BITNESS])]
936
959
  ]);
937
960
  } else {
@@ -1013,8 +1036,7 @@
1013
1036
  };
1014
1037
 
1015
1038
  this.parseCH = function () {
1016
- var ua = this.ua,
1017
- uaCH = this.uaCH,
1039
+ var uaCH = this.uaCH,
1018
1040
  rgxMap = this.rgxMap;
1019
1041
 
1020
1042
  switch (this.itemType) {
@@ -1046,6 +1068,18 @@
1046
1068
  if (uaCH[MODEL]) {
1047
1069
  this.set(MODEL, uaCH[MODEL]);
1048
1070
  }
1071
+ if (uaCH[FORMFACTOR]) {
1072
+ var ff;
1073
+ if (typeof uaCH[FORMFACTOR] !== 'string') {
1074
+ var idx = 0;
1075
+ while (!ff && idx < uaCH[FORMFACTOR].length) {
1076
+ ff = strMapper(uaCH[FORMFACTOR][idx++], formFactorMap);
1077
+ }
1078
+ } else {
1079
+ ff = strMapper(uaCH[FORMFACTOR], formFactorMap);
1080
+ }
1081
+ this.set(TYPE, ff);
1082
+ }
1049
1083
  break;
1050
1084
  case UA_OS:
1051
1085
  var osName = uaCH[PLATFORM];
package/license.md DELETED
@@ -1,21 +0,0 @@
1
- MIT License
2
-
3
- Copyright (c) 2012-2023 Faisal Salman <<f@faisalman.com>>
4
-
5
- Permission is hereby granted, free of charge, to any person obtaining a copy
6
- of this software and associated documentation files (the "Software"), to deal
7
- in the Software without restriction, including without limitation the rights
8
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
- copies of the Software, and to permit persons to whom the Software is
10
- furnished to do so, subject to the following conditions:
11
-
12
- The above copyright notice and this permission notice shall be included in all
13
- copies or substantial portions of the Software.
14
-
15
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
- SOFTWARE.