diff --git a/CHANGELOG.md b/CHANGELOG.md index 2a28e74..81ca94c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,8 @@ # Bowser Changelog +### 1.7.0 (May 18, 2017) +- [ADD] Add OS version support for Windows and macOS (#178) + ### 1.6.0 (December 5, 2016) - [ADD] Add some tests for Windows devices (#89) - [ADD] Add `root` to initialization process (#170) diff --git a/README.md b/README.md index 0493b44..875a36b 100644 --- a/README.md +++ b/README.md @@ -155,7 +155,7 @@ If detected, one of these flags may be set to true: `osversion` may also be set: - * `osversion` - for Android, iOS, Windows Phone, WebOS, Bada, and Tizen. If included in UA string. + * `osversion` - for Android, iOS, MacOS, Windows, Windows Phone, WebOS, Bada, and Tizen. If included in UA string. iOS is always reported as `ios` and additionally as `iphone`/`ipad`/`ipod`, whichever one matches best. If WebOS device is an HP TouchPad the flag `touchpad` is additionally set. diff --git a/bower.json b/bower.json index 7003014..80a0983 100644 --- a/bower.json +++ b/bower.json @@ -1,19 +1,24 @@ { "name": "bowser", - "description": "a browser detector", + "description": "Lightweight browser detector", "keywords": [ - "ender", "browser", - "sniff", - "detection" + "useragent", + "user-agent", + "parser", + "ua", + "detection", + "ender", + "sniff" ], - "version": "1.6.0", - "homepage": "https://github.com/ded/bowser", + "version": "1.7.0", + "homepage": "https://github.com/lancedikson/bowser", "scripts": [ "src/bowser.js" ], "authors": [ - "Dustin Diaz (http://dustindiaz.com)" + "Dustin Diaz (http://dustindiaz.com)", + "Denis Demchenko " ], "moduleType": [], "license": "MIT", diff --git a/package.json b/package.json index 39d5139..ed15f3b 100644 --- a/package.json +++ b/package.json @@ -1,14 +1,18 @@ { "name": "bowser", - "description": "a browser detector", + "version": "1.7.0", + "description": "Lightweight browser detector", "keywords": [ - "ender", "browser", - "sniff", - "detection" + "useragent", + "user-agent", + "parser", + "ua", + "detection", + "ender", + "sniff" ], - "version": "1.6.0", - "homepage": "https://github.com/ded/bowser", + "homepage": "https://github.com/lancedikson/bowser", "author": "Dustin Diaz (http://dustindiaz.com)", "main": "./src/bowser.js", "typings": "./typings.d.ts", diff --git a/src/bowser.js b/src/bowser.js index e6b27e1..17962c2 100644 --- a/src/bowser.js +++ b/src/bowser.js @@ -336,10 +336,31 @@ result.linux = t } + function getWindowsVersion (s) { + switch (s) { + case 'NT': return 'NT' + case 'XP': return 'XP' + case 'NT 5.0': return '2000' + case 'NT 5.1': return 'XP' + case 'NT 5.2': return '2003' + case 'NT 6.0': return 'Vista' + case 'NT 6.1': return '7' + case 'NT 6.2': return '8' + case 'NT 6.3': return '8.1' + case 'NT 10.0': return '10' + default: return undefined + } + } + // OS version extraction var osVersion = ''; - if (result.windowsphone) { + if (result.windows) { + osVersion = getWindowsVersion(getFirstMatch(/Windows ((NT|XP)( \d\d?.\d)?)/i)) + } else if (result.windowsphone) { osVersion = getFirstMatch(/windows phone (?:os)?\s?(\d+(\.\d+)*)/i); + } else if (result.mac) { + osVersion = getFirstMatch(/Mac OS X (\d+([_\.\s]\d+)*)/i); + osVersion = osVersion.replace(/[_\s]/g, '.'); } else if (iosdevice) { osVersion = getFirstMatch(/os (\d+([_\s]\d+)*) like mac os x/i); osVersion = osVersion.replace(/[_\s]/g, '.'); @@ -359,7 +380,7 @@ } // device type extraction - var osMajorVersion = osVersion.split('.')[0]; + var osMajorVersion = !result.windows && osVersion.split('.')[0]; if ( tablet || nexusTablet diff --git a/src/useragents.js b/src/useragents.js index 7e6faf2..719b7a0 100644 --- a/src/useragents.js +++ b/src/useragents.js @@ -85,6 +85,7 @@ module.exports.useragents = { chrome: true , version: '30.0' , windows: true + , osversion: '8' , blink: true , a: true } @@ -92,6 +93,7 @@ module.exports.useragents = { chrome: true , version: '29.0' , windows: true + , osversion: '7' , blink: true , a: true } @@ -107,6 +109,7 @@ module.exports.useragents = { chrome: true , version: '29.0' , windows: true + , osversion: '8' , blink: true , a: true } @@ -114,6 +117,7 @@ module.exports.useragents = { chrome: true , version: '28.0' , windows: true + , osversion: '7' , blink: true , a: true } @@ -121,6 +125,7 @@ module.exports.useragents = { chrome: true , version: '11.0' , mac: true + , osversion: '10.6.7' , webkit: true , c: true } @@ -222,6 +227,7 @@ module.exports.useragents = { , 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/28.0.1500.52 Safari/537.36 OPR/15.0.1147.100': { opera: true , windows: true + , osversion: '7' , blink: true , version: '15.0' , a: true @@ -246,24 +252,28 @@ module.exports.useragents = { opera: true , version: '12.14' , windows: true + , osversion: 'Vista' , a: true } , 'Mozilla/5.0 (Windows NT 6.0; rv:2.0) Gecko/20100101 Firefox/4.0 Opera 12.14': { opera: true , version: '12.14' , windows: true + , osversion: 'Vista' , a: true } , 'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.0) Opera 12.14': { opera: true , version: '12.14' , windows: true + , osversion: 'Vista' , a: true } , 'Opera/12.80 (Windows NT 5.1; U; en) Presto/2.10.289 Version/12.02': { opera: true , version: '12.02' , windows: true + , osversion: 'XP' , a: true } , 'Opera/9.80 (X11; Linux i686; U; es-ES) Presto/2.8.131 Version/11.11': { @@ -276,12 +286,14 @@ module.exports.useragents = { opera: true , version: '11.01' , mac: true + , osversion: '10.6.7' , a: true } , 'Opera/9.80 (Windows NT 5.2; U; zh-cn) Presto/2.6.30 Version/10.63': { opera: true , version: '10.63' , windows: true + , osversion: '2003' , a: true } , 'Opera/9.80 (X11; Linux i686; U; it) Presto/2.5.24 Version/10.54': { @@ -346,6 +358,7 @@ module.exports.useragents = { , blink: true , version: '15.4' , mac: true + , osversion: '10.10.3' , a: true }, 'Mozilla/5.0 (Linux; Android 5.1.1; Nexus 5 Build/LMY48B) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 YaBrowser/15.4.2272.3608.00 Mobile Safari/537.36': { @@ -363,6 +376,7 @@ module.exports.useragents = { safari: true , version: '5.1' , mac: true + , osversion: '10.6.8' , webkit: true , c: true } @@ -370,6 +384,7 @@ module.exports.useragents = { safari: true , version: '5.0' , mac: true + , osversion: '10.6.7' , webkit: true , c: true } @@ -377,6 +392,7 @@ module.exports.useragents = { safari: true , version: '5.0' , windows: true + , osversion: 'XP' , webkit: true , c: true } @@ -391,6 +407,7 @@ module.exports.useragents = { safari: true , version: '4.1' , windows: true + , osversion: '2000' , webkit: true , c: true } @@ -398,6 +415,7 @@ module.exports.useragents = { safari: true , version: '4.0' , mac: true + , osversion: '10.6.1' , webkit: true , c: true } @@ -405,6 +423,7 @@ module.exports.useragents = { safari: true , version: '3.2' , mac: true + , osversion: '10.5.7' , webkit: true , c: true } @@ -575,72 +594,84 @@ module.exports.useragents = { msie: true , version: '11.0' , windows: true + , osversion: '8.1' , a: true } , 'Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; Touch; rv:11.0) like Gecko': { msie: true , version: '11.0' , windows: true + , osversion: '8.1' , a: true } , 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0; ARM; Touch; WPDesktop)': { msie: true , version: '10.0' , windows: true + , osversion: '8' , a: true } , 'Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; .NET4.0E; .NET4.0C; Media Center PC 6.0; rv:11.0) like Gecko': { msie: true , version: '11.0' , windows: true + , osversion: '8.1' , a: true } , 'Mozilla/5.0 (compatible; MSIE 10.6; Windows NT 6.1; Trident/5.0; InfoPath.2; SLCC1; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET CLR 2.0.50727) 3gpp-gba UNTRUSTED/1.0': { msie: true , version: '10.6' , windows: true + , osversion: '7' , a: true } , 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; Trident/4.0; InfoPath.2; SV1; .NET CLR 2.0.50727; WOW64)': { msie: true , version: '10.0' , windows: true + , osversion: '7' , a: true } , 'Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET CLR 2.0.50727; Media Center PC 6.0)': { msie: true , version: '9.0' , windows: true + , osversion: '7' , c: true } , 'Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/5.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C)': { msie: true , version: '8.0' , windows: true + , osversion: '7' , c: true } , 'Mozilla/4.0 (compatible; MSIE 7.0b; Windows NT 5.1; .NET CLR 1.1.4322; InfoPath.1; .NET CLR 2.0.50727)': { msie: true , version: '7.0' , windows: true + , osversion: 'XP' , c: true } , 'Mozilla/4.0 (compatible; MSIE 6.1; Windows XP; .NET CLR 1.1.4322; .NET CLR 2.0.50727)': { msie: true , version: '6.1' , windows: true + , osversion: 'XP' , c: true } , 'Mozilla/4.0 (Compatible; Windows NT 5.1; MSIE 6.0) (compatible; MSIE 6.0; Windows NT 5.1; .NET CLR 1.1.4322; .NET CLR 2.0.50727)': { msie: true , version: '6.0' , windows: true + , osversion: 'XP' , c: true } , 'Mozilla/4.0 (compatible; MSIE 5.01; Windows NT)': { msie: true , version: '5.01' , windows: true + , osversion: 'NT' , c: true } , 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0; Xbox; Xbox One)': { @@ -654,12 +685,14 @@ module.exports.useragents = { , version: '11.0' , a: true , windows: true + , osversion: '8.1' } , 'Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; Touch; LCTE; rv:11.0)': { msie: true , version: '11.0' , a: true , windows: true + , osversion: '10' } } , 'Microsoft Edge': { @@ -667,6 +700,7 @@ module.exports.useragents = { msedge: true , version: '12.0' , windows: true + , osversion: '10' , a: true } } @@ -716,6 +750,7 @@ module.exports.useragents = { , firefox: true , version: '25.0' , windows: true + , osversion: '7' , a: true } , 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:24.0) Gecko/20100101 Firefox/24.0': { @@ -723,6 +758,7 @@ module.exports.useragents = { , firefox: true , version: '24.0' , mac: true + , osversion: '10.8' , a: true } , 'Mozilla/5.0 (X11; Linux i686; rv:21.0) Gecko/20100101 Firefox/21.0': { @@ -751,6 +787,7 @@ module.exports.useragents = { , firefox: true , version: '15.0' , windows: true + , osversion: '8' , c: true } , 'Mozilla/5.0 (Windows; U; Windows NT 6.1; WOW64; en-US; rv:2.0.4) Gecko/20120718 AskTbAVR-IDW/3.12.5.17700 Firefox/14.0.1': { @@ -758,6 +795,7 @@ module.exports.useragents = { , firefox: true , version: '14.0' , windows: true + , osversion: '7' , c: true } , 'Mozilla/5.0 (Windows NT 5.1; rv:6.0) Gecko/20100101 Firefox/6.0 FirePHP/0.6': { @@ -765,6 +803,7 @@ module.exports.useragents = { , firefox: true , version: '6.0' , windows: true + , osversion: 'XP' , c: true } , 'Mozilla/5.0 (X11; Linux x86_64; rv:2.2a1pre) Gecko/20100101 Firefox/4.2a1pre': { @@ -779,6 +818,7 @@ module.exports.useragents = { , firefox: true , version: '4.0' , mac: true + , osversion: '10.6' , c: true } , 'Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US; rv:1.9.2b1) Gecko/20091014 Firefox/3.6b1 GTB5': { @@ -786,6 +826,7 @@ module.exports.useragents = { , firefox: true , version: '3.6' , windows: true + , osversion: '7' , c: true } , 'Mozilla/5.0 (Windows; U; Windows NT 6.0; de; rv:1.9.0.15) Gecko/2009101601 Firefox 2.1 (.NET CLR 3.5.30729)': { @@ -793,6 +834,7 @@ module.exports.useragents = { , firefox: true , version: '2.1' , windows: true + , osversion: 'Vista' , c: true } , 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.8.0.7) Gecko/20061014 Firefox/1.5.0.7': { @@ -819,6 +861,7 @@ module.exports.useragents = { , seamonkey: true , version: '2.7' , windows: true + , osversion: '2003' , x: true } , 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10.5; rv:10.0.1) Gecko/20100101 Firefox/10.0.1 SeaMonkey/2.7.1': { @@ -826,6 +869,7 @@ module.exports.useragents = { , seamonkey: true , version: '2.7' , mac: true + , osversion: '10.5' , x: true } , 'Mozilla/5.0 (X11; Linux i686; rv:10.0.1) Gecko/20100101 Firefox/10.0.1 SeaMonkey/2.7.1': { @@ -1159,6 +1203,7 @@ module.exports.useragents = { vivaldi: true , version: '1.0' , mac: true + , osversion: '10.11.1' , blink: true , a: true }, @@ -1166,6 +1211,7 @@ module.exports.useragents = { vivaldi: true , version: '1.0' , windows: true + , osversion: '10' , blink: true , a: true } @@ -1225,6 +1271,7 @@ module.exports.useragents = { }, 'Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.21 (KHTML, like Gecko) QupZilla/1.8.6 Safari/537.21': { windows: true, + osversion: '8', qupzilla: true, version: '1.8.6', webkit: true, @@ -1265,6 +1312,7 @@ module.exports.useragents = { sleipnir: true , blink: true , windows: true + , osversion: '7' , x: true , version: '6.1.4' } @@ -1272,6 +1320,7 @@ module.exports.useragents = { , 'K-Meleon': { 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:24.0) Gecko/20140105 Firefox/24.0 K-Meleon/74.0': { windows: true + , osversion: '7' , kMeleon: true , version: '74.0' , gecko: true