Просмотр файла system/inc/functions.php

Размер файла: 16.43Kb
  1. <?php
  2. /**********************************
  3. * @package: PerfCMS *
  4. * @year: 2012 *
  5. * @author: Artas *
  6. * @link: http://perfcms.pp.ua *
  7. **********************************/
  8. function display_error($content) {
  9. echo "<div class=\"error\">{$content}</div>\n";
  10. }
  11.  
  12. function go($link) {
  13. header('location: '.$link);
  14. exit;
  15. }
  16. function cget($var) {
  17. return htmlspecialchars(trim($var));
  18. }
  19. function escape($inp)
  20. {
  21. if(is_array($inp))
  22. return array_map(__METHOD__, $inp);
  23.  
  24. if(!empty($inp) && is_string($inp)) {
  25. return str_replace(array('\\', "\0", "\n", "\r", "'", '"', "\x1a"), array('\\', '\0', '\n', '\r', "\'", '\"', '\Z'), $inp);
  26. }
  27.  
  28. return $inp;
  29. }
  30. function rtime($var) {
  31. require_once(SYS.'/classes/lang.php');
  32. global $lang;
  33. if ($var == NULL) {
  34. $var = time();
  35. }
  36. $real_time = date('d.m.Y '.$lang->word('time_in').' H:i', $var);
  37. $date = date('d.m.Y', $var);
  38. $time = date('H:i', $var);
  39.  
  40. if ($date == date('d.m.Y')) {
  41. $real_time = date(''.$lang->word('today').' '.$lang->word('time_in').' H:i', $var);
  42. }
  43. if ($date == date('d.m.Y', time()-60*60*24)) {
  44. $real_time = date(''.$lang->word('yesterday').' '.$lang->word('time_in').' H:i', $var);
  45. }
  46. return $real_time;
  47. }
  48. function input($var) {
  49. return escape(htmlspecialchars($var, ENT_QUOTES));
  50. }
  51. function output($var) {
  52. return smiles(tags(nl2br($var)));
  53. }
  54. function crypto($var) {
  55. return md5(base64_encode($var) .'_PerfCMS_');
  56. }
  57.  
  58. function highlight($code)
  59. {
  60. $code = strtr($code, array (
  61. '<br />' => '',
  62. '\\' => 'slash'
  63. ));
  64. $code = html_entity_decode($code, ENT_QUOTES, 'UTF-8');
  65. $code = stripslashes($code);
  66. if(!strpos($code,"<?") && substr($code,0,2)!="<?") {
  67. $code="<?php\n".trim($code)."\n?>";
  68. }
  69. $code = trim($code);
  70. $code = highlight_string($code,true);
  71. $code = strtr($code, array (
  72. 'slash' => '&#92;',
  73. ':' => '&#58;',
  74. '[' => '&#91;',
  75. '&nbsp;' => ' '
  76. ));
  77. return '<div class="code">'.$code.'</div>';
  78. }
  79.  
  80. function tags($var){
  81. global $system;
  82. $var = preg_replace(array ('#\[code\](.*?)\[\/code\]#se'), array ("''.highlight('$1').''"), str_replace("]\n", "]", $var));
  83. if($system['bb_b'] == 'on') { $var = preg_replace('/\[b\](.+)\[\/b\]/isU', '<b>$1</b>', $var); }
  84. if($system['bb_u'] == 'on') { $var = preg_replace('/\[u\](.+)\[\/u\]/isU', '<span style="text-decoration:underline;">$1</span>', $var); }
  85. if($system['bb_s'] == 'on') { $var = preg_replace('/\[s\](.+)\[\/s\]/isU', '<s>$1</s>', $var); }
  86. if($system['bb_i'] == 'on') { $var = preg_replace('/\[i\](.+)\[\/i\]/isU', '<i>$1</i>', $var); }
  87. if($system['bb_big'] == 'on') { $var = preg_replace('/\[big\](.+)\[\/big\]/isU', '<span style="font-size:large;">$1</span>', $var); }
  88. if($system['bb_small'] == 'on') { $var = preg_replace('/\[small\](.+)\[\/small\]/isU', '<span style="font-size:small;">$1</span>', $var); }
  89. if($system['bb_red'] == 'on') { $var = preg_replace('/\[red\](.+)\[\/red\]/isU', '<span style="color:#ff0000;">$1</span>', $var); }
  90. if($system['bb_yellow'] == 'on') { $var = preg_replace('/\[yellow\](.+)\[\/yellow\]/isU', '<span style="color:#ffff22;">$1</span>', $var); }
  91. if($system['bb_green'] == 'on') { $var = preg_replace('/\[green\](.+)\[\/green\]/isU', '<span style="color:#00bb00;">$1</span>', $var); }
  92. if($system['bb_blue'] == 'on') { $var = preg_replace('/\[blue\](.+)\[\/blue\]/isU', '<span style="color:#0000bb;">$1</span>', $var); }
  93. if($system['bb_color'] == 'on') { $var = preg_replace('/\[color=(.+)\](.+)\[\/color\]/isU', '<span style="color:$1;">$2</span>', $var); }
  94. if($system['bb_quote'] == 'on') { $var = preg_replace('/\[quote\](.+)\[\/quote\]/isU', '<div class="quote">$1</div>', $var); }
  95. if($system['bb_size'] == 'on') { $var = preg_replace('/\[size=([0-9]+)\](.+)\[\/size\]/isU', '<span style="font-size:$1px;">$2</span>', $var); }
  96. $var = preg_replace("/(https?|ftps?)\:\/\/([a-z0-9\.\/\-\?\_\=&;]*)\b/i", "<a href=\"$1://$2\" target=\"_blank\">$1://$2</a>", $var);
  97. $var = preg_replace("/([a-z0-9\.\-\_]*)\@([a-z0-9\.\-]*)\.([a-z]*)\b/i", '<a href="mailto:$1@$2.$3">$1@$2.$3</a>', $var);
  98. return $var;
  99. }
  100.  
  101. function smiles($var) {
  102. $var = preg_replace('/\:\)|:-\)|:smile:/', '<img src="/template/smiles/smiley-smile.png" alt="Smile" />', $var);
  103. $var = preg_replace('/:D|:-D/i', '<img src="/template/smiles/smiley-grin.png" alt="Smile" />', $var);
  104. $var = preg_replace('/\:\(|:-\(/i', '<img src="/template/smiles/smiley-sad.png" alt="Smile" />', $var);
  105. $var = preg_replace('/\;-\(|\;\(/', '<img src="/template/smiles/smiley-cry.png" alt="Smile" />', $var);
  106. $var = preg_replace('/\;\)|\;-\)/', '<img src="/template/smiles/smiley-wink.png" alt="Smile" />', $var);
  107. $var = preg_replace('/8\)|8-\)/i', '<img src="/template/smiles/smiley-cool.png" alt="Smile" />', $var);
  108. $var = preg_replace('/=O|O_O/i', '<img src="/template/smiles/smiley-eek.png" alt="Smile" />', $var);
  109. $var = str_replace('$)', '<img src="/template/smiles/smiley-money.png" alt="Smile" />', $var);
  110. $var = str_replace(':*', '<img src="/template/smiles/smiley-kiss.png" alt="Smile" />', $var);
  111. $var = preg_replace('/:P/i', '<img src="/template/smiles/smiley-razz.png" alt="Smile" />', $var);
  112. $var = str_replace(':|', '<img src="/template/smiles/smiley-netural.png" alt="Smile" />', $var);
  113. $var = preg_replace('/:Z/', '<img src="/template/smiles/smiley-sleep.png" alt="Smile" />', $var);
  114. $var = preg_replace('/:lol:/i', '<img src="/template/smiles/smiley-lol.png" alt="Smile" />', $var);
  115. $var = preg_replace('/:rofl:/i', '<img src="/template/smiles/smiley-yell.png" alt="Smile" />', $var);
  116. $var = str_replace(':&', '<img src="/template/smiles/smiley-confuse.png" alt="Smile" />', $var);
  117. $var = str_replace(':>', '<img src="/template/smiles/smiley-evil.png" alt="Smile" />', $var);
  118. $var = str_replace(':@', '<img src="/template/smiles/smiley-mad.png" alt="Smile" />', $var);
  119. $var = preg_replace('/:angel:/i', '<img src="/template/smiles/smiley-angel.png" alt="Smile" />', $var);
  120. $var = preg_replace('/:bla:/i', '<img src="/template/smiles/smiley-draw.png" alt="Smile" />', $var);
  121. $var = preg_replace('/:fat:/i', '<img src="/template/smiles/smiley-fat.png" alt="Smile" />', $var);
  122. $var = preg_replace('/:kitty:/i', '<img src="/template/smiles/smiley-kitty.png" alt="Smile" />', $var);
  123. $var = preg_replace('/:green:/i', '<img src="/template/smiles/smiley-mr-green.png" alt="Smile" />', $var);
  124. $var = str_replace('%)', '<img src="/template/smiles/smiley-nerd.png" alt="Smile" />', $var);
  125. $var = preg_replace('/:red:/i', '<img src="/template/smiles/smiley-red.png" alt="Smile" />', $var);
  126. $var = preg_replace('/:roll:/i', '<img src="/template/smiles/smiley-roll.png" alt="Smile" />', $var);
  127. $var = preg_replace('/:sweat:/i', '<img src="/template/smiles/smiley-sweat.png" alt="Smile" />', $var);
  128. $var = preg_replace('/:slim:/i', '<img src="/template/smiles/smiley-slim.png" alt="Smile" />', $var);
  129. $var = preg_replace('/:surprise:/i', '<img src="/template/smiles/smiley-surprise.png" alt="Smile" />', $var);
  130. $var = str_replace('<)', '<img src="/template/smiles/smiley-twist.png" alt="Smile" />', $var);
  131. $var = str_replace(':]', '<img src="/template/smiles/smiley-zipper.png" alt="Smile" />', $var);
  132. return $var;
  133. }
  134. function browser_type() {
  135. $useragent = $_SERVER['HTTP_USER_AGENT'];
  136. if(preg_match('/android|avantgo|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|msie|mmp|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino/i',$useragent)||preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|e\-|e\/|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(di|rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|xda(\-|2|g)|yas\-|your|zeto|zte\-/i',substr($useragent,0,4)))
  137. {
  138. return 'wap';
  139. }
  140. else {
  141. return 'web';
  142. }
  143. }
  144. function subtok($string,$chr,$pos,$len = NULL) {
  145. return implode($chr,array_slice(explode($chr,$string),$pos,$len));
  146. }
  147. function browser($agent) {
  148.  
  149. if(empty($agent)) { $agent = $_SERVER['HTTP_USER_AGENT']; }
  150.  
  151. if (stripos($agent, 'Avant Browser') !== false) {
  152. return 'Avant Browser';
  153. } elseif (stripos($agent, 'Acoo Browser') !== false) {
  154. return 'Acoo Browser';
  155. } elseif (stripos($agent, 'MyIE2') !== false) {
  156. return 'MyIE2';
  157. } elseif (preg_match('|Iron/([0-9a-z\.]*)|i', $agent, $pocket)) {
  158. return 'SRWare Iron ' . subtok($pocket[1], '.', 0, 2);
  159. } elseif (preg_match('|Chrome/([0-9a-z\.]*)|i', $agent, $pocket)) {
  160. return 'Chrome ' . subtok($pocket[1], '.', 0, 3);
  161. } elseif (preg_match('#(Maxthon|NetCaptor)( [0-9a-z\.]*)?#i', $agent, $pocket)) {
  162. return $pocket[1] . $pocket[2];
  163. } elseif (stripos($agent, 'Safari') !== false && preg_match('|Version/([0-9]{1,2}.[0-9]{1,2})|i', $agent, $pocket)) {
  164. return 'Safari ' . subtok($pocket[1], '.', 0, 3);
  165. } elseif (preg_match('#(NetFront|K-Meleon|Netscape|Galeon|Epiphany|Konqueror|Safari|Opera Mini|Opera Mobile/Opera Mobi)/([0-9a-z\.]*)#i', $agent, $pocket)) {
  166. return $pocket[1] . ' ' . subtok($pocket[2], '.', 0, 2);
  167. } elseif (stripos($agent, 'Opera') !== false && preg_match('|Version/([0-9]{1,2}.[0-9]{1,2})|i', $agent, $pocket)) {
  168. return 'Opera ' . $pocket[1];
  169. } elseif (preg_match('|Opera[/ ]([0-9a-z\.]*)|i', $agent, $pocket)) {
  170. return 'Opera ' . subtok($pocket[1], '.', 0, 2);
  171. } elseif (preg_match('|Orca/([ 0-9a-z\.]*)|i', $agent, $pocket)) {
  172. return 'Orca ' . subtok($pocket[1], '.', 0, 2);
  173. } elseif (preg_match('#(SeaMonkey|Firefox|GranParadiso|Minefield|Shiretoko)/([0-9a-z\.]*)#i', $agent, $pocket)) {
  174. return $pocket[1] . ' ' . subtok($pocket[2], '.', 0, 3);
  175. } elseif (preg_match('|rv:([0-9a-z\.]*)|i', $agent, $pocket) && strpos($agent, 'Mozilla/') !== false) {
  176. return 'Mozilla ' . subtok($pocket[1], '.', 0, 2);
  177. } elseif (preg_match('|Lynx/([0-9a-z\.]*)|i', $agent, $pocket)) {
  178. return 'Lynx ' . subtok($pocket[1], '.', 0, 2);
  179. } elseif (preg_match('|MSIE ([0-9a-z\.]*)|i', $agent, $pocket)) {
  180. return 'IE ' . subtok($pocket[1], '.', 0, 2);
  181. } elseif (preg_match('|Googlebot/([0-9a-z\.]*)|i', $agent, $pocket)) {
  182. return 'Google Bot ' . subtok($pocket[1], '/', 0, 2);
  183. } elseif (preg_match('|Yandex|i', $agent)) {
  184. return 'Yandex Bot ';
  185. } elseif (preg_match('|Nokia([0-9a-z\.\-\_]*)|i', $agent, $pocket)) {
  186. return 'Nokia '.$pocket[1];
  187. } else {
  188. $agent = preg_replace('|http://|i', '', $agent);
  189. $agent = strtok($agent, '/ ');
  190. $agent = substr($agent, 0, 22);
  191. $agent = subtok($agent, '.', 0, 2);
  192.  
  193. if (!empty($agent)) {
  194. return $agent;
  195. }
  196. }
  197. return 'Unknown';
  198. }
  199. function img($name) {
  200. return '<img src="/template/icons/'. $name .'" alt="Icon" /> ';
  201. }
  202. function nick($user_id) {
  203. global $db;
  204. if($db->query("SELECT * FROM `users` WHERE `id` = '". $user_id ."'")->rowCount() == 1) {
  205. $us = $db->query("SELECT * FROM `users` WHERE `id` = '". $user_id ."'")->fetch();
  206. if($us['time'] > (time()-300)) { $on = img('on.png'); } else { $on = img('off.png'); }
  207. return img($us['gender'].'.png') .' <a href="/user/'. $us['id'] .'/">'.($us['level'] >=6 ? '<span class="red">'.$us['nick'].'</span>' : ($us['level'] >= 2 && $us['level'] <= 5 ? '<span style="color:#22b14c;">'.$us['nick'].'</span>' : $us['nick'])) .'</a> '. $on;
  208. } else {
  209. return 'User Not Exists';
  210. }
  211. }
  212. function tnick($user_id) {
  213. global $db;
  214. if($db->query("SELECT * FROM `users` WHERE `id` = '". $user_id ."'")->rowCount() == 1) {
  215. $us = $db->query("SELECT * FROM `users` WHERE `id` = '". $user_id ."'")->fetch();
  216. return $us['nick'];
  217. } else {
  218. return 'User Not Exists';
  219. }
  220. }
  221. function avatar($user_nick) {
  222. if(file_exists(ROOT .'/files/avatars/'. $user_nick .'.png')) {
  223. return '<img src="/files/avatars/'. $user_nick .'.png" alt="'. $user_nick .'" /><br/>';
  224. }
  225. else {
  226. return '<img src="/files/preview/no_photo.png" alt="No photo" /><br/>';
  227. }
  228. }
  229.  
  230.  
  231. function cyrlat($cyr_str) {
  232. $tr = array(
  233. "Ґ"=>"G","Ё"=>"YO","Є"=>"E","Ї"=>"YI","І"=>"I",
  234. "і"=>"i","ґ"=>"g","ё"=>"yo","№"=>"","є"=>"e",
  235. "ї"=>"yi","А"=>"A","Б"=>"B","В"=>"V","Г"=>"G",
  236. "Д"=>"D","Е"=>"E","Ж"=>"ZH","З"=>"Z","И"=>"I",
  237. "Й"=>"Y","К"=>"K","Л"=>"L","М"=>"M","Н"=>"N",
  238. "О"=>"O","П"=>"P","Р"=>"R","С"=>"S","Т"=>"T",
  239. "У"=>"U","Ф"=>"F","Х"=>"H","Ц"=>"TS","Ч"=>"CH",
  240. "Ш"=>"SH","Щ"=>"SCH","Ъ"=>"'","Ы"=>"YI","Ь"=>"",
  241. "Э"=>"E","Ю"=>"YU","Я"=>"YA","а"=>"a","б"=>"b",
  242. "в"=>"v","г"=>"g","д"=>"d","е"=>"e","ж"=>"zh",
  243. "з"=>"z","и"=>"i","й"=>"y","к"=>"k","л"=>"l",
  244. "м"=>"m","н"=>"n","о"=>"o","п"=>"p","р"=>"r",
  245. "с"=>"s","т"=>"t","у"=>"u","ф"=>"f","х"=>"h",
  246. "ц"=>"ts","ч"=>"ch","ш"=>"sh","щ"=>"sch","ъ"=>"",
  247. "ы"=>"yi","ь"=>"","э"=>"e","ю"=>"yu","я"=>"ya",
  248. " "=>"-", "_"=>"-", "~"=>"-", "`" => "", "!"=>"",
  249. "@"=>"-", "#"=>"", "$"=>"", "%"=>"", "^"=>"",
  250. "&"=>"", "*"=>"", "("=>"", ")"=>"", "+"=>"-",
  251. "\\"=>"", "="=>"-", ";"=>"", ":"=>"", "?"=>"",
  252. "<"=>"", ">"=>"",","=>"", "."=>"", "'"=>''
  253. );
  254. return strtolower(strtr($cyr_str,$tr));
  255. }
  256. function size($var) {
  257. if ($var >= 1073741824) return round($var/1073741824, 2) .' Gb';
  258. else if ($var >= 1048576) return round($var/1048576, 2) .' Mb';
  259. elseif($var >= 1024) return round($var/1024, 2) .' Kb';
  260. else return round($var) .' b';
  261. }
  262.  
  263. function user_level($user_id) {
  264. global $db;
  265. if($db->query("SELECT * FROM `users` WHERE `id` = '$user_id'")->rowCount() == 1)
  266. {
  267. $level = $db->query("SELECT level FROM `users` WHERE `id` = '$user_id'")->fetchColumn();
  268. if($level == 1) {
  269. return 'User';
  270. } elseif($level == 2) {
  271. return 'ChatMod';
  272. } elseif($level == 3) {
  273. return 'ForumMod';
  274. } elseif($level == 4) {
  275. return 'ShareMod';
  276. } elseif($level == 5) {
  277. return 'SuperMod';
  278. } elseif($level == 6) {
  279. return 'Admin';
  280. } elseif($level == 7) {
  281. return 'SuperAdmin';
  282. } else {
  283. return 'Undefined';
  284. }
  285. } else {
  286. return 'User not exists';
  287. }
  288. }
  289. function level($level) {
  290. if($level == 1) {
  291. return 'User';
  292. } elseif($level == 2) {
  293. return 'ChatMod';
  294. } elseif($level == 3) {
  295. return 'ForumMod';
  296. } elseif($level == 4) {
  297. return 'ShareMod';
  298. } elseif($level == 5) {
  299. return 'SuperMod';
  300. } elseif($level == 6) {
  301. return 'Admin';
  302. } elseif($level == 7) {
  303. return 'SuperAdmin';
  304. } else {
  305. return 'Undefined';
  306. }
  307. }
  308.  
  309. function title() {
  310. global $title;
  311. global $system;
  312. if(!empty($title)) { return ''.$title.''; } else { return 'Page of PerfCMS'; }
  313. }
  314. function user_panel() {
  315. global $lang;
  316. global $user;
  317. return (isset($user) ? '<a href="/user/panel/">'. $lang->word('user_panel') .'</a> | <a href="/exit/">'. $lang->word('sign_out') .'</a>' : '<a href="/sign_in/">'. $lang->word('sign_in') .'</a> | <a href="/sign_up/">'. $lang->word('sign_up') .'</a>') . ($user['level'] >= 6 ? ' | <a href="/padmin/">'. $lang->word('admin_panel').'</a>' : NULL);
  318. }