123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681 |
- <?php
- /**
- * CodeIgniter
- *
- * An open source application development framework for PHP
- *
- * This content is released under the MIT License (MIT)
- *
- * Copyright (c) 2014 - 2019, British Columbia Institute of Technology
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- * THE SOFTWARE.
- *
- * @package CodeIgniter
- * @author EllisLab Dev Team
- * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/)
- * @copyright Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/)
- * @license https://opensource.org/licenses/MIT MIT License
- * @link https://codeigniter.com
- * @since Version 1.0.0
- * @filesource
- */
- defined('BASEPATH') OR exit('No direct script access allowed');
- /**
- * User Agent Class
- *
- * Identifies the platform, browser, robot, or mobile device of the browsing agent
- *
- * @package CodeIgniter
- * @subpackage Libraries
- * @category User Agent
- * @author EllisLab Dev Team
- * @link https://codeigniter.com/user_guide/libraries/user_agent.html
- */
- class CI_User_agent {
- /**
- * Current user-agent
- *
- * @var string
- */
- public $agent = NULL;
- /**
- * Flag for if the user-agent belongs to a browser
- *
- * @var bool
- */
- public $is_browser = FALSE;
- /**
- * Flag for if the user-agent is a robot
- *
- * @var bool
- */
- public $is_robot = FALSE;
- /**
- * Flag for if the user-agent is a mobile browser
- *
- * @var bool
- */
- public $is_mobile = FALSE;
- /**
- * Languages accepted by the current user agent
- *
- * @var array
- */
- public $languages = array();
- /**
- * Character sets accepted by the current user agent
- *
- * @var array
- */
- public $charsets = array();
- /**
- * List of platforms to compare against current user agent
- *
- * @var array
- */
- public $platforms = array();
- /**
- * List of browsers to compare against current user agent
- *
- * @var array
- */
- public $browsers = array();
- /**
- * List of mobile browsers to compare against current user agent
- *
- * @var array
- */
- public $mobiles = array();
- /**
- * List of robots to compare against current user agent
- *
- * @var array
- */
- public $robots = array();
- /**
- * Current user-agent platform
- *
- * @var string
- */
- public $platform = '';
- /**
- * Current user-agent browser
- *
- * @var string
- */
- public $browser = '';
- /**
- * Current user-agent version
- *
- * @var string
- */
- public $version = '';
- /**
- * Current user-agent mobile name
- *
- * @var string
- */
- public $mobile = '';
- /**
- * Current user-agent robot name
- *
- * @var string
- */
- public $robot = '';
- /**
- * HTTP Referer
- *
- * @var mixed
- */
- public $referer;
- // --------------------------------------------------------------------
- /**
- * Constructor
- *
- * Sets the User Agent and runs the compilation routine
- *
- * @return void
- */
- public function __construct()
- {
- $this->_load_agent_file();
- if (isset($_SERVER['HTTP_USER_AGENT']))
- {
- $this->agent = trim($_SERVER['HTTP_USER_AGENT']);
- $this->_compile_data();
- }
- log_message('info', 'User Agent Class Initialized');
- }
- // --------------------------------------------------------------------
- /**
- * Compile the User Agent Data
- *
- * @return bool
- */
- protected function _load_agent_file()
- {
- if (($found = file_exists(APPPATH.'config/user_agents.php')))
- {
- include(APPPATH.'config/user_agents.php');
- }
- if (file_exists(APPPATH.'config/'.ENVIRONMENT.'/user_agents.php'))
- {
- include(APPPATH.'config/'.ENVIRONMENT.'/user_agents.php');
- $found = TRUE;
- }
- if ($found !== TRUE)
- {
- return FALSE;
- }
- $return = FALSE;
- if (isset($platforms))
- {
- $this->platforms = $platforms;
- unset($platforms);
- $return = TRUE;
- }
- if (isset($browsers))
- {
- $this->browsers = $browsers;
- unset($browsers);
- $return = TRUE;
- }
- if (isset($mobiles))
- {
- $this->mobiles = $mobiles;
- unset($mobiles);
- $return = TRUE;
- }
- if (isset($robots))
- {
- $this->robots = $robots;
- unset($robots);
- $return = TRUE;
- }
- return $return;
- }
- // --------------------------------------------------------------------
- /**
- * Compile the User Agent Data
- *
- * @return bool
- */
- protected function _compile_data()
- {
- $this->_set_platform();
- foreach (array('_set_robot', '_set_browser', '_set_mobile') as $function)
- {
- if ($this->$function() === TRUE)
- {
- break;
- }
- }
- }
- // --------------------------------------------------------------------
- /**
- * Set the Platform
- *
- * @return bool
- */
- protected function _set_platform()
- {
- if (is_array($this->platforms) && count($this->platforms) > 0)
- {
- foreach ($this->platforms as $key => $val)
- {
- if (preg_match('|'.preg_quote($key).'|i', $this->agent))
- {
- $this->platform = $val;
- return TRUE;
- }
- }
- }
- $this->platform = 'Unknown Platform';
- return FALSE;
- }
- // --------------------------------------------------------------------
- /**
- * Set the Browser
- *
- * @return bool
- */
- protected function _set_browser()
- {
- if (is_array($this->browsers) && count($this->browsers) > 0)
- {
- foreach ($this->browsers as $key => $val)
- {
- if (preg_match('|'.$key.'.*?([0-9\.]+)|i', $this->agent, $match))
- {
- $this->is_browser = TRUE;
- $this->version = $match[1];
- $this->browser = $val;
- $this->_set_mobile();
- return TRUE;
- }
- }
- }
- return FALSE;
- }
- // --------------------------------------------------------------------
- /**
- * Set the Robot
- *
- * @return bool
- */
- protected function _set_robot()
- {
- if (is_array($this->robots) && count($this->robots) > 0)
- {
- foreach ($this->robots as $key => $val)
- {
- if (preg_match('|'.preg_quote($key).'|i', $this->agent))
- {
- $this->is_robot = TRUE;
- $this->robot = $val;
- $this->_set_mobile();
- return TRUE;
- }
- }
- }
- return FALSE;
- }
- // --------------------------------------------------------------------
- /**
- * Set the Mobile Device
- *
- * @return bool
- */
- protected function _set_mobile()
- {
- if (is_array($this->mobiles) && count($this->mobiles) > 0)
- {
- foreach ($this->mobiles as $key => $val)
- {
- if (FALSE !== (stripos($this->agent, $key)))
- {
- $this->is_mobile = TRUE;
- $this->mobile = $val;
- return TRUE;
- }
- }
- }
- return FALSE;
- }
- // --------------------------------------------------------------------
- /**
- * Set the accepted languages
- *
- * @return void
- */
- protected function _set_languages()
- {
- if ((count($this->languages) === 0) && ! empty($_SERVER['HTTP_ACCEPT_LANGUAGE']))
- {
- $this->languages = explode(',', preg_replace('/(;\s?q=[0-9\.]+)|\s/i', '', strtolower(trim($_SERVER['HTTP_ACCEPT_LANGUAGE']))));
- }
- if (count($this->languages) === 0)
- {
- $this->languages = array('Undefined');
- }
- }
- // --------------------------------------------------------------------
- /**
- * Set the accepted character sets
- *
- * @return void
- */
- protected function _set_charsets()
- {
- if ((count($this->charsets) === 0) && ! empty($_SERVER['HTTP_ACCEPT_CHARSET']))
- {
- $this->charsets = explode(',', preg_replace('/(;\s?q=.+)|\s/i', '', strtolower(trim($_SERVER['HTTP_ACCEPT_CHARSET']))));
- }
- if (count($this->charsets) === 0)
- {
- $this->charsets = array('Undefined');
- }
- }
- // --------------------------------------------------------------------
- /**
- * Is Browser
- *
- * @param string $key
- * @return bool
- */
- public function is_browser($key = NULL)
- {
- if ( ! $this->is_browser)
- {
- return FALSE;
- }
- // No need to be specific, it's a browser
- if ($key === NULL)
- {
- return TRUE;
- }
- // Check for a specific browser
- return (isset($this->browsers[$key]) && $this->browser === $this->browsers[$key]);
- }
- // --------------------------------------------------------------------
- /**
- * Is Robot
- *
- * @param string $key
- * @return bool
- */
- public function is_robot($key = NULL)
- {
- if ( ! $this->is_robot)
- {
- return FALSE;
- }
- // No need to be specific, it's a robot
- if ($key === NULL)
- {
- return TRUE;
- }
- // Check for a specific robot
- return (isset($this->robots[$key]) && $this->robot === $this->robots[$key]);
- }
- // --------------------------------------------------------------------
- /**
- * Is Mobile
- *
- * @param string $key
- * @return bool
- */
- public function is_mobile($key = NULL)
- {
- if ( ! $this->is_mobile)
- {
- return FALSE;
- }
- // No need to be specific, it's a mobile
- if ($key === NULL)
- {
- return TRUE;
- }
- // Check for a specific robot
- return (isset($this->mobiles[$key]) && $this->mobile === $this->mobiles[$key]);
- }
- // --------------------------------------------------------------------
- /**
- * Is this a referral from another site?
- *
- * @return bool
- */
- public function is_referral()
- {
- if ( ! isset($this->referer))
- {
- if (empty($_SERVER['HTTP_REFERER']))
- {
- $this->referer = FALSE;
- }
- else
- {
- $referer_host = @parse_url($_SERVER['HTTP_REFERER'], PHP_URL_HOST);
- $own_host = parse_url(config_item('base_url'), PHP_URL_HOST);
- $this->referer = ($referer_host && $referer_host !== $own_host);
- }
- }
- return $this->referer;
- }
- // --------------------------------------------------------------------
- /**
- * Agent String
- *
- * @return string
- */
- public function agent_string()
- {
- return $this->agent;
- }
- // --------------------------------------------------------------------
- /**
- * Get Platform
- *
- * @return string
- */
- public function platform()
- {
- return $this->platform;
- }
- // --------------------------------------------------------------------
- /**
- * Get Browser Name
- *
- * @return string
- */
- public function browser()
- {
- return $this->browser;
- }
- // --------------------------------------------------------------------
- /**
- * Get the Browser Version
- *
- * @return string
- */
- public function version()
- {
- return $this->version;
- }
- // --------------------------------------------------------------------
- /**
- * Get The Robot Name
- *
- * @return string
- */
- public function robot()
- {
- return $this->robot;
- }
- // --------------------------------------------------------------------
- /**
- * Get the Mobile Device
- *
- * @return string
- */
- public function mobile()
- {
- return $this->mobile;
- }
- // --------------------------------------------------------------------
- /**
- * Get the referrer
- *
- * @return bool
- */
- public function referrer()
- {
- return empty($_SERVER['HTTP_REFERER']) ? '' : trim($_SERVER['HTTP_REFERER']);
- }
- // --------------------------------------------------------------------
- /**
- * Get the accepted languages
- *
- * @return array
- */
- public function languages()
- {
- if (count($this->languages) === 0)
- {
- $this->_set_languages();
- }
- return $this->languages;
- }
- // --------------------------------------------------------------------
- /**
- * Get the accepted Character Sets
- *
- * @return array
- */
- public function charsets()
- {
- if (count($this->charsets) === 0)
- {
- $this->_set_charsets();
- }
- return $this->charsets;
- }
- // --------------------------------------------------------------------
- /**
- * Test for a particular language
- *
- * @param string $lang
- * @return bool
- */
- public function accept_lang($lang = 'en')
- {
- return in_array(strtolower($lang), $this->languages(), TRUE);
- }
- // --------------------------------------------------------------------
- /**
- * Test for a particular character set
- *
- * @param string $charset
- * @return bool
- */
- public function accept_charset($charset = 'utf-8')
- {
- return in_array(strtolower($charset), $this->charsets(), TRUE);
- }
- // --------------------------------------------------------------------
- /**
- * Parse a custom user-agent string
- *
- * @param string $string
- * @return void
- */
- public function parse($string)
- {
- // Reset values
- $this->is_browser = FALSE;
- $this->is_robot = FALSE;
- $this->is_mobile = FALSE;
- $this->browser = '';
- $this->version = '';
- $this->mobile = '';
- $this->robot = '';
- // Set the new user-agent string and parse it, unless empty
- $this->agent = $string;
- if ( ! empty($string))
- {
- $this->_compile_data();
- }
- }
- }
|