2011-12-05 16:53:12 +01:00
|
|
|
<?php
|
2013-01-19 20:36:40 +01:00
|
|
|
namespace chat\util;
|
2013-01-07 18:46:19 +01:00
|
|
|
use \wcf\data\package\PackageCache;
|
2011-12-23 15:26:54 +01:00
|
|
|
use \wcf\system\user\storage\UserStorageHandler;
|
|
|
|
use \wcf\system\WCF;
|
2011-12-05 16:53:12 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Chat utilities
|
|
|
|
*
|
|
|
|
* @author Tim Düsterhus
|
2013-01-19 20:36:40 +01:00
|
|
|
* @copyright 2010-2013 Tim Düsterhus
|
2011-12-05 16:53:12 +01:00
|
|
|
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
|
2013-01-19 20:36:40 +01:00
|
|
|
* @package be.bastelstu.chat
|
2011-12-05 16:53:12 +01:00
|
|
|
* @subpackage util
|
|
|
|
*/
|
2012-03-12 22:51:29 +01:00
|
|
|
final class ChatUtil {
|
2011-12-10 14:43:18 +01:00
|
|
|
/**
|
|
|
|
* Matches a time-interval with modifiers.
|
|
|
|
* Each part may be optionally separated by a comma
|
|
|
|
*
|
2013-01-19 20:36:40 +01:00
|
|
|
* @see \chat\util\ChatUtil::timeModifier()
|
2011-12-10 14:43:18 +01:00
|
|
|
*/
|
2011-12-14 17:25:16 +01:00
|
|
|
const TIME_MODIFIER_REGEX = '((?:[0-9]+[s|h|d|w|m|y|S|H|D|W|M|Y]?,?)+)';
|
2011-12-10 14:43:18 +01:00
|
|
|
|
2012-03-08 22:07:46 +01:00
|
|
|
/**
|
|
|
|
* Package identifier of Tims Chat.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
const PACKAGE_IDENTIFIER = 'be.bastelstu.chat';
|
2012-03-08 22:07:46 +01:00
|
|
|
|
2012-06-04 21:34:07 +02:00
|
|
|
/**
|
|
|
|
* Which user-storage-keys need serialization.
|
|
|
|
* The value should always be true.
|
|
|
|
*
|
|
|
|
* @var array<boolean>
|
|
|
|
*/
|
|
|
|
private static $serialize = array('color' => true, 'suspensions' => true);
|
2011-12-23 15:26:54 +01:00
|
|
|
|
2012-03-08 22:07:46 +01:00
|
|
|
/**
|
|
|
|
* Cached packageID of Tims Chat.
|
|
|
|
*
|
|
|
|
* @var integer
|
|
|
|
*/
|
|
|
|
private static $packageID = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the packageID of Tims Chat.
|
|
|
|
*/
|
|
|
|
public static function getPackageID() {
|
|
|
|
if (self::$packageID === null) {
|
2013-01-07 18:46:19 +01:00
|
|
|
self::$packageID = PackageCache::getInstance()->getPackageID(self::PACKAGE_IDENTIFIER);
|
2012-03-08 22:07:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return self::$packageID;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a random number.
|
|
|
|
*
|
|
|
|
* @return integer
|
|
|
|
*/
|
|
|
|
public static function /* int */ getRandomNumber() {
|
2012-12-20 18:46:38 +01:00
|
|
|
return 4; // chosen by a fair dice roll
|
|
|
|
// guaranteed to be random
|
2012-03-08 22:07:46 +01:00
|
|
|
}
|
|
|
|
|
2011-12-05 16:53:12 +01:00
|
|
|
/**
|
|
|
|
* Creates a gradient out of two colors represented by an integer.
|
|
|
|
* The first byte is red, the second byte is green, the third one is blue.
|
|
|
|
* The numbers can be easily expressed in hexadecimal notation: 0xFF0000 being red.
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param integer $start
|
|
|
|
* @param integer $end
|
2011-12-23 15:26:54 +01:00
|
|
|
* @return string
|
2011-12-05 16:53:12 +01:00
|
|
|
*/
|
|
|
|
public static function gradient($string, $start, $end) {
|
2013-05-21 22:45:28 +02:00
|
|
|
if (($length = \wcf\util\StringUtil::length($string)) === 0) return '';
|
2011-12-14 17:24:41 +01:00
|
|
|
|
2013-04-23 16:36:04 +02:00
|
|
|
if ($start === $end) {
|
2013-04-23 16:49:54 +02:00
|
|
|
return '<span style="color:rgb('.($start >> 16 & 255).','.($start >> 8 & 255).','.($start & 255).')">'.\wcf\util\StringUtil::encodeHTML($string).'</span>';
|
2013-04-23 16:36:04 +02:00
|
|
|
}
|
|
|
|
|
2013-05-21 22:45:28 +02:00
|
|
|
$r = (int) ((($start >> 16 & 255) - ($end >> 16 & 255)) / ($length - 1));
|
|
|
|
$g = (int) ((($start >> 8 & 255) - ($end >> 8 & 255)) / ($length - 1));
|
|
|
|
$b = (int) ((($start & 255) - ($end & 255)) / ($length - 1));
|
2011-12-05 16:53:12 +01:00
|
|
|
|
|
|
|
$result = '';
|
2013-05-21 22:45:28 +02:00
|
|
|
$string = self::str_split($string);
|
|
|
|
for ($i = 0; $i < $length; $i++) {
|
2013-01-19 20:36:40 +01:00
|
|
|
$result .= '<span style="color:rgb('.(($start >> 16 & 255) - $i * $r).','.(($start >> 8 & 255) - $i * $g).','.(($start & 255) - $i * $b).')">'.\wcf\util\StringUtil::encodeHTML($string[$i]).'</span>';
|
2011-12-05 16:53:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
2011-12-10 14:25:36 +01:00
|
|
|
|
2011-12-23 15:26:54 +01:00
|
|
|
/**
|
|
|
|
* Reads user data.
|
|
|
|
*
|
2012-11-20 16:01:32 +01:00
|
|
|
* @param string $field
|
2012-03-23 23:27:15 +01:00
|
|
|
* @param \wcf\data\user\User $user
|
2011-12-23 15:26:54 +01:00
|
|
|
* @return mixed
|
|
|
|
*/
|
2012-03-23 23:27:15 +01:00
|
|
|
public static function readUserData($field, \wcf\data\user\User $user = null) {
|
|
|
|
if ($user === null) $user = WCF::getUser();
|
2011-12-23 15:26:54 +01:00
|
|
|
$ush = UserStorageHandler::getInstance();
|
|
|
|
|
|
|
|
// load storage
|
2013-01-09 17:35:30 +01:00
|
|
|
$ush->loadStorage(array($user->userID));
|
|
|
|
$data = $ush->getStorage(array($user->userID), $field);
|
2011-12-23 15:26:54 +01:00
|
|
|
|
2012-03-23 23:27:15 +01:00
|
|
|
if ($data[$user->userID] === null) {
|
2011-12-23 15:26:54 +01:00
|
|
|
switch ($field) {
|
|
|
|
case 'color':
|
2012-03-23 23:27:15 +01:00
|
|
|
$data[$user->userID] = array(1 => self::getRandomNumber(), 2 => self::getRandomNumber() * 0xFFFF);
|
2011-12-23 15:26:54 +01:00
|
|
|
break;
|
|
|
|
}
|
2012-05-19 21:25:50 +02:00
|
|
|
if ($data[$user->userID] !== null) static::writeUserData(array($field => $data[$user->userID]));
|
2011-12-24 16:59:29 +01:00
|
|
|
|
2012-03-23 23:27:15 +01:00
|
|
|
return $data[$user->userID];
|
2011-12-23 15:26:54 +01:00
|
|
|
}
|
|
|
|
|
2012-03-23 23:27:15 +01:00
|
|
|
if (isset(static::$serialize[$field])) return unserialize($data[$user->userID]);
|
|
|
|
else return $data[$user->userID];
|
2011-12-23 15:26:54 +01:00
|
|
|
}
|
|
|
|
|
2013-04-27 00:38:53 +02:00
|
|
|
/**
|
|
|
|
* Writes user data
|
|
|
|
* @param array $data
|
|
|
|
* @param \wcf\data\user\User $user
|
|
|
|
*/
|
|
|
|
public static function writeUserData(array $data, \wcf\data\user\User $user = null) {
|
|
|
|
if ($user === null) $user = WCF::getUser();
|
|
|
|
$ush = UserStorageHandler::getInstance();
|
|
|
|
|
|
|
|
foreach ($data as $key => $value) {
|
|
|
|
$ush->update($user->userID, $key, (isset(static::$serialize[$key])) ? serialize($value) : $value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-13 18:15:30 +01:00
|
|
|
/**
|
|
|
|
* Splits a string into smaller chunks.
|
|
|
|
* UTF-8 safe version of str_split().
|
|
|
|
*
|
|
|
|
* @param string $string
|
|
|
|
* @param integer $length
|
|
|
|
* @return array<string>
|
|
|
|
*/
|
|
|
|
public static function str_split($string, $length = 1) {
|
|
|
|
$result = array();
|
2013-01-19 20:36:40 +01:00
|
|
|
for ($i = 0, $max = \wcf\util\StringUtil::length($string); $i < $max; $i += $length) {
|
|
|
|
$result[] = \wcf\util\StringUtil::substring($string, $i, $length);
|
2011-12-13 18:15:30 +01:00
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2011-12-10 14:43:18 +01:00
|
|
|
/**
|
|
|
|
* Creates an interval out of a string with modifiers.
|
|
|
|
* Modifiers may be mixed. Valid modifiers are: _s_econd, _h_our, _d_ay, _w_week, _m_onth, _y_ear
|
|
|
|
* '2' -> 2 minutes
|
|
|
|
* '2h' -> 2 hours
|
|
|
|
* '1y12m2w3d12h' -> 1 year, 12 months, 2 weeks, 3 days, 12 hours
|
|
|
|
*
|
|
|
|
* @param string $time
|
|
|
|
* @return integer
|
|
|
|
*/
|
|
|
|
public static function timeModifier($time) {
|
2011-12-23 20:28:09 +01:00
|
|
|
$regex = new \wcf\system\Regex('([0-9]+[s|h|d|w|m|y]?)', \wcf\system\Regex::CASE_INSENSITIVE);
|
|
|
|
if (!$regex->match($time, true)) return 0;
|
|
|
|
$matches = $regex->getMatches();
|
|
|
|
|
2011-12-10 14:43:18 +01:00
|
|
|
$result = 0;
|
|
|
|
foreach ($matches[1] as $time) {
|
|
|
|
// 60 seconds a minute
|
|
|
|
$multiplier = 60;
|
|
|
|
$modifier = substr($time, -1);
|
|
|
|
|
|
|
|
switch ($modifier) {
|
|
|
|
case 'y':
|
|
|
|
case 'Y':
|
|
|
|
// twelve months a year
|
|
|
|
$multiplier *= 12;
|
|
|
|
case 'm':
|
|
|
|
case 'M':
|
|
|
|
// about 4.3 weeks per month
|
|
|
|
$multiplier *= 4.34812141;
|
|
|
|
case 'w':
|
|
|
|
case 'W':
|
|
|
|
// seven days a weeks
|
|
|
|
$multiplier *= 7;
|
|
|
|
case 'd':
|
|
|
|
case 'D':
|
|
|
|
// 24 hours a day
|
|
|
|
$multiplier *= 24;
|
|
|
|
case 'h':
|
|
|
|
case 'H':
|
|
|
|
// 60 minutes an hour
|
|
|
|
$multiplier *= 60;
|
|
|
|
$time = substr($time, 0, -1);
|
|
|
|
break;
|
|
|
|
case 's':
|
|
|
|
case 'S':
|
|
|
|
// 60 seconds per minute
|
|
|
|
$multiplier /= 60;
|
|
|
|
$time = substr($time, 0, -1);
|
|
|
|
}
|
|
|
|
|
|
|
|
$result += $time * $multiplier;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (int) round($result, 0);
|
|
|
|
}
|
2012-03-08 22:07:46 +01:00
|
|
|
|
2012-06-04 21:34:07 +02:00
|
|
|
/**
|
|
|
|
* Disables the constructor.
|
|
|
|
*/
|
2012-03-12 22:51:29 +01:00
|
|
|
private function __construct() { }
|
2011-12-05 16:53:12 +01:00
|
|
|
}
|