X-Git-Url: https://git-public.kairo.at/?p=php-utility-classes.git;a=blobdiff_plain;f=include%2Fclasses%2Fuseragent.php-class;h=2aa2ddc08fbec5dc6af9ad34f59bb4cd5cc604f8;hp=840a3987bf29af50b9b0dc8dd6c254eac3b36493;hb=44bed2e1b6c17f6f32c0303e1e6a7928ab476b7b;hpb=4e8c44da4b14508bb68da58c20d00e2fc887846d diff --git a/include/classes/useragent.php-class b/include/classes/useragent.php-class index 840a398..2aa2ddc 100755 --- a/include/classes/useragent.php-class +++ b/include/classes/useragent.php-class @@ -135,21 +135,23 @@ class userAgent { // get UA brand and version $this->brand = 'Unknown'; $this->version = null; // find reasonable defaults - if (preg_match('|([0-9a-zA-Z\.:()_ -]+)/([0-9a-zA-Z\._+-]+)|', $this->uastring, $regs)) { + if (preg_match('|([0-9a-zA-Z\.:()_ -]+)/(\d[0-9a-zA-Z\._+-]*)|', $this->uastring, $regs)) { $this->brand = trim($regs[1]); $this->version = $regs[2]; } - elseif (preg_match('|^([a-zA-Z\._ -]+)[_ -][vV]?([0-9][0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + elseif (preg_match('|^([a-zA-Z\._ -]+)[_ -][vV]?(\d[0-9a-zA-Z\.+]*)|', $this->uastring, $regs)) { $this->brand = trim($regs[1]); $this->version = $regs[2]; } - elseif (preg_match('|^([a-zA-Z\._ -]+)|', $this->uastring, $regs)) { + elseif (preg_match('|^([0-9a-zA-Z\._ -]+)|', $this->uastring, $regs)) { $this->brand = trim($regs[1]); $this->version = null; } $this->bot = (strpos(strtolower($this->brand), 'bot') !== false) || (strpos(strtolower($this->brand), 'crawler') !== false) - || (strpos(strtolower($this->brand), 'spider') !== false); + || (strpos(strtolower($this->brand), 'spider') !== false) + || (strpos(strtolower($this->brand), 'search') !== false) + || (strpos(strtolower($this->brand), 'seek') !== false); // search for any real and/or special UAs if (preg_match('|Netscape6/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { @@ -227,12 +229,14 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } - elseif (preg_match('|rv:([0-9a-zA-Z\.+]+)|', $this->uastring, $regs) && strstr($this->uastring, "Mozilla/") && strstr($this->uastring, "Gecko/")) { + elseif (preg_match('|rv:([0-9a-zA-Z\.+]+)|', $this->uastring, $regs) && + strstr($this->uastring, "Mozilla/") && strstr($this->uastring, "Gecko/")) { $this->brand = 'Mozilla'; $this->version = $regs[1]; $this->bot = false; } - elseif (preg_match('|m([0-9]+)\)|', $this->uastring, $regs) && strstr($this->uastring, "Mozilla/") && strstr($this->uastring, "Gecko/")) { + elseif (preg_match('|m([0-9]+)\)|', $this->uastring, $regs) && + strstr($this->uastring, "Mozilla/") && strstr($this->uastring, "Gecko/")) { $this->brand = 'Mozilla'; $this->version = 'M'.$regs[1]; $this->bot = false; @@ -322,6 +326,11 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } + elseif (preg_match('|PLAYSTATION 3; ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'PlayStation 3'; + $this->version = $regs[1]; + $this->bot = false; + } elseif (preg_match('|NetFront/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { $this->brand = 'NetFront'; $this->version = $regs[1]; @@ -362,6 +371,11 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } + elseif (preg_match('|IXI/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'IXI'; + $this->version = $regs[1]; + $this->bot = false; + } elseif (preg_match('|IBM-WebExplorer-DLL/v([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { $this->brand = 'WebExplorer'; $this->version = $regs[1]; @@ -377,23 +391,43 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } - elseif (preg_match('|wget[/ ]([0-9a-zA-Z\.+]+)|i', $this->uastring, $regs)) { - $this->brand = 'wget'; + elseif (preg_match('|WinHttp.WinHttpRequest.([0-9\.]+)|i', $this->uastring, $regs)) { + $this->brand = 'WinHttpRequest'; $this->version = $regs[1]; $this->bot = false; } - elseif (preg_match('|; arexx\)|i', $this->uastring, $regs)) { + elseif (preg_match('|alpha[/ ]06; AmigaOS|i', $this->uastring, $regs)) { + $this->brand = 'Alpha 06'; + $this->version = null; + $this->bot = false; + } + elseif (preg_match('|; arexx[\);]|i', $this->uastring, $regs)) { $this->brand = 'ARexx'; $this->version = null; $this->bot = false; } - elseif (preg_match('|ZyBorg/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { - $this->brand = 'ZyBorg'; + elseif (preg_match('|; Voyager; AmigaOS[\);]|i', $this->uastring, $regs)) { + $this->brand = 'AmigaVoyager'; + $this->version = null; + $this->bot = false; + } + elseif (preg_match('|AWEB ([0-9a-zA-Z\.+ ]+)|', $this->uastring, $regs)) { + $this->brand = 'AWEB'; $this->version = $regs[1]; - $this->bot = true; + $this->bot = false; } - elseif (preg_match('|Googlebot/?([0-9a-zA-Z\.+]+)?|', $this->uastring, $regs)) { - $this->brand = 'Googlebot'; + elseif (preg_match('|X ([0-9a-zA-Z\.+ ]+); Commodore 64|', $this->uastring, $regs)) { + $this->brand = 'X'; + $this->version = $regs[1]; + $this->bot = false; + } + elseif (preg_match('|DB Browse ([0-9a-zA-Z\.+]+)|i', $this->uastring, $regs)) { + $this->brand = 'DB Browse'; + $this->version = $regs[1]; + $this->bot = false; + } + elseif (preg_match('|ZyBorg/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'ZyBorg'; $this->version = $regs[1]; $this->bot = true; } @@ -407,11 +441,41 @@ class userAgent { $this->version = $regs[1]; $this->bot = true; } + elseif (preg_match('|([0-9a-zA-Z\.+]+bot)/([0-9a-zA-Z\.+]+)|i', $this->uastring, $regs)) { + $this->brand = $regs[1]; + $this->version = $regs[2]; + $this->bot = true; + } + elseif (preg_match('|VoilaBot ((BETA )?[0-9a-zA-Z\.+]+)|i', $this->uastring, $regs)) { + $this->brand = 'VoilaBot'; + $this->version = $regs[1]; + $this->bot = true; + } elseif (preg_match('|Slurp|', $this->uastring, $regs)) { $this->brand = 'Slurp'; $this->version = null; $this->bot = true; } + elseif (preg_match('|Check&Get ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'Check&Get'; + $this->version = $regs[1]; + $this->bot = true; + } + elseif (preg_match('|WebCapture ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'WebCapture'; + $this->version = $regs[1]; + $this->bot = true; + } + elseif (preg_match('|WebMon ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'WebMon'; + $this->version = $regs[1]; + $this->bot = true; + } + elseif (preg_match('|Powermarks/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'Powermarks'; + $this->version = $regs[1]; + $this->bot = true; + } elseif (preg_match('|Gulper Web Bot ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { $this->brand = 'Gulper Web Bot'; $this->version = $regs[1]; @@ -422,6 +486,11 @@ class userAgent { $this->version = $regs[1]; $this->bot = true; } + elseif (preg_match('|Twiceler-([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'Twiceler'; + $this->version = $regs[1]; + $this->bot = true; + } elseif (preg_match('|Microsoft URL Control - ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { $this->brand = 'Microsoft URL Control'; $this->version = $regs[1]; @@ -442,18 +511,29 @@ class userAgent { $this->version = null; $this->bot = true; } + elseif (preg_match('|http://www.livedir.net|', $this->uastring, $regs)) { + $this->brand = 'livedir.net'; + $this->version = null; + $this->bot = true; + } + elseif (preg_match('|WebClipping.com|', $this->uastring, $regs)) { + $this->brand = 'WebClipping.com'; + $this->version = null; + $this->bot = true; + } elseif (preg_match('|http://www.almaden.ibm.com/cs/crawler|', $this->uastring)) { $this->brand = 'almaden crawler'; $this->version = null; $this->bot = true; } - elseif (preg_match('|B-l-i-t-z-B-O-T|', $this->uastring) || preg_match('|B l i t z B O T @ t r i c u s . n e t|', $this->uastring)) { + elseif (preg_match('|B-l-i-t-z-B-O-T|', $this->uastring) || + preg_match('|B l i t z B O T @ t r i c u s . n e t|', $this->uastring)) { $this->brand = 'BlitzBOT'; $this->version = null; $this->bot = true; } - elseif (preg_match('|sitecheck.internetseer.com|', $this->uastring)) { - $this->brand = 'internetseer'; + elseif (preg_match('|Really Gmane.org\'s favicon grabber|', $this->uastring)) { + $this->brand = 'Really Gmane.org\'s favicon grabber'; $this->version = null; $this->bot = true; } @@ -462,13 +542,23 @@ class userAgent { $this->version = null; $this->bot = true; } - elseif (preg_match('|efp@gmx.net|', $this->uastring)) { - $this->brand = 'efp'; + elseif (preg_match('|Arachmo|', $this->uastring)) { + $this->brand = 'Arachmo'; + $this->version = null; + $this->bot = true; + } + elseif (preg_match('|OsO|', $this->uastring)) { + $this->brand = 'OsO'; $this->version = null; $this->bot = true; } - elseif (preg_match('|42_HAL|', $this->uastring)) { - $this->brand = '42_HAL'; + elseif (preg_match('|Yoono|', $this->uastring)) { + $this->brand = 'Yoono'; + $this->version = null; + $this->bot = true; + } + elseif (preg_match('|efp@gmx.net|', $this->uastring)) { + $this->brand = 'efp'; $this->version = null; $this->bot = true; } @@ -482,6 +572,21 @@ class userAgent { $this->version = null; $this->bot = true; } + elseif (preg_match('|Linkman|', $this->uastring)) { + $this->brand = 'Linkman'; + $this->version = null; + $this->bot = true; + } + elseif (preg_match('|Sage|', $this->uastring, $regs)) { + $this->brand = 'Sage'; + $this->version = null; + $this->bot = true; + } + elseif (preg_match('|Google Desktop|', $this->uastring)) { + $this->brand = 'Google Desktop'; + $this->version = null; + $this->bot = true; + } elseif (preg_match('|^Firefly|', $this->uastring)) { // comes here with correct value but would be detected as MSIE } @@ -490,6 +595,26 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } + elseif (preg_match('|Steganos Internet Anonym([0-9a-zA-Z\. +]*)|', $this->uastring, $regs)) { + $this->brand = 'Steganos Internet Anonym'; + $this->version = $regs[1]; + $this->bot = false; + } + elseif (preg_match('|BorderManager ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'BorderManager'; + $this->version = $regs[1]; + $this->bot = false; + } + elseif (preg_match('|WebWasher ([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = 'WebWasher'; + $this->version = $regs[1]; + $this->bot = false; + } + elseif (preg_match('|SaferSurf|', $this->uastring, $regs)) { + $this->brand = 'SaferSurf'; + $this->version = null; + $this->bot = false; + } elseif (preg_match('|Avant Browser[^/]|', $this->uastring)) { $this->brand = 'Avant Browser'; $this->version = null; @@ -550,23 +675,25 @@ class userAgent { $this->version = $regs[1]; $this->bot = false; } - elseif (preg_match('|Mozilla/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs) && (strpos($this->uastring, 'compatible;') === false) && (strpos($this->uastring, 'Gecko/') === false)) { + elseif (preg_match('|Mozilla/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs) && + (strpos($this->uastring, 'compatible') === false) && (strpos($this->uastring, 'Gecko/') === false) && + (intval($regs[1]) < 5)) { $this->brand = 'Netscape'; $this->version = $regs[1]; if (intval($this->version) == 4) { $this->brand .= ' Communicator'; } $this->bot = false; } - elseif (preg_match('|Mozilla/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs) && (strpos($this->uastring, 'compatible;') !== false)) { - $this->brand = 'Mozilla-compatible (unknown)'; + elseif (preg_match('|Mozilla/([0-9a-zA-Z\.+]+)|', $this->uastring, $regs)) { + $this->brand = (strpos($this->uastring, 'compatible') !== false)?'Mozilla-compatible (unknown)':'Mozilla (unknown)'; $this->version = null; $this->bot = false; } - $botArray = array('Scooter','Spinne','Vagabondo','Firefly','Scrubby','NG','Pompos','Szukacz','ASPseek', + $botArray = array('Scooter','Spinne','Vagabondo','Firefly','Scrubby','NG','Pompos','Szukacz','Schmozilla','42_HAL', 'NetResearchServer','LinkWalker','Zeus','W3C_Validator','ZyBorg','Ask Jeeves','ia_archiver', 'PingALink Monitoring Services','IlTrovatore-Setaccio','Nutch','Mercator','search.ch', - 'appie','larbin','NutchCVS','ObjectsSearch','Webchat','Mediapartners-Google','Schmozilla', - 'FavOrg','findlinks','DataCha0s','ichiro','Francis','','','','','','',''); + 'appie','larbin','NutchCVS','Webchat','Mediapartners-Google','sitecheck.internetseer.com', + 'FavOrg','findlinks','DataCha0s','ichiro','Francis','','','','',''); if (in_array($this->brand, $botArray)) { $this->bot = true; @@ -595,7 +722,7 @@ class userAgent { public function getUAString() { return $this->uastring; } public function getEngine() { - // return gecko|khtml|trident|tasman|nscp|presto|gzilla|gtkhtml|links|icestorm|unknown + // return gecko|khtml|trident|tasman|nscp|presto|gzilla|gtkhtml|links|icestorm|netfront|unknown if (!isset($this->uadata['engine'])) { $this->uadata['engine'] = 'unknown'; $this->uadata['geckodate'] = null; @@ -637,6 +764,9 @@ class userAgent { elseif ((strpos($this->brand, 'ICEbrowser') !== false) || (strpos($this->brand, 'ICE Browser') !== false)) { $this->uadata['engine'] = 'icestorm'; } + elseif ((strpos($this->brand, 'PlayStation') !== false) || (strpos($this->brand, 'NetFront') !== false)) { + $this->uadata['engine'] = 'netfront'; + } elseif ((strpos($this->brand, 'Avant') !== false) || (strpos($this->brand, 'Crazy Browser') !== false) || (strpos($this->brand, 'AOL') !== false) || (strpos($this->brand, 'MSN') !== false) || (strpos($this->brand, 'MyIE2') !== false) || (strpos($this->brand, 'Maxthon') !== false)) { @@ -854,6 +984,9 @@ class userAgent { if (preg_match('/AmigaOS/i', $this->uastring, $regs)) { $this->uadata['os'] = 'AmigaOS'; } + if (preg_match('/Commodore 64/i', $this->uastring, $regs)) { + $this->uadata['os'] = 'Commodore 64'; + } elseif (preg_match('/curl\/[^\(]+\(([^\);]+)/i', $this->uastring, $regs)) { $this->uadata['os'] = $regs[1]; } @@ -900,6 +1033,7 @@ class userAgent { elseif (strpos($this->uadata['os'], 'IRIX') !== false) { $this->uadata['platform'] = 'IRIX'; } elseif (strpos($this->uadata['os'], 'HP-UX') !== false) { $this->uadata['platform'] = 'HP-UX'; } elseif (strpos($this->uadata['os'], 'AmigaOS') !== false) { $this->uadata['platform'] = 'Amiga'; } + elseif (strpos($this->uadata['os'], 'Commodore 64') !== false) { $this->uadata['platform'] = 'C64'; } elseif (strpos($this->uadata['os'], 'OpenVMS') !== false) { $this->uadata['platform'] = 'OpenVMS'; } elseif (strpos($this->uadata['os'], 'Warp') !== false) { $this->uadata['platform'] = 'OS/2'; } elseif (strpos($this->uadata['os'], 'SymbianOS') !== false) { $this->uadata['platform'] = 'SymbianOS'; }