| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- <?php
- namespace Luracast\Restler;
- /**
- * Information gathered about the api user is kept here using static methods
- * and properties for other classes to make use of them.
- * Typically Authentication classes populate them
- *
- * @category Framework
- * @package restler
- * @author R.Arul Kumaran <arul@luracast.com>
- * @copyright 2010 Luracast
- * @license http://www.opensource.org/licenses/lgpl-license.php LGPL
- * @link http://luracast.com/products/restler/
- *
- */
- class User implements iIdentifyUser
- {
- private static $initialized = false;
- public static $id = null;
- public static $cacheId = null;
- public static $ip;
- public static $browser = '';
- public static $platform = '';
- public static function init()
- {
- static::$initialized = true;
- static::$ip = static::getIpAddress();
- }
- public static function getUniqueIdentifier($includePlatform = false)
- {
- if (!static::$initialized) static::init();
- return static::$id ? : base64_encode('ip:' . ($includePlatform
- ? static::$ip . '-' . static::$platform
- : static::$ip
- ));
- }
- public static function getIpAddress($ignoreProxies = false)
- {
- foreach (array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR',
- 'HTTP_X_FORWARDED', 'HTTP_X_CLUSTER_CLIENT_IP',
- 'HTTP_FORWARDED_FOR', 'HTTP_FORWARDED',
- 'REMOTE_ADDR') as $key) {
- if (array_key_exists($key, $_SERVER) === true) {
- foreach (explode(',', $_SERVER[$key]) as $ip) {
- $ip = trim($ip); // just to be safe
- if (filter_var($ip, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4
- | FILTER_FLAG_NO_PRIV_RANGE
- | FILTER_FLAG_NO_RES_RANGE) !== false
- ) {
- return $ip;
- }
- }
- }
- }
- }
- /**
- * Authentication classes should call this method
- *
- * @param string $id user id as identified by the authentication classes
- *
- * @return void
- */
- public static function setUniqueIdentifier($id)
- {
- static::$id = $id;
- }
- /**
- * User identity to be used for caching purpose
- *
- * When the dynamic cache service places an object in the cache, it needs to
- * label it with a unique identifying string known as a cache ID. This
- * method gives that identifier
- *
- * @return string
- */
- public static function getCacheIdentifier()
- {
- return static::$cacheId ?: static::$id;
- }
- /**
- * User identity for caching purpose
- *
- * In a role based access control system this will be based on role
- *
- * @param $id
- *
- * @return void
- */
- public static function setCacheIdentifier($id)
- {
- static::$cacheId = $id;
- }
- }
|