@tinkoff/user-agent 0.7.116 → 0.8.102
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/README.md +190 -1
- package/lib/client-hints/constants.d.ts +7 -0
- package/lib/client-hints/constants.es.js +23 -0
- package/lib/client-hints/constants.js +32 -0
- package/lib/client-hints/parse-client-hints-headers/consts.d.ts +11 -0
- package/lib/client-hints/parse-client-hints-headers/consts.es.js +11 -0
- package/lib/client-hints/parse-client-hints-headers/consts.js +15 -0
- package/lib/client-hints/parse-client-hints-headers/parseClientHintsHeaders.d.ts +18 -0
- package/lib/client-hints/parse-client-hints-headers/parseClientHintsHeaders.es.js +54 -0
- package/lib/client-hints/parse-client-hints-headers/parseClientHintsHeaders.js +58 -0
- package/lib/client-hints/parse-client-hints-user-agent-data/parseClientHintsUserAgentData.d.ts +17 -0
- package/lib/client-hints/parse-client-hints-user-agent-data/parseClientHintsUserAgentData.es.js +47 -0
- package/lib/client-hints/parse-client-hints-user-agent-data/parseClientHintsUserAgentData.js +51 -0
- package/lib/client-hints/utils/getBackwardCompatibleOsName.d.ts +2 -0
- package/lib/client-hints/utils/getBackwardCompatibleOsName.es.js +10 -0
- package/lib/client-hints/utils/getBackwardCompatibleOsName.js +14 -0
- package/lib/client-hints/utils/parseBrowserFromString.d.ts +6 -0
- package/lib/client-hints/utils/parseBrowserFromString.es.js +42 -0
- package/lib/client-hints/utils/parseBrowserFromString.js +46 -0
- package/lib/client-hints/utils/parseBrowserFromUserAgentData.d.ts +6 -0
- package/lib/client-hints/utils/parseBrowserFromUserAgentData.es.js +39 -0
- package/lib/client-hints/utils/parseBrowserFromUserAgentData.js +43 -0
- package/lib/client-hints/utils/parseQuotedString.d.ts +2 -0
- package/lib/client-hints/utils/parseQuotedString.es.js +18 -0
- package/lib/client-hints/utils/parseQuotedString.js +22 -0
- package/lib/constants.d.ts +15 -6
- package/lib/constants.es.js +16 -60
- package/lib/constants.js +18 -61
- package/lib/index.d.ts +7 -5
- package/lib/index.es.js +5 -3
- package/lib/index.js +12 -8
- package/lib/parse-user-agent-header/consts.d.ts +2 -0
- package/lib/parse-user-agent-header/consts.es.js +27 -0
- package/lib/parse-user-agent-header/consts.js +31 -0
- package/lib/parse-user-agent-header/parseUserAgentHeader.d.ts +3 -0
- package/lib/parse-user-agent-header/parseUserAgentHeader.es.js +29 -0
- package/lib/parse-user-agent-header/parseUserAgentHeader.js +33 -0
- package/lib/{isSameSiteNoneCompatible.es.js → parse-user-agent-header/utils/is-same-site-none-compatible/isSameSiteNoneCompatible.es.js} +6 -1
- package/lib/{isSameSiteNoneCompatible.js → parse-user-agent-header/utils/is-same-site-none-compatible/isSameSiteNoneCompatible.js} +6 -1
- package/lib/parse-user-agent-header/utils/toLowerName.d.ts +2 -0
- package/lib/parse-user-agent-header/utils/toLowerName.es.js +14 -0
- package/lib/parse-user-agent-header/utils/toLowerName.js +24 -0
- package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/not_supported.txt +24 -2
- package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/supported.txt +7 -136
- package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/supported_force.txt +0 -1
- package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/supported_modern.txt +1 -1
- package/lib/satisfies/constants.d.ts +16 -0
- package/lib/satisfies/constants.es.js +75 -0
- package/lib/satisfies/constants.js +82 -0
- package/lib/satisfies/is-browser-satisfies-requirements.d.ts +4 -0
- package/lib/satisfies/is-browser-satisfies-requirements.es.js +74 -0
- package/lib/satisfies/is-browser-satisfies-requirements.js +84 -0
- package/lib/satisfies/types.d.ts +6 -0
- package/lib/satisfies/utils/normalizeBrowserslist.d.ts +3 -0
- package/lib/satisfies/utils/normalizeBrowserslist.es.js +42 -0
- package/lib/satisfies/utils/normalizeBrowserslist.js +50 -0
- package/lib/types.d.ts +4 -0
- package/lib/utils/getBrowserEngine.d.ts +9 -0
- package/lib/{utils.es.js → utils/getBrowserEngine.es.js} +14 -18
- package/lib/{utils.js → utils/getBrowserEngine.js} +13 -18
- package/lib/utils/getMobileOs.d.ts +9 -0
- package/lib/utils/getMobileOs.es.js +24 -0
- package/lib/utils/getMobileOs.js +28 -0
- package/package.json +3 -3
- package/lib/client-hints.d.ts +0 -33
- package/lib/client-hints.es.js +0 -177
- package/lib/client-hints.js +0 -182
- package/lib/satisfies.d.ts +0 -8
- package/lib/satisfies.es.js +0 -107
- package/lib/satisfies.js +0 -118
- package/lib/userAgent.d.ts +0 -3
- package/lib/userAgent.es.js +0 -48
- package/lib/userAgent.js +0 -58
- package/lib/utils.d.ts +0 -3
- /package/lib/{isSameSiteNoneCompatible.d.ts → parse-user-agent-header/utils/is-same-site-none-compatible/isSameSiteNoneCompatible.d.ts} +0 -0
- /package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/bots.txt +0 -0
- /package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/not_supported_modern.txt +0 -0
- /package/lib/{__tests__ → satisfies/__tests__}/uaDatasets/unknown.txt +0 -0
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var isString = require('@tinkoff/utils/is/string');
|
|
6
|
+
var browserslistTinkoffConfig = require('@tinkoff/browserslist-config');
|
|
7
|
+
var browserslistFileConfig = require('@tramvai/cli/lib/external/browserslist-normalized-file-config');
|
|
8
|
+
var parseUserAgentHeader = require('../parse-user-agent-header/parseUserAgentHeader.js');
|
|
9
|
+
var constants = require('./constants.js');
|
|
10
|
+
var normalizeBrowserslist = require('./utils/normalizeBrowserslist.js');
|
|
11
|
+
|
|
12
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
13
|
+
|
|
14
|
+
var isString__default = /*#__PURE__*/_interopDefaultLegacy(isString);
|
|
15
|
+
var browserslistTinkoffConfig__default = /*#__PURE__*/_interopDefaultLegacy(browserslistTinkoffConfig);
|
|
16
|
+
var browserslistFileConfig__default = /*#__PURE__*/_interopDefaultLegacy(browserslistFileConfig);
|
|
17
|
+
|
|
18
|
+
/*
|
|
19
|
+
The function isBrowserSatisfiesRequirements checks if a given user agent satisfies the specified
|
|
20
|
+
browser requirements based on a browserslist configuration. It parses the user agent to determine
|
|
21
|
+
the browser and its version, normalizes the browserslist configuration, and compares the browser
|
|
22
|
+
version against the specified requirements. The function returns true if the browser meets the requirements,
|
|
23
|
+
false if it does not, and null if the browser is not found in the browserslist.
|
|
24
|
+
It also handles special cases for Chromium-based browsers and allows forcing the use of minimum requested
|
|
25
|
+
versions for browsers with incomplete statistics.
|
|
26
|
+
*/
|
|
27
|
+
const isBrowserSatisfiesRequirements = (userAgent, browserslistConfig, { env = 'defaults', forceMinimumUnknownVersions = false } = {}) => {
|
|
28
|
+
const ua = isString__default["default"](userAgent) ? parseUserAgentHeader.parseUserAgentHeader(userAgent) : userAgent;
|
|
29
|
+
const { engine: { name: engineName = '', version: engineVersion }, device: { type = '' } = {}, } = ua;
|
|
30
|
+
let { browser: { name: browserName = '', version: browserVersion = '' } = {} } = ua;
|
|
31
|
+
/*
|
|
32
|
+
Chromium based browsers (yandex, samsung, opera, vivaldi, edge) specify the engine version as `Chrome/*'.
|
|
33
|
+
And the engine version (blink) will be converted to the chromium version one-to-one.
|
|
34
|
+
https://github.com/faisalman/ua-parser-js/pull/390
|
|
35
|
+
https://developer.mozilla.org/en-US/docs/Web/HTTP/Browser_detection_using_the_user_agent#Rendering_engine
|
|
36
|
+
*/
|
|
37
|
+
if (engineName === 'chromium' ||
|
|
38
|
+
(engineName.toLowerCase() === 'blink' &&
|
|
39
|
+
constants.CHROMIUM_BASED_BROWSERS.indexOf(browserName.toLowerCase()) !== -1)) {
|
|
40
|
+
browserName = 'chrome';
|
|
41
|
+
browserVersion = engineVersion || '';
|
|
42
|
+
}
|
|
43
|
+
// parseFloat - it will take away the major + minor versions, discard the rest.
|
|
44
|
+
const checkVersion = parseFloat(browserVersion);
|
|
45
|
+
const deviceType = constants.DEVICE_TYPES[type] || type || constants.DEVICE_TYPES.desktop; // по умолчанию считаем устройство десктопом
|
|
46
|
+
if (!browserName) {
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
const targets = browserslistConfig ?? browserslistFileConfig__default["default"][env] ?? browserslistTinkoffConfig__default["default"][env];
|
|
50
|
+
const browsers = normalizeBrowserslist.normalizeBrowserslist(targets);
|
|
51
|
+
// Browsers from query may not be present in https://caniuse.com/usage-table, and browserslist will return higher versions than requested.
|
|
52
|
+
// Example of this problem - https://github.com/babel/babel/issues/8545
|
|
53
|
+
// It is mean, that for this unknown versions babel will not add specific transforms, but still, transpiled code has a chance to work in required old browsers.
|
|
54
|
+
// And if `satisfies` will be used for example for old browser detection, we can force use minimum requested versions instead of minimum from caniuse data.
|
|
55
|
+
if (forceMinimumUnknownVersions) {
|
|
56
|
+
Object.keys(constants.BROWSERS_WITHOUT_COMPLETE_STAT).forEach((browser) => {
|
|
57
|
+
const target = targets.find((query) => query.startsWith(browser));
|
|
58
|
+
// @todo - respect other browserslist query patterns
|
|
59
|
+
if (target && target.includes('>=')) {
|
|
60
|
+
const [targetBrowser, targetMinVersion] = target.split(' >= ');
|
|
61
|
+
// @ts-expect-error
|
|
62
|
+
const browserKey = constants.BROWSERS_WITHOUT_COMPLETE_STAT[targetBrowser];
|
|
63
|
+
const mappedBrowser = constants.BROWSERS_LIST_MAP[browserKey];
|
|
64
|
+
if (mappedBrowser && browsers[mappedBrowser.name]) {
|
|
65
|
+
if (Number(targetMinVersion) < Number(browsers[mappedBrowser.name][mappedBrowser.type])) {
|
|
66
|
+
browsers[mappedBrowser.name][mappedBrowser.type] = Number(targetMinVersion);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
let hasEntry = false;
|
|
73
|
+
if (browserName in browsers) {
|
|
74
|
+
const browserInfo = browsers[browserName];
|
|
75
|
+
const browserInfoVersion = browserInfo.any ?? browserInfo[deviceType];
|
|
76
|
+
hasEntry = !!browserInfoVersion;
|
|
77
|
+
if (checkVersion >= browserInfoVersion) {
|
|
78
|
+
return true;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return hasEntry ? false : null; // null means that we did not find a browser match in the browserslist.
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
exports.isBrowserSatisfiesRequirements = isBrowserSatisfiesRequirements;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import browserslist from 'browserslist';
|
|
2
|
+
import { BROWSERS_LIST_MAP } from '../constants.es.js';
|
|
3
|
+
|
|
4
|
+
const normalizeBrowserslist = (query) => {
|
|
5
|
+
const resolved = browserslist(query, {
|
|
6
|
+
/*
|
|
7
|
+
We set it to true so that the browserslist returns the full list for mobile browsers,
|
|
8
|
+
because by default, due to the fact that `Can I use` stores only the latest version of mobile browsers,
|
|
9
|
+
the browserslist returns only the latest version for mobile devices,
|
|
10
|
+
and so it will map compliance to the desktop version.
|
|
11
|
+
*/
|
|
12
|
+
mobileToDesktop: true,
|
|
13
|
+
})
|
|
14
|
+
/*
|
|
15
|
+
Since ie was removed from the @tinkoff/browserslist-config config, in order to cut off ie,
|
|
16
|
+
we add a dummy version so that the entire function returns false for any version of ie,
|
|
17
|
+
and if the regular ie version was set in the custom config or in the config passed as an argument,
|
|
18
|
+
this dummy version will not affect anything and the custom version will be used.
|
|
19
|
+
*/
|
|
20
|
+
.concat(['ie 999']);
|
|
21
|
+
const result = {};
|
|
22
|
+
for (let i = 0; i < resolved.length; i++) {
|
|
23
|
+
const [name, version] = resolved[i].split(' ');
|
|
24
|
+
if (BROWSERS_LIST_MAP[name]) {
|
|
25
|
+
const { type: mapType, name: mapName } = BROWSERS_LIST_MAP[name];
|
|
26
|
+
const mapVersion = parseFloat(version);
|
|
27
|
+
if (result[mapName]) {
|
|
28
|
+
if (!result[mapName][mapType] || result[mapName][mapType] > mapVersion) {
|
|
29
|
+
result[mapName][mapType] = mapVersion;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
result[mapName] = {
|
|
34
|
+
[mapType]: mapVersion,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return result;
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export { normalizeBrowserslist };
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var browserslist = require('browserslist');
|
|
6
|
+
var constants = require('../constants.js');
|
|
7
|
+
|
|
8
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
9
|
+
|
|
10
|
+
var browserslist__default = /*#__PURE__*/_interopDefaultLegacy(browserslist);
|
|
11
|
+
|
|
12
|
+
const normalizeBrowserslist = (query) => {
|
|
13
|
+
const resolved = browserslist__default["default"](query, {
|
|
14
|
+
/*
|
|
15
|
+
We set it to true so that the browserslist returns the full list for mobile browsers,
|
|
16
|
+
because by default, due to the fact that `Can I use` stores only the latest version of mobile browsers,
|
|
17
|
+
the browserslist returns only the latest version for mobile devices,
|
|
18
|
+
and so it will map compliance to the desktop version.
|
|
19
|
+
*/
|
|
20
|
+
mobileToDesktop: true,
|
|
21
|
+
})
|
|
22
|
+
/*
|
|
23
|
+
Since ie was removed from the @tinkoff/browserslist-config config, in order to cut off ie,
|
|
24
|
+
we add a dummy version so that the entire function returns false for any version of ie,
|
|
25
|
+
and if the regular ie version was set in the custom config or in the config passed as an argument,
|
|
26
|
+
this dummy version will not affect anything and the custom version will be used.
|
|
27
|
+
*/
|
|
28
|
+
.concat(['ie 999']);
|
|
29
|
+
const result = {};
|
|
30
|
+
for (let i = 0; i < resolved.length; i++) {
|
|
31
|
+
const [name, version] = resolved[i].split(' ');
|
|
32
|
+
if (constants.BROWSERS_LIST_MAP[name]) {
|
|
33
|
+
const { type: mapType, name: mapName } = constants.BROWSERS_LIST_MAP[name];
|
|
34
|
+
const mapVersion = parseFloat(version);
|
|
35
|
+
if (result[mapName]) {
|
|
36
|
+
if (!result[mapName][mapType] || result[mapName][mapType] > mapVersion) {
|
|
37
|
+
result[mapName][mapType] = mapVersion;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
result[mapName] = {
|
|
42
|
+
[mapType]: mapVersion,
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return result;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
exports.normalizeBrowserslist = normalizeBrowserslist;
|
package/lib/types.d.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { BrowserEngine, DeviceType, MobileOs } from './constants';
|
|
2
|
+
export type BrowserEngineType = (typeof BrowserEngine)[keyof typeof BrowserEngine];
|
|
1
3
|
export interface Browser {
|
|
2
4
|
name: string | undefined;
|
|
3
5
|
/**
|
|
@@ -18,6 +20,7 @@ export interface Engine {
|
|
|
18
20
|
name: string | undefined;
|
|
19
21
|
version: string | undefined;
|
|
20
22
|
}
|
|
23
|
+
export type DeviceType = (typeof DeviceType)[keyof typeof DeviceType];
|
|
21
24
|
export interface Device {
|
|
22
25
|
/**
|
|
23
26
|
* Device type may be undefined in various cases.
|
|
@@ -37,6 +40,7 @@ export interface OS {
|
|
|
37
40
|
export interface Cpu {
|
|
38
41
|
architecture: string | undefined;
|
|
39
42
|
}
|
|
43
|
+
export type MobileOs = (typeof MobileOs)[keyof typeof MobileOs];
|
|
40
44
|
export interface UserAgent {
|
|
41
45
|
browser: Browser;
|
|
42
46
|
engine: Engine;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Possible values :
|
|
3
|
+
* firefox, safari, chrome, other
|
|
4
|
+
*
|
|
5
|
+
* The return type here should be BrowserEngine, not string,
|
|
6
|
+
* but we are not changing it to maintain backward compatibility.
|
|
7
|
+
*/
|
|
8
|
+
export declare const getBrowserEngine: (browserName?: string, engineName?: string) => string;
|
|
9
|
+
//# sourceMappingURL=getBrowserEngine.d.ts.map
|
|
@@ -1,32 +1,28 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
case 'RIM Tablet OS':
|
|
11
|
-
return 'blackberry';
|
|
12
|
-
}
|
|
13
|
-
};
|
|
1
|
+
import { BrowserEngine } from '../constants.es.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Possible values :
|
|
5
|
+
* firefox, safari, chrome, other
|
|
6
|
+
*
|
|
7
|
+
* The return type here should be BrowserEngine, not string,
|
|
8
|
+
* but we are not changing it to maintain backward compatibility.
|
|
9
|
+
*/
|
|
14
10
|
const getBrowserEngine = (browserName, engineName) => {
|
|
15
11
|
switch (true) {
|
|
16
12
|
case browserName === 'firefox':
|
|
17
|
-
return
|
|
13
|
+
return BrowserEngine.firefox;
|
|
18
14
|
// If an `engineName` is webkit, and it's not Safari,
|
|
19
15
|
// then define the `browserName` as `safari`, because all browsers
|
|
20
16
|
// on iOS use webkit. Also, we are not handling mobile Safari separately,
|
|
21
17
|
// as it webkit too. See https://en.wikipedia.org/wiki/WebKit
|
|
22
18
|
case browserName === 'safari' || browserName === 'mobile safari' || engineName === 'webkit':
|
|
23
|
-
return
|
|
19
|
+
return BrowserEngine.safari;
|
|
24
20
|
// We aren't using something like `browserName === 'chrome'` here,
|
|
25
21
|
// because there are a lot of browsers based on chromium.
|
|
26
22
|
case engineName === 'blink' || engineName === 'chromium':
|
|
27
|
-
return
|
|
23
|
+
return BrowserEngine.chrome;
|
|
28
24
|
}
|
|
29
|
-
return
|
|
25
|
+
return BrowserEngine.other;
|
|
30
26
|
};
|
|
31
27
|
|
|
32
|
-
export { getBrowserEngine
|
|
28
|
+
export { getBrowserEngine };
|
|
@@ -2,36 +2,31 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
case 'RIM Tablet OS':
|
|
15
|
-
return 'blackberry';
|
|
16
|
-
}
|
|
17
|
-
};
|
|
5
|
+
var constants = require('../constants.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Possible values :
|
|
9
|
+
* firefox, safari, chrome, other
|
|
10
|
+
*
|
|
11
|
+
* The return type here should be BrowserEngine, not string,
|
|
12
|
+
* but we are not changing it to maintain backward compatibility.
|
|
13
|
+
*/
|
|
18
14
|
const getBrowserEngine = (browserName, engineName) => {
|
|
19
15
|
switch (true) {
|
|
20
16
|
case browserName === 'firefox':
|
|
21
|
-
return
|
|
17
|
+
return constants.BrowserEngine.firefox;
|
|
22
18
|
// If an `engineName` is webkit, and it's not Safari,
|
|
23
19
|
// then define the `browserName` as `safari`, because all browsers
|
|
24
20
|
// on iOS use webkit. Also, we are not handling mobile Safari separately,
|
|
25
21
|
// as it webkit too. See https://en.wikipedia.org/wiki/WebKit
|
|
26
22
|
case browserName === 'safari' || browserName === 'mobile safari' || engineName === 'webkit':
|
|
27
|
-
return
|
|
23
|
+
return constants.BrowserEngine.safari;
|
|
28
24
|
// We aren't using something like `browserName === 'chrome'` here,
|
|
29
25
|
// because there are a lot of browsers based on chromium.
|
|
30
26
|
case engineName === 'blink' || engineName === 'chromium':
|
|
31
|
-
return
|
|
27
|
+
return constants.BrowserEngine.chrome;
|
|
32
28
|
}
|
|
33
|
-
return
|
|
29
|
+
return constants.BrowserEngine.other;
|
|
34
30
|
};
|
|
35
31
|
|
|
36
32
|
exports.getBrowserEngine = getBrowserEngine;
|
|
37
|
-
exports.getMobileOs = getMobileOs;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Possible values:
|
|
3
|
+
* winphone, android, ios, blackberry
|
|
4
|
+
*
|
|
5
|
+
* The return type here should be MobileOs, not string | undefined,
|
|
6
|
+
* but we are not changing it to maintain backward compatibility.
|
|
7
|
+
*/
|
|
8
|
+
export declare const getMobileOs: (osName?: string) => string | undefined;
|
|
9
|
+
//# sourceMappingURL=getMobileOs.d.ts.map
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { MobileOs } from '../constants.es.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Possible values:
|
|
5
|
+
* winphone, android, ios, blackberry
|
|
6
|
+
*
|
|
7
|
+
* The return type here should be MobileOs, not string | undefined,
|
|
8
|
+
* but we are not changing it to maintain backward compatibility.
|
|
9
|
+
*/
|
|
10
|
+
const getMobileOs = (osName) => {
|
|
11
|
+
switch (osName) {
|
|
12
|
+
case 'Windows Phone':
|
|
13
|
+
return MobileOs.winphone;
|
|
14
|
+
case 'Android':
|
|
15
|
+
return MobileOs.android;
|
|
16
|
+
case 'iOS':
|
|
17
|
+
return MobileOs.ios;
|
|
18
|
+
case 'BlackBerry':
|
|
19
|
+
case 'RIM Tablet OS':
|
|
20
|
+
return MobileOs.blackberry;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export { getMobileOs };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var constants = require('../constants.js');
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Possible values:
|
|
9
|
+
* winphone, android, ios, blackberry
|
|
10
|
+
*
|
|
11
|
+
* The return type here should be MobileOs, not string | undefined,
|
|
12
|
+
* but we are not changing it to maintain backward compatibility.
|
|
13
|
+
*/
|
|
14
|
+
const getMobileOs = (osName) => {
|
|
15
|
+
switch (osName) {
|
|
16
|
+
case 'Windows Phone':
|
|
17
|
+
return constants.MobileOs.winphone;
|
|
18
|
+
case 'Android':
|
|
19
|
+
return constants.MobileOs.android;
|
|
20
|
+
case 'iOS':
|
|
21
|
+
return constants.MobileOs.ios;
|
|
22
|
+
case 'BlackBerry':
|
|
23
|
+
case 'RIM Tablet OS':
|
|
24
|
+
return constants.MobileOs.blackberry;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
exports.getMobileOs = getMobileOs;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tinkoff/user-agent",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.8.102",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"module": "lib/index.es.js",
|
|
@@ -18,7 +18,7 @@
|
|
|
18
18
|
"watch": "tsc -w"
|
|
19
19
|
},
|
|
20
20
|
"dependencies": {
|
|
21
|
-
"@tinkoff/browserslist-config": "0.
|
|
21
|
+
"@tinkoff/browserslist-config": "0.6.2",
|
|
22
22
|
"@tinkoff/utils": "^2.1.2",
|
|
23
23
|
"browserslist": "^4.16.7",
|
|
24
24
|
"tslib": "^2.4.0",
|
|
@@ -29,7 +29,7 @@
|
|
|
29
29
|
"user-agent-data-types": "^0.3.1"
|
|
30
30
|
},
|
|
31
31
|
"peerDependencies": {
|
|
32
|
-
"@tramvai/cli": "
|
|
32
|
+
"@tramvai/cli": "6.59.0",
|
|
33
33
|
"@types/ua-parser-js": "^0.7.33"
|
|
34
34
|
},
|
|
35
35
|
"license": "Apache-2.0"
|
package/lib/client-hints.d.ts
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
import type { UserAgent } from './types';
|
|
2
|
-
/**
|
|
3
|
-
*
|
|
4
|
-
* @description
|
|
5
|
-
*
|
|
6
|
-
* Some of the data are available only when additional headers for client-hints were sent from server:
|
|
7
|
-
* - full browser version (only major version is available by default)
|
|
8
|
-
* - OS version
|
|
9
|
-
* - CPU architecture
|
|
10
|
-
* - device model
|
|
11
|
-
*
|
|
12
|
-
* To be able to use data you should first provide header `Accept-CH` with the list of headers that client should send.
|
|
13
|
-
*
|
|
14
|
-
* @param headers
|
|
15
|
-
* @returns
|
|
16
|
-
*/
|
|
17
|
-
export declare const parseClientHintsHeaders: (headers: Record<string, string | string[] | undefined>) => UserAgent;
|
|
18
|
-
/**
|
|
19
|
-
*
|
|
20
|
-
* @description
|
|
21
|
-
* Some of the data will be available if `UADataValues` were gotten from
|
|
22
|
-
* `getHighEntropyValues` async method, but it's not suitable for all cases.
|
|
23
|
-
*
|
|
24
|
-
* @see https://developer.mozilla.org/en-US/docs/Web/API/User-Agent_Client_Hints_API
|
|
25
|
-
* @see https://wicg.github.io/ua-client-hints/#http-ua-hints
|
|
26
|
-
*
|
|
27
|
-
* @param payload
|
|
28
|
-
*
|
|
29
|
-
* @example
|
|
30
|
-
* const clientHints = parseClientHintsUserAgentData(window.navigator.userAgentData)
|
|
31
|
-
*/
|
|
32
|
-
export declare const parseClientHintsUserAgentData: (payload: UADataValues) => UserAgent;
|
|
33
|
-
//# sourceMappingURL=client-hints.d.ts.map
|
package/lib/client-hints.es.js
DELETED
|
@@ -1,177 +0,0 @@
|
|
|
1
|
-
import { getMobileOs, getBrowserEngine } from './utils.es.js';
|
|
2
|
-
|
|
3
|
-
const KNOWN_VENDORS = new Set(['Opera', 'Google Chrome', 'Microsoft Edge', 'Firefox', 'Safari']);
|
|
4
|
-
const KNOWN_ENGINES = new Set(['Chromium']);
|
|
5
|
-
const BACKWARD_COMPATIBILITY_BROWSER_NAME = {
|
|
6
|
-
'Google Chrome': 'chrome',
|
|
7
|
-
'Microsoft Edge': 'edge',
|
|
8
|
-
};
|
|
9
|
-
const BACKWARD_COMPATIBILITY_ENGINE_NAME = {
|
|
10
|
-
Chromium: 'Blink',
|
|
11
|
-
};
|
|
12
|
-
const BACKWARD_COMPATIBILITY_ARCH = {
|
|
13
|
-
x86: 'amd64',
|
|
14
|
-
};
|
|
15
|
-
const BACKWARD_COMPATIBILITY_OS_NAME = {
|
|
16
|
-
macOS: 'Mac OS',
|
|
17
|
-
};
|
|
18
|
-
const parseQuotedString = (str) => {
|
|
19
|
-
if (!str) {
|
|
20
|
-
return str;
|
|
21
|
-
}
|
|
22
|
-
try {
|
|
23
|
-
return JSON.parse(str)?.trim();
|
|
24
|
-
}
|
|
25
|
-
catch (err) {
|
|
26
|
-
return str;
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
const parseBrowserFromString = (brandsList) => {
|
|
30
|
-
const browser = {
|
|
31
|
-
name: undefined,
|
|
32
|
-
version: undefined,
|
|
33
|
-
major: undefined,
|
|
34
|
-
browserEngine: '',
|
|
35
|
-
};
|
|
36
|
-
const engine = {
|
|
37
|
-
name: undefined,
|
|
38
|
-
version: undefined,
|
|
39
|
-
};
|
|
40
|
-
brandsList.split(',').forEach((entry) => {
|
|
41
|
-
const [name, version] = entry.split(/;\s*v=/).map(parseQuotedString);
|
|
42
|
-
if (name && KNOWN_VENDORS.has(name)) {
|
|
43
|
-
browser.name = BACKWARD_COMPATIBILITY_BROWSER_NAME[name] ?? name.toLowerCase();
|
|
44
|
-
browser.version = version;
|
|
45
|
-
browser.major = version;
|
|
46
|
-
}
|
|
47
|
-
if (name && KNOWN_ENGINES.has(name)) {
|
|
48
|
-
engine.name = BACKWARD_COMPATIBILITY_ENGINE_NAME[name] ?? name.toLowerCase();
|
|
49
|
-
engine.version = version;
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
if (!browser.name && engine.name) {
|
|
53
|
-
browser.name = engine.name;
|
|
54
|
-
browser.version = engine.version;
|
|
55
|
-
}
|
|
56
|
-
browser.browserEngine = getBrowserEngine(browser.name?.toLowerCase(), engine.name?.toLowerCase());
|
|
57
|
-
return { browser, engine };
|
|
58
|
-
};
|
|
59
|
-
const parseBrowserFromUserAgentData = (brands) => {
|
|
60
|
-
const browser = {
|
|
61
|
-
name: undefined,
|
|
62
|
-
version: undefined,
|
|
63
|
-
major: undefined,
|
|
64
|
-
browserEngine: '',
|
|
65
|
-
};
|
|
66
|
-
const engine = {
|
|
67
|
-
name: undefined,
|
|
68
|
-
version: undefined,
|
|
69
|
-
};
|
|
70
|
-
brands.forEach(({ brand, version }) => {
|
|
71
|
-
if (KNOWN_VENDORS.has(brand)) {
|
|
72
|
-
browser.name = BACKWARD_COMPATIBILITY_BROWSER_NAME[brand] ?? brand.toLowerCase();
|
|
73
|
-
browser.version = version;
|
|
74
|
-
[browser.major] = version.split('.');
|
|
75
|
-
}
|
|
76
|
-
if (KNOWN_ENGINES.has(brand)) {
|
|
77
|
-
engine.name = BACKWARD_COMPATIBILITY_ENGINE_NAME[brand] ?? brand.toLowerCase();
|
|
78
|
-
engine.version = version;
|
|
79
|
-
}
|
|
80
|
-
});
|
|
81
|
-
if (!browser.name && engine.name) {
|
|
82
|
-
browser.name = engine.name;
|
|
83
|
-
browser.version = engine.version;
|
|
84
|
-
}
|
|
85
|
-
browser.browserEngine = getBrowserEngine(browser.name?.toLowerCase(), engine.name?.toLowerCase());
|
|
86
|
-
return { browser, engine };
|
|
87
|
-
};
|
|
88
|
-
const getBackwardCompatibleOsName = (payload) => {
|
|
89
|
-
if (payload === undefined) {
|
|
90
|
-
return undefined;
|
|
91
|
-
}
|
|
92
|
-
return BACKWARD_COMPATIBILITY_OS_NAME[payload] ?? payload;
|
|
93
|
-
};
|
|
94
|
-
/**
|
|
95
|
-
*
|
|
96
|
-
* @description
|
|
97
|
-
*
|
|
98
|
-
* Some of the data are available only when additional headers for client-hints were sent from server:
|
|
99
|
-
* - full browser version (only major version is available by default)
|
|
100
|
-
* - OS version
|
|
101
|
-
* - CPU architecture
|
|
102
|
-
* - device model
|
|
103
|
-
*
|
|
104
|
-
* To be able to use data you should first provide header `Accept-CH` with the list of headers that client should send.
|
|
105
|
-
*
|
|
106
|
-
* @param headers
|
|
107
|
-
* @returns
|
|
108
|
-
*/
|
|
109
|
-
const parseClientHintsHeaders = (headers) => {
|
|
110
|
-
const { browser, engine } = parseBrowserFromString(headers['sec-ch-ua-full-version-list'] || headers['sec-ch-ua']);
|
|
111
|
-
const osName = parseQuotedString(headers['sec-ch-ua-platform']);
|
|
112
|
-
const mobileOS = getMobileOs(osName);
|
|
113
|
-
const architecture = parseQuotedString(headers['sec-ch-ua-arch']);
|
|
114
|
-
return {
|
|
115
|
-
browser,
|
|
116
|
-
engine,
|
|
117
|
-
os: {
|
|
118
|
-
name: getBackwardCompatibleOsName(osName),
|
|
119
|
-
version: parseQuotedString(headers['sec-ch-ua-platform-version']),
|
|
120
|
-
},
|
|
121
|
-
cpu: {
|
|
122
|
-
architecture: architecture
|
|
123
|
-
? (BACKWARD_COMPATIBILITY_ARCH[architecture] ?? architecture)
|
|
124
|
-
: architecture,
|
|
125
|
-
},
|
|
126
|
-
mobileOS,
|
|
127
|
-
device: {
|
|
128
|
-
model: parseQuotedString(headers['sec-ch-ua-model']),
|
|
129
|
-
type: headers['sec-ch-ua-mobile'] === '?1' ? 'mobile' : 'desktop',
|
|
130
|
-
vendor: undefined,
|
|
131
|
-
},
|
|
132
|
-
// basically all the browsers with client-hints support
|
|
133
|
-
// also compatible with SameSite=None
|
|
134
|
-
sameSiteNoneCompatible: true,
|
|
135
|
-
};
|
|
136
|
-
};
|
|
137
|
-
/**
|
|
138
|
-
*
|
|
139
|
-
* @description
|
|
140
|
-
* Some of the data will be available if `UADataValues` were gotten from
|
|
141
|
-
* `getHighEntropyValues` async method, but it's not suitable for all cases.
|
|
142
|
-
*
|
|
143
|
-
* @see https://developer.mozilla.org/en-US/docs/Web/API/User-Agent_Client_Hints_API
|
|
144
|
-
* @see https://wicg.github.io/ua-client-hints/#http-ua-hints
|
|
145
|
-
*
|
|
146
|
-
* @param payload
|
|
147
|
-
*
|
|
148
|
-
* @example
|
|
149
|
-
* const clientHints = parseClientHintsUserAgentData(window.navigator.userAgentData)
|
|
150
|
-
*/
|
|
151
|
-
const parseClientHintsUserAgentData = (payload) => {
|
|
152
|
-
const { browser, engine } = parseBrowserFromUserAgentData(payload.fullVersionList || payload.brands || []);
|
|
153
|
-
return {
|
|
154
|
-
browser,
|
|
155
|
-
engine,
|
|
156
|
-
os: {
|
|
157
|
-
name: getBackwardCompatibleOsName(payload.platform),
|
|
158
|
-
version: payload.platformVersion,
|
|
159
|
-
},
|
|
160
|
-
cpu: {
|
|
161
|
-
architecture: payload.architecture
|
|
162
|
-
? (BACKWARD_COMPATIBILITY_ARCH[payload.architecture] ?? payload.architecture)
|
|
163
|
-
: payload.architecture,
|
|
164
|
-
},
|
|
165
|
-
mobileOS: getMobileOs(payload.platform),
|
|
166
|
-
device: {
|
|
167
|
-
model: payload.model,
|
|
168
|
-
type: payload.mobile ? 'mobile' : 'desktop',
|
|
169
|
-
vendor: undefined,
|
|
170
|
-
},
|
|
171
|
-
// basically all the browsers with client-hints support
|
|
172
|
-
// also compatible with SameSite=None
|
|
173
|
-
sameSiteNoneCompatible: true,
|
|
174
|
-
};
|
|
175
|
-
};
|
|
176
|
-
|
|
177
|
-
export { parseClientHintsHeaders, parseClientHintsUserAgentData };
|