This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include
, or for example
via PHP's auto-loading mechanism.
1 | <?php |
||||||
2 | |||||||
3 | namespace XoopsModules\Xoopstube; |
||||||
4 | |||||||
5 | /* |
||||||
6 | You may not change or alter any portion of this comment or credits |
||||||
7 | of supporting developers from this source code or any supporting source code |
||||||
8 | which is considered copyrighted (c) material of the original comment or credit authors. |
||||||
9 | |||||||
10 | This program is distributed in the hope that it will be useful, |
||||||
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
||||||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
||||||
13 | */ |
||||||
14 | |||||||
15 | use WideImage\WideImage; |
||||||
16 | use Xmf\Request; |
||||||
17 | use XoopsModules\Xoopstube\{ |
||||||
18 | Common, |
||||||
19 | Helper |
||||||
0 ignored issues
–
show
|
|||||||
20 | }; |
||||||
21 | |||||||
22 | /** |
||||||
23 | * xoopstube |
||||||
24 | * |
||||||
25 | * @copyright XOOPS Project (https://xoops.org) |
||||||
26 | * @license https://www.fsf.org/copyleft/gpl.html GNU public license |
||||||
27 | * @author Hervé Thouzard (http://www.herve-thouzard.com/) |
||||||
28 | */ |
||||||
29 | |||||||
30 | /** |
||||||
31 | * A set of useful and common functions |
||||||
32 | * |
||||||
33 | * @package xoopstube |
||||||
34 | * @author Hervé Thouzard - Instant Zero (http://xoops.instant-zero.com) |
||||||
35 | * @copyright (c) Instant Zero |
||||||
36 | * |
||||||
37 | * Note: You should be able to use it without the need to instantiate it. |
||||||
38 | */ |
||||||
39 | |||||||
40 | //require_once dirname(__DIR__) . '/include/common.php'; |
||||||
41 | |||||||
42 | /** |
||||||
43 | * Class Utility |
||||||
44 | */ |
||||||
45 | class Utility extends Common\SysUtility |
||||||
46 | { |
||||||
47 | //--------------- Custom module methods ----------------------------- |
||||||
48 | |||||||
49 | public const MODULE_NAME = 'xoopstube'; |
||||||
50 | |||||||
51 | /** |
||||||
52 | * Access the only instance of this class |
||||||
53 | * |
||||||
54 | * @return \XoopsModules\Xoopstube\Utility |
||||||
55 | * |
||||||
56 | * @static |
||||||
57 | * @staticvar object |
||||||
58 | */ |
||||||
59 | public static function getInstance() |
||||||
60 | { |
||||||
61 | static $instance; |
||||||
62 | if (null === $instance) { |
||||||
63 | $instance = new static(); |
||||||
64 | } |
||||||
65 | |||||||
66 | return $instance; |
||||||
67 | } |
||||||
68 | |||||||
69 | /** |
||||||
70 | * Returns a module's option (with cache) |
||||||
71 | * |
||||||
72 | * @param string $option module option's name |
||||||
73 | * @param bool $withCache Do we have to use some cache ? |
||||||
74 | * |
||||||
75 | * @return mixed option's value |
||||||
76 | */ |
||||||
77 | public static function getModuleOption($option, $withCache = true) |
||||||
78 | { |
||||||
79 | global $xoopsModuleConfig, $xoopsModule; |
||||||
80 | $repmodule = self::MODULE_NAME; |
||||||
81 | static $options = []; |
||||||
82 | if (\is_array($options) && \array_key_exists($option, $options) && $withCache) { |
||||||
83 | return $options[$option]; |
||||||
84 | } |
||||||
85 | |||||||
86 | $retval = false; |
||||||
87 | if (isset($xoopsModuleConfig) && (\is_object($xoopsModule) && $xoopsModule->getVar('dirname') == $repmodule && $xoopsModule->getVar('isactive'))) { |
||||||
88 | if (isset($xoopsModuleConfig[$option])) { |
||||||
89 | $retval = $xoopsModuleConfig[$option]; |
||||||
90 | } |
||||||
91 | } else { |
||||||
92 | /** @var \XoopsModuleHandler $moduleHandler */ |
||||||
93 | $moduleHandler = \xoops_getHandler('module'); |
||||||
94 | $module = $moduleHandler->getByDirname($repmodule); |
||||||
95 | /** @var \XoopsConfigHandler $configHandler */ |
||||||
96 | $configHandler = \xoops_getHandler('config'); |
||||||
97 | if ($module) { |
||||||
98 | $moduleConfig = $configHandler->getConfigsByCat(0, $module->getVar('mid')); |
||||||
99 | if (isset($moduleConfig[$option])) { |
||||||
100 | $retval = $moduleConfig[$option]; |
||||||
101 | } |
||||||
102 | } |
||||||
103 | } |
||||||
104 | $options[$option] = $retval; |
||||||
105 | |||||||
106 | return $retval; |
||||||
107 | } |
||||||
108 | |||||||
109 | /** |
||||||
110 | * Is Xoops 2.3.x ? |
||||||
111 | * |
||||||
112 | * @return bool |
||||||
113 | */ |
||||||
114 | public static function isX23() |
||||||
115 | { |
||||||
116 | $x23 = false; |
||||||
117 | $xv = \str_replace('XOOPS ', '', \XOOPS_VERSION); |
||||||
118 | if ((int)mb_substr($xv, 2, 1) >= 3) { |
||||||
119 | $x23 = true; |
||||||
120 | } |
||||||
121 | |||||||
122 | return $x23; |
||||||
123 | } |
||||||
124 | |||||||
125 | /** |
||||||
126 | * Is Xoops 2.0.x ? |
||||||
127 | * |
||||||
128 | * @return bool |
||||||
129 | */ |
||||||
130 | public static function isX20() |
||||||
131 | { |
||||||
132 | $x20 = false; |
||||||
133 | $xv = \str_replace('XOOPS ', '', \XOOPS_VERSION); |
||||||
134 | if ('0' == mb_substr($xv, 2, 1)) { |
||||||
135 | $x20 = true; |
||||||
136 | } |
||||||
137 | |||||||
138 | return $x20; |
||||||
139 | } |
||||||
140 | |||||||
141 | /** |
||||||
142 | * Create (in a link) a javascript confirmation's box |
||||||
143 | * |
||||||
144 | * @param string $message Message to display |
||||||
145 | * @param bool $form Is this a confirmation for a form ? |
||||||
146 | * |
||||||
147 | * @return string the javascript code to insert in the link (or in the form) |
||||||
148 | */ |
||||||
149 | public static function javascriptLinkConfirm($message, $form = false) |
||||||
150 | { |
||||||
151 | if (!$form) { |
||||||
152 | return "onclick=\"javascript:return confirm('" . \str_replace("'", ' ', $message) . "')\""; |
||||||
153 | } |
||||||
154 | |||||||
155 | return "onSubmit=\"javascript:return confirm('" . \str_replace("'", ' ', $message) . "')\""; |
||||||
156 | } |
||||||
157 | |||||||
158 | /** |
||||||
159 | * Get current user IP |
||||||
160 | * |
||||||
161 | * @return string IP address (format Ipv4) |
||||||
162 | */ |
||||||
163 | public static function IP() |
||||||
164 | { |
||||||
165 | $proxy_ip = ''; |
||||||
166 | if (Request::hasVar('HTTP_X_FORWARDED_FOR', 'SERVER')) { |
||||||
167 | $proxy_ip = $_SERVER['HTTP_X_FORWARDED_FOR']; |
||||||
168 | } elseif (!empty($_SERVER['HTTP_X_FORWARDED'])) { |
||||||
169 | $proxy_ip = $_SERVER['HTTP_X_FORWARDED']; |
||||||
170 | } elseif (!empty($_SERVER['HTTP_FORWARDED_FOR'])) { |
||||||
171 | $proxy_ip = $_SERVER['HTTP_FORWARDED_FOR']; |
||||||
172 | } elseif (!empty($_SERVER['HTTP_FORWARDED'])) { |
||||||
173 | $proxy_ip = $_SERVER['HTTP_FORWARDED']; |
||||||
174 | } elseif (!empty($_SERVER['HTTP_VIA'])) { |
||||||
175 | $proxy_ip = $_SERVER['HTTP_VIA']; |
||||||
176 | } elseif (!empty($_SERVER['HTTP_X_COMING_FROM'])) { |
||||||
177 | $proxy_ip = $_SERVER['HTTP_X_COMING_FROM']; |
||||||
178 | } elseif (!empty($_SERVER['HTTP_COMING_FROM'])) { |
||||||
179 | $proxy_ip = $_SERVER['HTTP_COMING_FROM']; |
||||||
180 | } |
||||||
181 | $regs = []; |
||||||
182 | //if (!empty($proxy_ip) && $is_ip = ereg('^(\d{1,3}\.){3,3}\d{1,3}', $proxy_ip, $regs) && count($regs) > 0) { |
||||||
183 | if (!empty($proxy_ip) && \filter_var($proxy_ip, \FILTER_VALIDATE_IP) && \count($regs) > 0) { |
||||||
184 | $the_IP = $regs[0]; |
||||||
185 | } else { |
||||||
186 | $the_IP = $_SERVER['REMOTE_ADDR']; |
||||||
187 | } |
||||||
188 | |||||||
189 | return $the_IP; |
||||||
190 | } |
||||||
191 | |||||||
192 | /** |
||||||
193 | * Set the page's title, meta description and meta keywords |
||||||
194 | * Datas are supposed to be sanitized |
||||||
195 | * |
||||||
196 | * @param string $pageTitle Page's Title |
||||||
197 | * @param string $metaDescription Page's meta description |
||||||
198 | * @param string $metaKeywords Page's meta keywords |
||||||
199 | */ |
||||||
200 | public static function setMetas($pageTitle = '', $metaDescription = '', $metaKeywords = '') |
||||||
201 | { |
||||||
202 | global $xoTheme, $xoTheme, $xoopsTpl; |
||||||
203 | $xoopsTpl->assign('xoops_pagetitle', $pageTitle); |
||||||
204 | if (isset($xoTheme) && \is_object($xoTheme)) { |
||||||
205 | if (!empty($metaKeywords)) { |
||||||
206 | $xoTheme->addMeta('meta', 'keywords', $metaKeywords); |
||||||
207 | } |
||||||
208 | if (!empty($metaDescription)) { |
||||||
209 | $xoTheme->addMeta('meta', 'description', $metaDescription); |
||||||
210 | } |
||||||
211 | } elseif (isset($xoopsTpl) && \is_object($xoopsTpl)) { // Compatibility for old Xoops versions |
||||||
212 | if (!empty($metaKeywords)) { |
||||||
213 | $xoopsTpl->assign('xoops_meta_keywords', $metaKeywords); |
||||||
214 | } |
||||||
215 | if (!empty($metaDescription)) { |
||||||
216 | $xoopsTpl->assign('xoops_meta_description', $metaDescription); |
||||||
217 | } |
||||||
218 | } |
||||||
219 | } |
||||||
220 | |||||||
221 | /** |
||||||
222 | * Send an email from a template to a list of recipients |
||||||
223 | * |
||||||
224 | * @param $tplName |
||||||
225 | * @param array $recipients List of recipients |
||||||
226 | * @param string $subject Email's subject |
||||||
227 | * @param array $variables Varirables to give to the template |
||||||
228 | * |
||||||
229 | * @return bool Result of the send |
||||||
230 | * @internal param string $tpl_name Template's name |
||||||
231 | */ |
||||||
232 | public static function sendEmailFromTpl($tplName, $recipients, $subject, $variables) |
||||||
233 | { |
||||||
234 | global $xoopsConfig; |
||||||
235 | require_once XOOPS_ROOT_PATH . '/class/xoopsmailer.php'; |
||||||
236 | if (!\is_array($recipients)) { |
||||||
237 | if ('' === \trim($recipients)) { |
||||||
238 | return false; |
||||||
239 | } |
||||||
240 | } elseif (0 == \count($recipients)) { |
||||||
241 | return false; |
||||||
242 | } |
||||||
243 | if (\function_exists('xoops_getMailer')) { |
||||||
244 | $xoopsMailer = \xoops_getMailer(); |
||||||
245 | } else { |
||||||
246 | $xoopsMailer = \getMailer(); |
||||||
247 | } |
||||||
248 | |||||||
249 | $xoopsMailer->useMail(); |
||||||
250 | $templateDir = XOOPS_ROOT_PATH . '/modules/' . self::MODULE_NAME . '/language/' . $xoopsConfig['language'] . '/mail_template'; |
||||||
251 | if (!\is_dir($templateDir)) { |
||||||
252 | $templateDir = XOOPS_ROOT_PATH . '/modules/' . self::MODULE_NAME . '/language/english/mail_template'; |
||||||
253 | } |
||||||
254 | $xoopsMailer->setTemplateDir($templateDir); |
||||||
255 | $xoopsMailer->setTemplate($tplName); |
||||||
256 | $xoopsMailer->setToEmails($recipients); |
||||||
257 | // TODO: Change ! |
||||||
258 | // $xoopsMailer->setFromEmail('[email protected]'); |
||||||
259 | //$xoopsMailer->setFromName('MonSite'); |
||||||
260 | $xoopsMailer->setSubject($subject); |
||||||
261 | foreach ($variables as $key => $value) { |
||||||
262 | $xoopsMailer->assign($key, $value); |
||||||
263 | } |
||||||
264 | $res = $xoopsMailer->send(); |
||||||
265 | unset($xoopsMailer); |
||||||
266 | $filename = XOOPS_UPLOAD_PATH . '/logmail_' . self::MODULE_NAME . '.php'; |
||||||
267 | if (!\is_file($filename)) { |
||||||
268 | $fp = @\fopen($filename, 'ab'); |
||||||
269 | if ($fp) { |
||||||
270 | \fwrite($fp, "<?php exit(); ?>\n"); |
||||||
271 | \fclose($fp); |
||||||
272 | } |
||||||
273 | } |
||||||
274 | $fp = @\fopen($filename, 'ab'); |
||||||
275 | |||||||
276 | if ($fp) { |
||||||
277 | \fwrite($fp, \str_repeat('-', 120) . "\n"); |
||||||
278 | \fwrite($fp, \date('d/m/Y H:i:s') . "\n"); |
||||||
279 | \fwrite($fp, 'Template name : ' . $tplName . "\n"); |
||||||
280 | \fwrite($fp, 'Email subject : ' . $subject . "\n"); |
||||||
281 | if (\is_array($recipients)) { |
||||||
282 | \fwrite($fp, 'Recipient(s) : ' . \implode(',', $recipients) . "\n"); |
||||||
283 | } else { |
||||||
284 | \fwrite($fp, 'Recipient(s) : ' . $recipients . "\n"); |
||||||
285 | } |
||||||
286 | \fwrite($fp, 'Transmited variables : ' . \implode(',', $variables) . "\n"); |
||||||
287 | \fclose($fp); |
||||||
288 | } |
||||||
289 | |||||||
290 | return $res; |
||||||
291 | } |
||||||
292 | |||||||
293 | /** |
||||||
294 | * Remove module's cache |
||||||
295 | */ |
||||||
296 | public static function updateCache() |
||||||
297 | { |
||||||
298 | global $xoopsModule; |
||||||
299 | $folder = $xoopsModule->getVar('dirname'); |
||||||
300 | $tpllist = []; |
||||||
301 | require_once XOOPS_ROOT_PATH . '/class/xoopsblock.php'; |
||||||
302 | require_once XOOPS_ROOT_PATH . '/class/template.php'; |
||||||
303 | $tplfileHandler = \xoops_getHandler('tplfile'); |
||||||
304 | $tpllist = $tplfileHandler->find(null, null, null, $folder); |
||||||
0 ignored issues
–
show
The method
find() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsTplfileHandler or XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
305 | \xoops_template_clear_module_cache($xoopsModule->getVar('mid')); // Clear module's blocks cache |
||||||
306 | |||||||
307 | foreach ($tpllist as $onetemplate) { // Remove cache for each page. |
||||||
308 | if ('module' === $onetemplate->getVar('tpl_type')) { |
||||||
309 | // Note, I've been testing all the other methods (like the one of Smarty) and none of them run, that's why I have used this code |
||||||
310 | $files_del = []; |
||||||
311 | $files_del = \glob(XOOPS_CACHE_PATH . '/*' . $onetemplate->getVar('tpl_file') . '*', \GLOB_NOSORT); |
||||||
312 | if (\count($files_del) > 0 && \is_array($files_del)) { |
||||||
313 | foreach ($files_del as $one_file) { |
||||||
314 | if (\is_file($one_file)) { |
||||||
315 | \unlink($one_file); |
||||||
316 | } |
||||||
317 | } |
||||||
318 | } |
||||||
319 | } |
||||||
320 | } |
||||||
321 | } |
||||||
322 | |||||||
323 | /** |
||||||
324 | * Redirect user with a message |
||||||
325 | * |
||||||
326 | * @param string $message message to display |
||||||
327 | * @param string $url The place where to go |
||||||
328 | * @param mixed $time |
||||||
329 | */ |
||||||
330 | public static function redirect($message = '', $url = 'index.php', $time = 2) |
||||||
331 | { |
||||||
332 | \redirect_header($url, $time, $message); |
||||||
333 | } |
||||||
334 | |||||||
335 | /** |
||||||
336 | * Returns the module's name (as defined by the user in the module manager) with cache |
||||||
337 | * |
||||||
338 | * @return string Module's name |
||||||
339 | */ |
||||||
340 | public static function getModuleName() |
||||||
341 | { |
||||||
342 | static $moduleName; |
||||||
343 | if (!isset($moduleName)) { |
||||||
344 | $mymodule = self::_getModule(); |
||||||
0 ignored issues
–
show
The method
_getModule() does not exist on XoopsModules\Xoopstube\Utility .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces. This is most likely a typographical error or the method has been renamed. ![]() |
|||||||
345 | $moduleName = $mymodule->getVar('name'); |
||||||
346 | } |
||||||
347 | |||||||
348 | return $moduleName; |
||||||
349 | } |
||||||
350 | |||||||
351 | /** |
||||||
352 | * Create a title for the href tags inside html links |
||||||
353 | * |
||||||
354 | * @param string $title Text to use |
||||||
355 | * |
||||||
356 | * @return string Formated text |
||||||
357 | */ |
||||||
358 | public static function makeHrefTitle($title) |
||||||
359 | { |
||||||
360 | $s = "\"'"; |
||||||
361 | $r = ' '; |
||||||
362 | |||||||
363 | return strtr($title, $s, $r); |
||||||
364 | } |
||||||
365 | |||||||
366 | /** |
||||||
367 | * Retourne la liste des utilisateurs appartenants à un groupe |
||||||
368 | * |
||||||
369 | * @param int $groupId Searched group |
||||||
370 | * |
||||||
371 | * @return array Array of XoopsUsers |
||||||
372 | */ |
||||||
373 | public static function getUsersFromGroup($groupId) |
||||||
374 | { |
||||||
375 | $users = []; |
||||||
376 | $memberHandler = \xoops_getHandler('member'); |
||||||
377 | $users = $memberHandler->getUsersByGroup($groupId, true); |
||||||
0 ignored issues
–
show
The method
getUsersByGroup() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsMembershipHandler or XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
378 | |||||||
379 | return $users; |
||||||
380 | } |
||||||
381 | |||||||
382 | /** |
||||||
383 | * Retourne la liste des emails des utilisateurs membres d'un groupe |
||||||
384 | * |
||||||
385 | * @param $groupId |
||||||
386 | * |
||||||
387 | * @return array Emails list |
||||||
388 | * @internal param int $group_id Group's number |
||||||
389 | */ |
||||||
390 | public static function getEmailsFromGroup($groupId) |
||||||
391 | { |
||||||
392 | $ret = []; |
||||||
393 | $users = self::getUsersFromGroup($groupId); |
||||||
394 | foreach ($users as $user) { |
||||||
395 | $ret[] = $user->getVar('email'); |
||||||
396 | } |
||||||
397 | |||||||
398 | return $ret; |
||||||
399 | } |
||||||
400 | |||||||
401 | /** |
||||||
402 | * Vérifie que l'utilisateur courant fait partie du groupe des administrateurs |
||||||
403 | * |
||||||
404 | * @return bool Admin or not |
||||||
405 | */ |
||||||
406 | public static function isAdmin() |
||||||
407 | { |
||||||
408 | global $xoopsUser, $xoopsModule; |
||||||
409 | if (\is_object($xoopsUser)) { |
||||||
410 | if (\in_array(XOOPS_GROUP_ADMIN, $xoopsUser->getGroups())) { |
||||||
411 | return true; |
||||||
412 | } |
||||||
413 | |||||||
414 | if (isset($xoopsModule) && $xoopsUser->isAdmin($xoopsModule->getVar('mid'))) { |
||||||
415 | return true; |
||||||
416 | } |
||||||
417 | } |
||||||
418 | |||||||
419 | return false; |
||||||
420 | } |
||||||
421 | |||||||
422 | /** |
||||||
423 | * Returns the current date in the Mysql format |
||||||
424 | * |
||||||
425 | * @return string Date in the Mysql format |
||||||
426 | */ |
||||||
427 | public static function getCurrentSQLDate() |
||||||
428 | { |
||||||
429 | return \date('Y-m-d'); // 2007-05-02 |
||||||
430 | } |
||||||
431 | |||||||
432 | /** |
||||||
433 | * @return bool|string |
||||||
434 | */ |
||||||
435 | public static function getCurrentSQLDateTime() |
||||||
436 | { |
||||||
437 | return \date('Y-m-d H:i:s'); // 2007-05-02 |
||||||
438 | } |
||||||
439 | |||||||
440 | /** |
||||||
441 | * Convert a Mysql date to the human's format |
||||||
442 | * |
||||||
443 | * @param string $date The date to convert |
||||||
444 | * @param string $format |
||||||
445 | * |
||||||
446 | * @return string The date in a human form |
||||||
447 | */ |
||||||
448 | public static function SQLDateToHuman($date, $format = 'l') |
||||||
449 | { |
||||||
450 | if ('0000-00-00' != $date && '' != \xoops_trim($date)) { |
||||||
451 | return \formatTimestamp(\strtotime($date), $format); |
||||||
452 | } |
||||||
453 | |||||||
454 | return ''; |
||||||
455 | } |
||||||
456 | |||||||
457 | /** |
||||||
458 | * Convert a timestamp to a Mysql date |
||||||
459 | * |
||||||
460 | * @param int $timestamp The timestamp to use |
||||||
461 | * |
||||||
462 | * @return string The date in the Mysql format |
||||||
463 | */ |
||||||
464 | public static function timestampToMysqlDate($timestamp) |
||||||
465 | { |
||||||
466 | return \date('Y-m-d', (int)$timestamp); |
||||||
467 | } |
||||||
468 | |||||||
469 | /** |
||||||
470 | * Conversion d'un dateTime Mysql en date lisible en français |
||||||
471 | * |
||||||
472 | * @param $dateTime |
||||||
473 | * |
||||||
474 | * @return bool|string |
||||||
475 | */ |
||||||
476 | public static function sqlDateTimeToFrench($dateTime) |
||||||
477 | { |
||||||
478 | return \date('d/m/Y H:i:s', \strtotime($dateTime)); |
||||||
479 | } |
||||||
480 | |||||||
481 | /** |
||||||
482 | * Convert a timestamp to a Mysql datetime form |
||||||
483 | * |
||||||
484 | * @param int $timestamp The timestamp to use |
||||||
485 | * |
||||||
486 | * @return string The date and time in the Mysql format |
||||||
487 | */ |
||||||
488 | public static function timestampToMysqlDateTime($timestamp) |
||||||
489 | { |
||||||
490 | return \date('Y-m-d H:i:s', $timestamp); |
||||||
491 | } |
||||||
492 | |||||||
493 | /** |
||||||
494 | * This function indicates if the current Xoops version needs to add asterisks to required fields in forms |
||||||
495 | * |
||||||
496 | * @return bool Yes = we need to add them, false = no |
||||||
497 | */ |
||||||
498 | public static function needsAsterisk() |
||||||
499 | { |
||||||
500 | if (self::isX23()) { |
||||||
501 | return false; |
||||||
502 | } |
||||||
503 | if (false !== mb_stripos(\XOOPS_VERSION, 'impresscms')) { |
||||||
504 | return false; |
||||||
505 | } |
||||||
506 | if (false === mb_stripos(\XOOPS_VERSION, 'legacy')) { |
||||||
507 | $xv = \xoops_trim(\str_replace('XOOPS ', '', \XOOPS_VERSION)); |
||||||
508 | if ((int)mb_substr($xv, 4, 2) >= 17) { |
||||||
509 | return false; |
||||||
510 | } |
||||||
511 | } |
||||||
512 | |||||||
513 | return true; |
||||||
514 | } |
||||||
515 | |||||||
516 | /** |
||||||
517 | * Mark the mandatory fields of a form with a star |
||||||
518 | * |
||||||
519 | * @param \XoopsForm $sform The form to modify |
||||||
520 | * |
||||||
521 | * @return \XoopsForm The modified form |
||||||
522 | * @internal param string $caracter The character to use to mark fields |
||||||
523 | */ |
||||||
524 | public static function &formMarkRequiredFields(\XoopsForm $sform) |
||||||
525 | { |
||||||
526 | if (self::needsAsterisk()) { |
||||||
527 | $required = []; |
||||||
528 | $elements = []; |
||||||
529 | foreach ($sform->getRequired() as $item) { |
||||||
530 | $required[] = $item->_name; |
||||||
531 | } |
||||||
532 | $elements = $sform->getElements(); |
||||||
533 | foreach ($elements as $iValue) { |
||||||
534 | if (\is_object($iValue) && \in_array($iValue->_name, $required)) { |
||||||
535 | $iValue->_caption .= ' *'; |
||||||
536 | } |
||||||
537 | } |
||||||
538 | } |
||||||
539 | |||||||
540 | return $sform; |
||||||
541 | } |
||||||
542 | |||||||
543 | /** |
||||||
544 | * Create a html heading (from h1 to h6) |
||||||
545 | * |
||||||
546 | * @param string $title The text to use |
||||||
547 | * @param int $level Level to return |
||||||
548 | * |
||||||
549 | * @return void The heading |
||||||
550 | */ |
||||||
551 | public static function htitle($title = '', $level = 1) |
||||||
552 | { |
||||||
553 | \printf('<h%01d>%s</h%01d>', $level, $title, $level); |
||||||
554 | } |
||||||
555 | |||||||
556 | /** |
||||||
557 | * Create a unique upload filename |
||||||
558 | * |
||||||
559 | * @param string $folder The folder where the file will be saved |
||||||
560 | * @param string $fileName Original filename (coming from the user) |
||||||
561 | * @param bool $trimName Do we need to create a "short" unique name ? |
||||||
562 | * |
||||||
563 | * @return string The unique filename to use (with its extension) |
||||||
564 | */ |
||||||
565 | public static function createUploadName($folder, $fileName, $trimName = false) |
||||||
566 | { |
||||||
567 | $workingfolder = $folder; |
||||||
568 | if ('/' !== \xoops_substr($workingfolder, mb_strlen($workingfolder) - 1, 1)) { |
||||||
569 | $workingfolder .= '/'; |
||||||
570 | } |
||||||
571 | $ext = \basename($fileName); |
||||||
572 | $ext = \explode('.', $ext); |
||||||
573 | $ext = '.' . $ext[\count($ext) - 1]; |
||||||
574 | $true = true; |
||||||
575 | while ($true) { |
||||||
576 | $ipbits = \explode('.', $_SERVER['REMOTE_ADDR']); |
||||||
577 | [$usec, $sec] = \explode(' ', \microtime()); |
||||||
578 | $usec *= 65536; |
||||||
579 | $sec = ((int)$sec) & 0xFFFF; |
||||||
580 | |||||||
581 | if ($trimName) { |
||||||
582 | $uid = \sprintf('%06x%04x%04x', ($ipbits[0] << 24) | ($ipbits[1] << 16) | ($ipbits[2] << 8) | $ipbits[3], $sec, $usec); |
||||||
583 | } else { |
||||||
584 | $uid = \sprintf('%08x-%04x-%04x', ($ipbits[0] << 24) | ($ipbits[1] << 16) | ($ipbits[2] << 8) | $ipbits[3], $sec, $usec); |
||||||
585 | } |
||||||
586 | if (!\file_exists($workingfolder . $uid . $ext)) { |
||||||
587 | $true = false; |
||||||
588 | } |
||||||
589 | } |
||||||
590 | |||||||
591 | return $uid . $ext; |
||||||
592 | } |
||||||
593 | |||||||
594 | /** |
||||||
595 | * Replace html entities with their ASCII equivalent |
||||||
596 | * |
||||||
597 | * @param string $chaine The string undecode |
||||||
598 | * |
||||||
599 | * @return string The undecoded string |
||||||
600 | */ |
||||||
601 | public static function unhtml($chaine) |
||||||
602 | { |
||||||
603 | $search = $replace = []; |
||||||
604 | $chaine = \html_entity_decode($chaine); |
||||||
605 | |||||||
606 | for ($i = 0; $i <= 255; ++$i) { |
||||||
607 | $search[] = '&#' . $i . ';'; |
||||||
608 | $replace[] = \chr($i); |
||||||
609 | } |
||||||
610 | $replace[] = '...'; |
||||||
611 | $search[] = ' '; |
||||||
612 | $replace[] = "'"; |
||||||
613 | $search[] = ''; |
||||||
614 | $replace[] = "'"; |
||||||
615 | $search[] = ''; |
||||||
616 | $replace[] = '-'; |
||||||
617 | $search[] = '•'; // $replace[] = ''; |
||||||
618 | $replace[] = ''; |
||||||
619 | $search[] = '—'; |
||||||
620 | $replace[] = '-'; |
||||||
621 | $search[] = '–'; |
||||||
622 | $replace[] = '-'; |
||||||
623 | $search[] = '­'; |
||||||
624 | $replace[] = '"'; |
||||||
625 | $search[] = '"'; |
||||||
626 | $replace[] = '&'; |
||||||
627 | $search[] = '&'; |
||||||
628 | $replace[] = ''; |
||||||
629 | $search[] = 'ˆ'; |
||||||
630 | $replace[] = '¡'; |
||||||
631 | $search[] = '¡'; |
||||||
632 | $replace[] = '¦'; |
||||||
633 | $search[] = '¦'; |
||||||
634 | $replace[] = '¨'; |
||||||
635 | $search[] = '¨'; |
||||||
636 | $replace[] = '¯'; |
||||||
637 | $search[] = '¯'; |
||||||
638 | $replace[] = '´'; |
||||||
639 | $search[] = '´'; |
||||||
640 | $replace[] = '¸'; |
||||||
641 | $search[] = '¸'; |
||||||
642 | $replace[] = '¿'; |
||||||
643 | $search[] = '¿'; |
||||||
644 | $replace[] = ''; |
||||||
645 | $search[] = '˜'; |
||||||
646 | $replace[] = "'"; |
||||||
647 | $search[] = '‘'; // $replace[]=''; |
||||||
648 | $replace[] = "'"; |
||||||
649 | $search[] = '’'; // $replace[]=''; |
||||||
650 | $replace[] = ''; |
||||||
651 | $search[] = '‚'; |
||||||
652 | $replace[] = "'"; |
||||||
653 | $search[] = '“'; // $replace[]=''; |
||||||
654 | $replace[] = "'"; |
||||||
655 | $search[] = '”'; // $replace[]=''; |
||||||
656 | $replace[] = ''; |
||||||
657 | $search[] = '„'; |
||||||
658 | $replace[] = ''; |
||||||
659 | $search[] = '‹'; |
||||||
660 | $replace[] = ''; |
||||||
661 | $search[] = '›'; |
||||||
662 | $replace[] = '<'; |
||||||
663 | $search[] = '<'; |
||||||
664 | $replace[] = '>'; |
||||||
665 | $search[] = '>'; |
||||||
666 | $replace[] = '±'; |
||||||
667 | $search[] = '±'; |
||||||
668 | $replace[] = '«'; |
||||||
669 | $search[] = '«'; |
||||||
670 | $replace[] = '»'; |
||||||
671 | $search[] = '»'; |
||||||
672 | $replace[] = '×'; |
||||||
673 | $search[] = '×'; |
||||||
674 | $replace[] = '÷'; |
||||||
675 | $search[] = '÷'; |
||||||
676 | $replace[] = '¢'; |
||||||
677 | $search[] = '¢'; |
||||||
678 | $replace[] = '£'; |
||||||
679 | $search[] = '£'; |
||||||
680 | $replace[] = '¤'; |
||||||
681 | $search[] = '¤'; |
||||||
682 | $replace[] = '¥'; |
||||||
683 | $search[] = '¥'; |
||||||
684 | $replace[] = '§'; |
||||||
685 | $search[] = '§'; |
||||||
686 | $replace[] = '©'; |
||||||
687 | $search[] = '©'; |
||||||
688 | $replace[] = '¬'; |
||||||
689 | $search[] = '¬'; |
||||||
690 | $replace[] = '®'; |
||||||
691 | $search[] = '®'; |
||||||
692 | $replace[] = '°'; |
||||||
693 | $search[] = '°'; |
||||||
694 | $replace[] = 'µ'; |
||||||
695 | $search[] = 'µ'; |
||||||
696 | $replace[] = '¶'; |
||||||
697 | $search[] = '¶'; |
||||||
698 | $replace[] = '·'; |
||||||
699 | $search[] = '·'; |
||||||
700 | $replace[] = ''; |
||||||
701 | $search[] = '†'; |
||||||
702 | $replace[] = ''; |
||||||
703 | $search[] = '‡'; |
||||||
704 | $replace[] = ''; |
||||||
705 | $search[] = '‰'; |
||||||
706 | $replace[] = 'Euro'; |
||||||
707 | $search[] = '€'; // $replace[]='' |
||||||
708 | $replace[] = '¼'; |
||||||
709 | $search[] = '¼'; |
||||||
710 | $replace[] = '½'; |
||||||
711 | $search[] = '½'; |
||||||
712 | $replace[] = '¾'; |
||||||
713 | $search[] = '¾'; |
||||||
714 | $replace[] = '¹'; |
||||||
715 | $search[] = '¹'; |
||||||
716 | $replace[] = '²'; |
||||||
717 | $search[] = '²'; |
||||||
718 | $replace[] = '³'; |
||||||
719 | $search[] = '³'; |
||||||
720 | $replace[] = 'á'; |
||||||
721 | $search[] = 'á'; |
||||||
722 | $replace[] = 'Á'; |
||||||
723 | $search[] = 'Á'; |
||||||
724 | $replace[] = 'â'; |
||||||
725 | $search[] = 'â'; |
||||||
726 | $replace[] = 'Â'; |
||||||
727 | $search[] = 'Â'; |
||||||
728 | $replace[] = 'à'; |
||||||
729 | $search[] = 'à'; |
||||||
730 | $replace[] = 'À'; |
||||||
731 | $search[] = 'À'; |
||||||
732 | $replace[] = 'å'; |
||||||
733 | $search[] = 'å'; |
||||||
734 | $replace[] = 'Å'; |
||||||
735 | $search[] = 'Å'; |
||||||
736 | $replace[] = 'ã'; |
||||||
737 | $search[] = 'ã'; |
||||||
738 | $replace[] = 'Ã'; |
||||||
739 | $search[] = 'Ã'; |
||||||
740 | $replace[] = 'ä'; |
||||||
741 | $search[] = 'ä'; |
||||||
742 | $replace[] = 'Ä'; |
||||||
743 | $search[] = 'Ä'; |
||||||
744 | $replace[] = 'ª'; |
||||||
745 | $search[] = 'ª'; |
||||||
746 | $replace[] = 'æ'; |
||||||
747 | $search[] = 'æ'; |
||||||
748 | $replace[] = 'Æ'; |
||||||
749 | $search[] = 'Æ'; |
||||||
750 | $replace[] = 'ç'; |
||||||
751 | $search[] = 'ç'; |
||||||
752 | $replace[] = 'Ç'; |
||||||
753 | $search[] = 'Ç'; |
||||||
754 | $replace[] = 'ð'; |
||||||
755 | $search[] = 'ð'; |
||||||
756 | $replace[] = 'Ð'; |
||||||
757 | $search[] = 'Ð'; |
||||||
758 | $replace[] = 'é'; |
||||||
759 | $search[] = 'é'; |
||||||
760 | $replace[] = 'É'; |
||||||
761 | $search[] = 'É'; |
||||||
762 | $replace[] = 'ê'; |
||||||
763 | $search[] = 'ê'; |
||||||
764 | $replace[] = 'Ê'; |
||||||
765 | $search[] = 'Ê'; |
||||||
766 | $replace[] = 'è'; |
||||||
767 | $search[] = 'è'; |
||||||
768 | $replace[] = 'È'; |
||||||
769 | $search[] = 'È'; |
||||||
770 | $replace[] = 'ë'; |
||||||
771 | $search[] = 'ë'; |
||||||
772 | $replace[] = 'Ë'; |
||||||
773 | $search[] = 'Ë'; |
||||||
774 | $replace[] = ''; |
||||||
775 | $search[] = 'ƒ'; |
||||||
776 | $replace[] = 'í'; |
||||||
777 | $search[] = 'í'; |
||||||
778 | $replace[] = 'Í'; |
||||||
779 | $search[] = 'Í'; |
||||||
780 | $replace[] = 'î'; |
||||||
781 | $search[] = 'î'; |
||||||
782 | $replace[] = 'Î'; |
||||||
783 | $search[] = 'Î'; |
||||||
784 | $replace[] = 'ì'; |
||||||
785 | $search[] = 'ì'; |
||||||
786 | $replace[] = 'Ì'; |
||||||
787 | $search[] = 'Ì'; |
||||||
788 | $replace[] = 'ï'; |
||||||
789 | $search[] = 'ï'; |
||||||
790 | $replace[] = 'Ï'; |
||||||
791 | $search[] = 'Ï'; |
||||||
792 | $replace[] = 'ñ'; |
||||||
793 | $search[] = 'ñ'; |
||||||
794 | $replace[] = 'Ñ'; |
||||||
795 | $search[] = 'Ñ'; |
||||||
796 | $replace[] = 'ó'; |
||||||
797 | $search[] = 'ó'; |
||||||
798 | $replace[] = 'Ó'; |
||||||
799 | $search[] = 'Ó'; |
||||||
800 | $replace[] = 'ô'; |
||||||
801 | $search[] = 'ô'; |
||||||
802 | $replace[] = 'Ô'; |
||||||
803 | $search[] = 'Ô'; |
||||||
804 | $replace[] = 'ò'; |
||||||
805 | $search[] = 'ò'; |
||||||
806 | $replace[] = 'Ò'; |
||||||
807 | $search[] = 'Ò'; |
||||||
808 | $replace[] = 'º'; |
||||||
809 | $search[] = 'º'; |
||||||
810 | $replace[] = 'ø'; |
||||||
811 | $search[] = 'ø'; |
||||||
812 | $replace[] = 'Ø'; |
||||||
813 | $search[] = 'Ø'; |
||||||
814 | $replace[] = 'õ'; |
||||||
815 | $search[] = 'õ'; |
||||||
816 | $replace[] = 'Õ'; |
||||||
817 | $search[] = 'Õ'; |
||||||
818 | $replace[] = 'ö'; |
||||||
819 | $search[] = 'ö'; |
||||||
820 | $replace[] = 'Ö'; |
||||||
821 | $search[] = 'Ö'; |
||||||
822 | $replace[] = ''; |
||||||
823 | $search[] = 'œ'; |
||||||
824 | $replace[] = ''; |
||||||
825 | $search[] = 'Œ'; |
||||||
826 | $replace[] = ''; |
||||||
827 | $search[] = 'š'; |
||||||
828 | $replace[] = ''; |
||||||
829 | $search[] = 'Š'; |
||||||
830 | $replace[] = 'ß'; |
||||||
831 | $search[] = 'ß'; |
||||||
832 | $replace[] = 'þ'; |
||||||
833 | $search[] = 'þ'; |
||||||
834 | $replace[] = 'Þ'; |
||||||
835 | $search[] = 'Þ'; |
||||||
836 | $replace[] = 'ú'; |
||||||
837 | $search[] = 'ú'; |
||||||
838 | $replace[] = 'Ú'; |
||||||
839 | $search[] = 'Ú'; |
||||||
840 | $replace[] = 'û'; |
||||||
841 | $search[] = 'û'; |
||||||
842 | $replace[] = 'Û'; |
||||||
843 | $search[] = 'Û'; |
||||||
844 | $replace[] = 'ù'; |
||||||
845 | $search[] = 'ù'; |
||||||
846 | $replace[] = 'Ù'; |
||||||
847 | $search[] = 'Ù'; |
||||||
848 | $replace[] = 'ü'; |
||||||
849 | $search[] = 'ü'; |
||||||
850 | $replace[] = 'Ü'; |
||||||
851 | $search[] = 'Ü'; |
||||||
852 | $replace[] = 'ý'; |
||||||
853 | $search[] = 'ý'; |
||||||
854 | $replace[] = 'Ý'; |
||||||
855 | $search[] = 'Ý'; |
||||||
856 | $replace[] = 'ÿ'; |
||||||
857 | $search[] = 'ÿ'; |
||||||
858 | $replace[] = ''; |
||||||
859 | $search[] = 'Ÿ'; |
||||||
860 | $chaine = \str_replace($search, $replace, $chaine); |
||||||
861 | |||||||
862 | return $chaine; |
||||||
863 | } |
||||||
864 | |||||||
865 | /** |
||||||
866 | * Create a title to be used by the url rewriting |
||||||
867 | * |
||||||
868 | * @param string $content The text to use to create the url |
||||||
869 | * @param int $urw The lower limit to create words |
||||||
870 | * |
||||||
871 | * @return string The text to use for the url |
||||||
872 | * Note, some parts are from Solo's code |
||||||
873 | */ |
||||||
874 | public static function makeSeoUrl($content, $urw = 1) |
||||||
875 | { |
||||||
876 | $s = "ÀÁÂÃÄÅÒÓÔÕÖØÈÉÊËÇÌÍÎÏÙÚÛÜÑàáâãäåòóôõöøèéêëçìíîïùúûüÿñ '()"; |
||||||
877 | $r = 'AAAAAAOOOOOOEEEECIIIIUUUUYNaaaaaaooooooeeeeciiiiuuuuyn----'; |
||||||
878 | $content = self::unhtml($content); // First, remove html entities |
||||||
879 | $content = strtr($content, $s, $r); |
||||||
880 | $content = \strip_tags($content); |
||||||
881 | $content = mb_strtolower($content); |
||||||
882 | $content = \htmlentities($content, \ENT_QUOTES | \ENT_HTML5); // TODO: Vérifier |
||||||
883 | $content = \preg_replace('/&([a-zA-Z])(uml|acute|grave|circ|tilde);/', '$1', $content); |
||||||
884 | $content = \html_entity_decode($content); |
||||||
885 | $content = \str_ireplace('quot', ' ', $content); |
||||||
886 | $content = \preg_replace("/'/i", ' ', $content); |
||||||
887 | $content = \str_ireplace('-', ' ', $content); |
||||||
888 | $content = \preg_replace('/[[:punct:]]/i', '', $content); |
||||||
889 | |||||||
890 | // Selon option mais attention au fichier .htaccess ! |
||||||
891 | // $content = eregi_replace('[[:digit:]]','', $content); |
||||||
892 | $content = \preg_replace('/[^a-z|A-Z|0-9]/', '-', $content); |
||||||
893 | |||||||
894 | $words = \explode(' ', $content); |
||||||
895 | $keywords = ''; |
||||||
896 | foreach ($words as $word) { |
||||||
897 | if (mb_strlen($word) >= $urw) { |
||||||
898 | $keywords .= '-' . \trim($word); |
||||||
899 | } |
||||||
900 | } |
||||||
901 | if (!$keywords) { |
||||||
902 | $keywords = '-'; |
||||||
903 | } |
||||||
904 | // Supprime les tirets en double |
||||||
905 | $keywords = \str_replace('---', '-', $keywords); |
||||||
906 | $keywords = \str_replace('--', '-', $keywords); |
||||||
907 | // Supprime un éventuel tiret à la fin de la chaine |
||||||
908 | if ('-' === mb_substr($keywords, mb_strlen($keywords) - 1, 1)) { |
||||||
909 | $keywords = mb_substr($keywords, 0, -1); |
||||||
910 | } |
||||||
911 | |||||||
912 | return $keywords; |
||||||
913 | } |
||||||
914 | |||||||
915 | /** |
||||||
916 | * Create the meta keywords based on the content |
||||||
917 | * |
||||||
918 | * @param string $content Content from which we have to create metakeywords |
||||||
919 | * |
||||||
920 | * @return string The list of meta keywords |
||||||
921 | */ |
||||||
922 | public static function createMetaKeywords($content) |
||||||
923 | { |
||||||
924 | $keywordscount = self::getModuleOption('metagen_maxwords'); |
||||||
925 | $keywordsorder = self::getModuleOption('metagen_order'); |
||||||
926 | |||||||
927 | $tmp = []; |
||||||
928 | // Search for the "Minimum keyword length" |
||||||
929 | if (Request::hasVar('xoopstube_keywords_limit', 'SESSION')) { |
||||||
930 | $limit = $_SESSION['xoopstube_keywords_limit']; |
||||||
931 | } else { |
||||||
932 | /** @var \XoopsConfigHandler $configHandler */ |
||||||
933 | $configHandler = \xoops_getHandler('config'); |
||||||
934 | $xoopsConfigSearch = $configHandler->getConfigsByCat(\XOOPS_CONF_SEARCH); |
||||||
935 | $limit = $xoopsConfigSearch['keyword_min']; |
||||||
936 | $_SESSION['xoopstube_keywords_limit'] = $limit; |
||||||
937 | } |
||||||
938 | $myts = \MyTextSanitizer::getInstance(); |
||||||
939 | $content = \str_replace('<br>', ' ', $content); |
||||||
940 | $content = $myts->undoHtmlSpecialChars($content); |
||||||
941 | $content = \strip_tags($content); |
||||||
942 | $content = mb_strtolower($content); |
||||||
943 | $search_pattern = [' ', "\t", "\r\n", "\r", "\n", ',', '.', "'", ';', ':', ')', '(', '"', '?', '!', '{', '}', '[', ']', '<', '>', '/', '+', '-', '_', '\\', '*']; |
||||||
944 | $replace_pattern = [' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '']; |
||||||
945 | $content = \str_replace($search_pattern, $replace_pattern, $content); |
||||||
946 | $keywords = \explode(' ', $content); |
||||||
947 | switch ($keywordsorder) { |
||||||
948 | case 0: // Ordre d'apparition dans le texte |
||||||
949 | $keywords = \array_unique($keywords); |
||||||
950 | break; |
||||||
951 | case 1: // Ordre de fréquence des mots |
||||||
952 | $keywords = \array_count_values($keywords); |
||||||
953 | \asort($keywords); |
||||||
954 | $keywords = \array_keys($keywords); |
||||||
955 | break; |
||||||
956 | case 2: // Ordre inverse de la fréquence des mots |
||||||
957 | $keywords = \array_count_values($keywords); |
||||||
958 | \arsort($keywords); |
||||||
959 | $keywords = \array_keys($keywords); |
||||||
960 | break; |
||||||
961 | } |
||||||
962 | // Remove black listed words |
||||||
963 | if ('' !== \xoops_trim(self::getModuleOption('metagen_blacklist'))) { |
||||||
964 | $metagen_blacklist = \str_replace("\r", '', self::getModuleOption('metagen_blacklist')); |
||||||
965 | $metablack = \explode("\n", $metagen_blacklist); |
||||||
966 | \array_walk($metablack, '\trim'); |
||||||
967 | $keywords = \array_diff($keywords, $metablack); |
||||||
968 | } |
||||||
969 | |||||||
970 | foreach ($keywords as $keyword) { |
||||||
971 | if (mb_strlen($keyword) >= $limit && !\is_numeric($keyword)) { |
||||||
972 | $tmp[] = $keyword; |
||||||
973 | } |
||||||
974 | } |
||||||
975 | $tmp = \array_slice($tmp, 0, $keywordscount); |
||||||
976 | if (\count($tmp) > 0) { |
||||||
977 | return \implode(',', $tmp); |
||||||
978 | } |
||||||
979 | if (!isset($configHandler) || !\is_object($configHandler)) { |
||||||
980 | /** @var \XoopsConfigHandler $configHandler */ |
||||||
981 | $configHandler = \xoops_getHandler('config'); |
||||||
982 | } |
||||||
983 | $xoopsConfigMetaFooter = $configHandler->getConfigsByCat(\XOOPS_CONF_METAFOOTER); |
||||||
984 | return $xoopsConfigMetaFooter['meta_keywords'] ?? ''; |
||||||
985 | } |
||||||
986 | |||||||
987 | /** |
||||||
988 | * Fonction chargée de gérer l'upload |
||||||
989 | * |
||||||
990 | * @param int $indice L'indice du fichier à télécharger |
||||||
991 | * @param string $dstpath |
||||||
992 | * @param null $mimeTypes |
||||||
993 | * @param null $uploadMaxSize |
||||||
994 | * @param null $maxWidth |
||||||
995 | * @param null $maxHeight |
||||||
996 | * |
||||||
997 | * @return bool|string True si l'upload s'est bien déroulé sinon le message d'erreur correspondant |
||||||
998 | */ |
||||||
999 | public static function uploadFile( |
||||||
1000 | $indice, |
||||||
1001 | $dstpath = XOOPS_UPLOAD_PATH, |
||||||
1002 | $mimeTypes = null, |
||||||
1003 | $uploadMaxSize = null, |
||||||
1004 | $maxWidth = null, |
||||||
1005 | $maxHeight = null |
||||||
1006 | ) { |
||||||
1007 | require_once XOOPS_ROOT_PATH . '/class/uploader.php'; |
||||||
1008 | global $destname; |
||||||
1009 | if (Request::hasVar('xoops_upload_file', 'POST')) { |
||||||
1010 | require_once XOOPS_ROOT_PATH . '/class/uploader.php'; |
||||||
1011 | $fldname = ''; |
||||||
1012 | $fldname = $_FILES[$_POST['xoops_upload_file'][$indice]]; |
||||||
1013 | $fldname = $fldname['name']; |
||||||
1014 | if (\xoops_trim('' !== $fldname)) { |
||||||
1015 | $destname = self::createUploadName($dstpath, $fldname, true); |
||||||
1016 | if (null === $mimeTypes) { |
||||||
1017 | $permittedtypes = \explode("\n", \str_replace("\r", '', self::getModuleOption('mimetypes'))); |
||||||
1018 | \array_walk($permittedtypes, '\trim'); |
||||||
1019 | } else { |
||||||
1020 | $permittedtypes = $mimeTypes; |
||||||
1021 | } |
||||||
1022 | $uploadSize = $uploadMaxSize ?? self::getModuleOption('maxuploadsize'); |
||||||
1023 | $uploader = new MediaUploader($dstpath, $permittedtypes, $uploadSize, $maxWidth, $maxHeight); |
||||||
1024 | //$uploader->allowUnknownTypes = true; |
||||||
1025 | $uploader->setTargetFileName($destname); |
||||||
1026 | if ($uploader->fetchMedia($_POST['xoops_upload_file'][$indice])) { |
||||||
1027 | if ($uploader->upload()) { |
||||||
1028 | return true; |
||||||
1029 | } |
||||||
1030 | |||||||
1031 | return _ERRORS . ' ' . \htmlentities($uploader->getErrors(), \ENT_QUOTES | \ENT_HTML5); |
||||||
1032 | } |
||||||
1033 | |||||||
1034 | return \htmlentities($uploader->getErrors(), \ENT_QUOTES | \ENT_HTML5); |
||||||
1035 | } |
||||||
1036 | |||||||
1037 | return false; |
||||||
1038 | } |
||||||
1039 | |||||||
1040 | return false; |
||||||
1041 | } |
||||||
1042 | |||||||
1043 | /** |
||||||
1044 | * Resize a Picture to some given dimensions (using the wideImage library) |
||||||
1045 | * |
||||||
1046 | * @param string $src_path Picture's source |
||||||
1047 | * @param string $dst_path Picture's destination |
||||||
1048 | * @param int $param_width Maximum picture's width |
||||||
1049 | * @param int $param_height Maximum picture's height |
||||||
1050 | * @param bool $keep_original Do we have to keep the original picture ? |
||||||
1051 | * @param string $fit Resize mode (see the wideImage library for more information) |
||||||
1052 | * |
||||||
1053 | * @return bool |
||||||
1054 | */ |
||||||
1055 | public static function resizePicture( |
||||||
1056 | $src_path, |
||||||
1057 | $dst_path, |
||||||
1058 | $param_width, |
||||||
1059 | $param_height, |
||||||
1060 | $keep_original = false, |
||||||
1061 | $fit = 'inside' |
||||||
1062 | ) { |
||||||
1063 | $resize = true; |
||||||
1064 | if (XOOPSTUBE_DONT_RESIZE_IF_SMALLER) { |
||||||
1065 | $pictureDimensions = \getimagesize($src_path); |
||||||
0 ignored issues
–
show
|
|||||||
1066 | if (\is_array($pictureDimensions)) { |
||||||
1067 | $width = $pictureDimensions[0]; |
||||||
1068 | $height = $pictureDimensions[1]; |
||||||
1069 | if ($width < $param_width && $height < $param_height) { |
||||||
1070 | $resize = false; |
||||||
1071 | } |
||||||
1072 | } |
||||||
1073 | } |
||||||
1074 | |||||||
1075 | $img = WideImage::load($src_path); |
||||||
1076 | if ($resize) { |
||||||
1077 | $result = $img->resize($param_width, $param_height, $fit); |
||||||
1078 | $result->saveToFile($dst_path); |
||||||
1079 | } else { |
||||||
1080 | @\copy($src_path, $dst_path); |
||||||
1081 | } |
||||||
0 ignored issues
–
show
It seems like you do not handle an error condition for
copy() . This can introduce security issues, and is generally not recommended.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
If you suppress an error, we recommend checking for the error condition explicitly: // For example instead of
@mkdir($dir);
// Better use
if (@mkdir($dir) === false) {
throw new \RuntimeException('The directory '.$dir.' could not be created.');
}
![]() |
|||||||
1082 | |||||||
1083 | if (!$keep_original) { |
||||||
1084 | @\unlink($src_path); |
||||||
1085 | } |
||||||
0 ignored issues
–
show
It seems like you do not handle an error condition for
unlink() . This can introduce security issues, and is generally not recommended.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
If you suppress an error, we recommend checking for the error condition explicitly: // For example instead of
@mkdir($dir);
// Better use
if (@mkdir($dir) === false) {
throw new \RuntimeException('The directory '.$dir.' could not be created.');
}
![]() |
|||||||
1086 | |||||||
1087 | return true; |
||||||
1088 | } |
||||||
1089 | |||||||
1090 | /** |
||||||
1091 | * Add days to a date and return the new date in Mysql Date format |
||||||
1092 | * |
||||||
1093 | * @param int $duration |
||||||
1094 | * @param int $startingDate Starting date (timestamp) |
||||||
1095 | * |
||||||
1096 | * @return bool|string |
||||||
1097 | * @internal param int $ Duration in days |
||||||
1098 | */ |
||||||
1099 | public static function addDaysToDate($duration = 1, $startingDate = 0) |
||||||
1100 | { |
||||||
1101 | if (0 == $startingDate) { |
||||||
1102 | $startingDate = \time(); |
||||||
1103 | } |
||||||
1104 | $endingDate = $startingDate + ($duration * 86400); |
||||||
1105 | |||||||
1106 | return \date('Y-m-d', $endingDate); |
||||||
1107 | } |
||||||
1108 | |||||||
1109 | /** |
||||||
1110 | * Returns a breadcrumb according to the parameters passed and starting (automatically) from the root of the module |
||||||
1111 | * |
||||||
1112 | * @param array $path The full path (except the root) of the breadcrumb in the form of key = url value = title |
||||||
1113 | * @param string $raquo The default separator to use |
||||||
1114 | * |
||||||
1115 | * @return string le breadcrumb |
||||||
1116 | */ |
||||||
1117 | public static function breadcrumb($path, $raquo = ' » ') |
||||||
1118 | { |
||||||
1119 | $breadcrumb = ''; |
||||||
1120 | $workingBreadcrumb = []; |
||||||
1121 | if (\is_array($path)) { |
||||||
1122 | $moduleName = self::getModuleName(); |
||||||
1123 | $workingBreadcrumb[] = "<a href='" . XOOPSTUBE_URL . "' title='" . self::makeHrefTitle($moduleName) . "'>" . $moduleName . '</a>'; |
||||||
1124 | foreach ($path as $url => $title) { |
||||||
0 ignored issues
–
show
|
|||||||
1125 | $workingBreadcrumb[] = "<a href='" . $url . "'>" . $title . '</a>'; |
||||||
1126 | } |
||||||
1127 | $cnt = \count($workingBreadcrumb); |
||||||
1128 | foreach ($workingBreadcrumb as $i => $iValue) { |
||||||
1129 | if ($i == $cnt - 1) { |
||||||
1130 | $workingBreadcrumb[$i] = \strip_tags($iValue); |
||||||
1131 | } |
||||||
1132 | } |
||||||
1133 | $breadcrumb = \implode($raquo, $workingBreadcrumb); |
||||||
1134 | } |
||||||
1135 | |||||||
1136 | return $breadcrumb; |
||||||
1137 | } |
||||||
1138 | |||||||
1139 | /** |
||||||
1140 | * @param $string |
||||||
1141 | * |
||||||
1142 | * @return string |
||||||
1143 | */ |
||||||
1144 | public static function close_tags($string) |
||||||
1145 | { |
||||||
1146 | // match opened tags |
||||||
1147 | if (\preg_match_all('/<([a-z\:\-]+)[^\/]>/', $string, $start_tags)) { |
||||||
1148 | $start_tags = $start_tags[1]; |
||||||
1149 | |||||||
1150 | // match closed tags |
||||||
1151 | if (\preg_match_all('/<\/([a-z]+)>/', $string, $end_tags)) { |
||||||
1152 | $complete_tags = []; |
||||||
1153 | $end_tags = $end_tags[1]; |
||||||
1154 | |||||||
1155 | foreach ($start_tags as $key => $val) { |
||||||
1156 | $posb = \array_search($val, $end_tags, true); |
||||||
1157 | if (\is_int($posb)) { |
||||||
1158 | unset($end_tags[$posb]); |
||||||
1159 | } else { |
||||||
1160 | $complete_tags[] = $val; |
||||||
1161 | } |
||||||
1162 | } |
||||||
1163 | } else { |
||||||
1164 | $complete_tags = $start_tags; |
||||||
1165 | } |
||||||
1166 | |||||||
1167 | $complete_tags = \array_reverse($complete_tags); |
||||||
1168 | foreach ($complete_tags as $iValue) { |
||||||
1169 | $string .= '</' . $iValue . '>'; |
||||||
1170 | } |
||||||
1171 | } |
||||||
1172 | |||||||
1173 | return $string; |
||||||
1174 | } |
||||||
1175 | |||||||
1176 | /** |
||||||
1177 | * @param $string |
||||||
1178 | * @param int $length |
||||||
1179 | * @param string $etc |
||||||
1180 | * @param bool $break_words |
||||||
1181 | * |
||||||
1182 | * @return string |
||||||
1183 | */ |
||||||
1184 | public static function truncate_tagsafe($string, $length = 80, $etc = '...', $break_words = false) |
||||||
1185 | { |
||||||
1186 | if (0 == $length) { |
||||||
1187 | return ''; |
||||||
1188 | } |
||||||
1189 | |||||||
1190 | if (mb_strlen($string) > $length) { |
||||||
1191 | $length -= mb_strlen($etc); |
||||||
1192 | if (!$break_words) { |
||||||
1193 | $string = \preg_replace('/\s+?(\S+)?$/', '', mb_substr($string, 0, $length + 1)); |
||||||
1194 | $string = \preg_replace('/<[^>]*$/', '', $string); |
||||||
1195 | $string = self::close_tags($string); |
||||||
1196 | } |
||||||
1197 | |||||||
1198 | return $string . $etc; |
||||||
1199 | } |
||||||
1200 | |||||||
1201 | return $string; |
||||||
1202 | } |
||||||
1203 | |||||||
1204 | /** |
||||||
1205 | * Create an infotip |
||||||
1206 | * @param $text |
||||||
1207 | * @return string |
||||||
1208 | */ |
||||||
1209 | public static function makeInfotips($text) |
||||||
1210 | { |
||||||
1211 | $ret = ''; |
||||||
1212 | $infotips = self::getModuleOption('infotips'); |
||||||
1213 | if ($infotips > 0) { |
||||||
1214 | $myts = \MyTextSanitizer::getInstance(); |
||||||
1215 | $ret = \htmlspecialchars(\xoops_substr(\strip_tags($text), 0, $infotips), \ENT_QUOTES | \ENT_HTML5); |
||||||
1216 | } |
||||||
1217 | |||||||
1218 | return $ret; |
||||||
1219 | } |
||||||
1220 | |||||||
1221 | /** |
||||||
1222 | * @param $datastream |
||||||
1223 | * @param $url |
||||||
1224 | * |
||||||
1225 | * @return string |
||||||
1226 | */ |
||||||
1227 | public static function postIt($datastream, $url) |
||||||
1228 | { |
||||||
1229 | $url = \preg_replace('@^http://@i', '', $url); |
||||||
1230 | $host = mb_substr($url, 0, mb_strpos($url, '/')); |
||||||
1231 | $uri = mb_strstr($url, '/'); |
||||||
1232 | $reqbody = ''; |
||||||
1233 | foreach ($datastream as $key => $val) { |
||||||
1234 | if (!empty($reqbody)) { |
||||||
1235 | $reqbody .= '&'; |
||||||
1236 | } |
||||||
1237 | $reqbody .= $key . '=' . \urlencode($val); |
||||||
1238 | } |
||||||
1239 | $contentlength = mb_strlen($reqbody); |
||||||
1240 | $reqheader = "POST $uri HTTP/1.1\r\n" . "Host: $host\n" . "Content-Type: application/x-www-form-urlencoded\r\n" . "Content-Length: $contentlength\r\n\r\n" . "$reqbody\r\n"; |
||||||
1241 | |||||||
1242 | return $reqheader; |
||||||
1243 | } |
||||||
1244 | |||||||
1245 | /** |
||||||
1246 | * Returns the mime type of a file using first finfo then mime_content |
||||||
1247 | * |
||||||
1248 | * @param $filename |
||||||
1249 | * @return string |
||||||
1250 | */ |
||||||
1251 | public static function getMimeType($filename) |
||||||
1252 | { |
||||||
1253 | if (\function_exists('finfo_open')) { |
||||||
1254 | $finfo = \finfo_open(); |
||||||
1255 | $mimetype = \finfo_file($finfo, $filename, \FILEINFO_MIME_TYPE); |
||||||
1256 | \finfo_close($finfo); |
||||||
1257 | |||||||
1258 | return $mimetype; |
||||||
1259 | } |
||||||
1260 | if (\function_exists('mime_content_type')) { |
||||||
1261 | return \mime_content_type($filename); |
||||||
1262 | } |
||||||
1263 | |||||||
1264 | return ''; |
||||||
1265 | } |
||||||
1266 | |||||||
1267 | /** |
||||||
1268 | * Retourne un criteria compo qui permet de filtrer les produits sur le mois courant |
||||||
1269 | * |
||||||
1270 | * @return \CriteriaCompo |
||||||
1271 | */ |
||||||
1272 | public static function getThisMonthCriteria() |
||||||
1273 | { |
||||||
1274 | $start = \mktime(0, 1, 0, \date('n'), \date('j'), \date('Y')); |
||||||
1275 | $end = \mktime(0, 0, 0, \date('n'), \date('t'), \date('Y')); |
||||||
1276 | $criteriaThisMonth = new \CriteriaCompo(); |
||||||
1277 | $criteriaThisMonth->add(new \Criteria('product_submitted', $start, '>=')); |
||||||
1278 | $criteriaThisMonth->add(new \Criteria('product_submitted', $end, '<=')); |
||||||
1279 | |||||||
1280 | return $criteriaThisMonth; |
||||||
1281 | } |
||||||
1282 | |||||||
1283 | /** |
||||||
1284 | * Retourne une liste d'objets XoopsUsers à partir d'une liste d'identifiants |
||||||
1285 | * |
||||||
1286 | * @param array $xoopsUsersIDs La liste des ID |
||||||
1287 | * |
||||||
1288 | * @return array Les objets XoopsUsers |
||||||
1289 | */ |
||||||
1290 | public static function getUsersFromIds($xoopsUsersIDs) |
||||||
1291 | { |
||||||
1292 | $users = []; |
||||||
1293 | if ($xoopsUsersIDs && \is_array($xoopsUsersIDs)) { |
||||||
1294 | $xoopsUsersIDs = \array_unique($xoopsUsersIDs); |
||||||
1295 | \sort($xoopsUsersIDs); |
||||||
1296 | if (\count($xoopsUsersIDs) > 0) { |
||||||
1297 | /** @var \XoopsUserHandler $memberHandler */ |
||||||
1298 | $memberHandler = \xoops_getHandler('user'); |
||||||
1299 | $criteria = new \Criteria('uid', '(' . \implode(',', $xoopsUsersIDs) . ')', 'IN'); |
||||||
1300 | $criteria->setSort('uid'); |
||||||
1301 | $users = $memberHandler->getObjects($criteria, true); |
||||||
1302 | } |
||||||
1303 | } |
||||||
1304 | |||||||
1305 | return $users; |
||||||
1306 | } |
||||||
1307 | |||||||
1308 | /** |
||||||
1309 | * Retourne l'ID de l'utilisateur courant (s'il est connecté) |
||||||
1310 | * |
||||||
1311 | * @return int L'uid ou 0 |
||||||
1312 | */ |
||||||
1313 | public static function getCurrentUserID() |
||||||
1314 | { |
||||||
1315 | global $xoopsUser; |
||||||
1316 | $uid = \is_object($xoopsUser) ? $xoopsUser->getVar('uid') : 0; |
||||||
1317 | |||||||
1318 | return $uid; |
||||||
1319 | } |
||||||
1320 | |||||||
1321 | /** |
||||||
1322 | * Retourne la liste des groupes de l'utilisateur courant (avec cache) |
||||||
1323 | * |
||||||
1324 | * @param int $uid |
||||||
1325 | * |
||||||
1326 | * @return array Les ID des groupes auquel l'utilisateur courant appartient |
||||||
1327 | */ |
||||||
1328 | public static function getMemberGroups($uid = 0) |
||||||
1329 | { |
||||||
1330 | static $buffer = []; |
||||||
1331 | if (0 == $uid) { |
||||||
1332 | $uid = self::getCurrentUserID(); |
||||||
1333 | } |
||||||
1334 | |||||||
1335 | if (\is_array($buffer) && \count($buffer) > 0 && isset($buffer[$uid])) { |
||||||
1336 | return $buffer[$uid]; |
||||||
1337 | } |
||||||
1338 | if ($uid > 0) { |
||||||
1339 | $memberHandler = \xoops_getHandler('member'); |
||||||
1340 | $buffer[$uid] = $memberHandler->getGroupsByUser($uid, false); // Renvoie un tableau d'ID (de groupes) |
||||||
1341 | } else { |
||||||
0 ignored issues
–
show
The method
getGroupsByUser() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsMembershipHandler or XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
1342 | $buffer[$uid] = [XOOPS_GROUP_ANONYMOUS]; |
||||||
1343 | } |
||||||
1344 | |||||||
1345 | return $buffer[$uid]; |
||||||
1346 | } |
||||||
1347 | |||||||
1348 | /** |
||||||
1349 | * Indique si l'utilisateur courant fait partie d'une groupe donné (avec gestion de cache) |
||||||
1350 | * |
||||||
1351 | * @param int $group Groupe recherché |
||||||
1352 | * @param int $uid |
||||||
1353 | * |
||||||
1354 | * @return bool vrai si l'utilisateur fait partie du groupe, faux sinon |
||||||
1355 | */ |
||||||
1356 | public static function isMemberOfGroup($group = 0, $uid = 0) |
||||||
1357 | { |
||||||
1358 | static $buffer = []; |
||||||
1359 | $retval = false; |
||||||
1360 | if (0 == $uid) { |
||||||
1361 | $uid = self::getCurrentUserID(); |
||||||
1362 | } |
||||||
1363 | if (\is_array($buffer) && \array_key_exists($group, $buffer)) { |
||||||
1364 | $retval = $buffer[$group]; |
||||||
1365 | } else { |
||||||
1366 | $memberHandler = \xoops_getHandler('member'); |
||||||
1367 | $groups = $memberHandler->getGroupsByUser($uid, false); // Renvoie un tableau d'ID (de groupes) |
||||||
1368 | $retval = \in_array($group, $groups); |
||||||
1369 | $buffer[$group] = $retval; |
||||||
1370 | } |
||||||
1371 | |||||||
1372 | return $retval; |
||||||
1373 | } |
||||||
1374 | |||||||
1375 | /** |
||||||
1376 | * Function responsible for verifying that a directory exists, we can write in and create an index.html file |
||||||
1377 | * |
||||||
1378 | * @param $folder |
||||||
1379 | */ |
||||||
1380 | public static function prepareFolder($folder) |
||||||
1381 | { |
||||||
1382 | if (!\is_dir($folder)) { |
||||||
1383 | if (!\mkdir($folder) && !\is_dir($folder)) { |
||||||
1384 | throw new \RuntimeException(\sprintf('Directory "%s" was not created', $folder)); |
||||||
1385 | } |
||||||
1386 | file_put_contents($folder . '/index.html', '<script>history.go(-1);</script>'); |
||||||
1387 | } |
||||||
1388 | // chmod($folder, 0777); |
||||||
1389 | } |
||||||
1390 | |||||||
1391 | /** |
||||||
1392 | * Duplicate a file in local |
||||||
1393 | * |
||||||
1394 | * @param string $path The file's path |
||||||
1395 | * @param string $filename The filename |
||||||
1396 | * |
||||||
1397 | * @return false|string If the copy succeed, the new filename else false |
||||||
1398 | * @since 2.1 |
||||||
1399 | */ |
||||||
1400 | public static function duplicateFile($path, $filename) |
||||||
1401 | { |
||||||
1402 | $newName = self::createUploadName($path, $filename); |
||||||
1403 | if (\copy($path . \DIRECTORY_SEPARATOR . $filename, $path . \DIRECTORY_SEPARATOR . $newName)) { |
||||||
1404 | return $newName; |
||||||
1405 | } |
||||||
1406 | |||||||
1407 | return false; |
||||||
1408 | } |
||||||
1409 | |||||||
1410 | //================================================================================================================================= |
||||||
1411 | |||||||
1412 | /** |
||||||
1413 | * @param $name |
||||||
1414 | * @param bool $optional |
||||||
1415 | * @return bool |
||||||
1416 | */ |
||||||
1417 | public static function getHandler($name, $optional = false) |
||||||
1418 | { |
||||||
1419 | global $handlers, $xoopsModule; |
||||||
1420 | |||||||
1421 | $name = mb_strtolower(\trim($name)); |
||||||
1422 | if (!isset($handlers[$name])) { |
||||||
1423 | if (\is_file($hnd_file = XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/class/class_' . $name . '.php')) { |
||||||
1424 | require_once $hnd_file; |
||||||
1425 | } |
||||||
1426 | $class = 'xtube' . \ucfirst($name) . 'Handler'; |
||||||
1427 | if (\class_exists($class)) { |
||||||
1428 | $handlers[$name] = new $class($GLOBALS['xoopsDB']); |
||||||
1429 | } |
||||||
1430 | } |
||||||
1431 | if (!isset($handlers[$name]) && !$optional) { |
||||||
1432 | \trigger_error('<div>Class <span style="font-weight: bold;">' . $class . '</span> does not exist.</div><div>Handler Name: ' . $name, \E_USER_ERROR) . '</div>'; |
||||||
1433 | } |
||||||
1434 | |||||||
1435 | return $handlers[$name] ?? false; |
||||||
1436 | } |
||||||
1437 | |||||||
1438 | /** |
||||||
1439 | * @param int $cid |
||||||
1440 | * @param string $permType |
||||||
1441 | * @param bool $redirect |
||||||
1442 | * |
||||||
1443 | * @return bool |
||||||
1444 | */ |
||||||
1445 | public static function checkGroups($cid = 0, $permType = 'XTubeCatPerm', $redirect = false) |
||||||
1446 | { |
||||||
1447 | global $xoopsModule; |
||||||
1448 | |||||||
1449 | $groups = \is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getGroups() : XOOPS_GROUP_ANONYMOUS; |
||||||
1450 | /** @var \XoopsGroupPermHandler $grouppermHandler */ |
||||||
1451 | $grouppermHandler = \xoops_getHandler('groupperm'); |
||||||
1452 | if (!$grouppermHandler->checkRight($permType, $cid, $groups, $xoopsModule->getVar('mid'))) { |
||||||
1453 | if (!$redirect) { |
||||||
1454 | return false; |
||||||
1455 | } |
||||||
1456 | \redirect_header('index.php', 3, _NOPERM); |
||||||
1457 | } |
||||||
1458 | |||||||
1459 | return true; |
||||||
1460 | } |
||||||
1461 | |||||||
1462 | /** |
||||||
1463 | * @param int $lid |
||||||
1464 | * |
||||||
1465 | * @return bool |
||||||
1466 | */ |
||||||
1467 | public static function getVoteDetails($lid = 0) |
||||||
1468 | { |
||||||
1469 | $sql = 'SELECT |
||||||
1470 | COUNT(rating) AS rate, |
||||||
1471 | MIN(rating) AS min_rate, |
||||||
1472 | MAX(rating) AS max_rate, |
||||||
1473 | AVG(rating) AS avg_rate, |
||||||
1474 | COUNT(ratinguser) AS rating_user, |
||||||
1475 | MAX(ratinguser) AS max_user, |
||||||
1476 | MAX(title) AS max_title, |
||||||
1477 | MIN(title) AS min_title, |
||||||
1478 | sum(ratinguser = 0) AS null_ratinguser |
||||||
1479 | FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_votedata'); |
||||||
1480 | if ($lid > 0) { |
||||||
1481 | $sql .= ' WHERE lid=' . $lid; |
||||||
1482 | } |
||||||
1483 | if (!$result = $GLOBALS['xoopsDB']->query($sql)) { |
||||||
1484 | return false; |
||||||
1485 | } |
||||||
1486 | $ret = $GLOBALS['xoopsDB']->fetchArray($result); |
||||||
1487 | |||||||
1488 | return $ret; |
||||||
1489 | } |
||||||
1490 | |||||||
1491 | /** |
||||||
1492 | * @param int $sel_id |
||||||
1493 | * |
||||||
1494 | * @return array|bool |
||||||
1495 | */ |
||||||
1496 | public static function calculateVoteData($sel_id = 0) |
||||||
1497 | { |
||||||
1498 | $ret = []; |
||||||
1499 | $ret['useravgrating'] = 0; |
||||||
1500 | |||||||
1501 | $sql = 'SELECT rating FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_votedata'); |
||||||
1502 | if (0 !== $sel_id) { |
||||||
1503 | $sql .= ' WHERE lid=' . $sel_id; |
||||||
1504 | } |
||||||
1505 | if (!$result = $GLOBALS['xoopsDB']->query($sql)) { |
||||||
1506 | return false; |
||||||
1507 | } |
||||||
1508 | $ret['uservotes'] = $GLOBALS['xoopsDB']->getRowsNum($result); |
||||||
1509 | while (list($rating) = $GLOBALS['xoopsDB']->fetchRow($result)) { |
||||||
1510 | $ret['useravgrating'] += (int)$rating; |
||||||
1511 | } |
||||||
1512 | if ($ret['useravgrating'] > 0) { |
||||||
1513 | $ret['useravgrating'] = \number_format($ret['useravgrating'] / $ret['uservotes'], 2); |
||||||
1514 | } |
||||||
1515 | |||||||
1516 | return $ret; |
||||||
1517 | } |
||||||
1518 | |||||||
1519 | /** |
||||||
1520 | * @param $array |
||||||
1521 | * @param null $name |
||||||
1522 | * @param null $def |
||||||
1523 | * @param bool $strict |
||||||
1524 | * @param int $lengthcheck |
||||||
1525 | * |
||||||
1526 | * @return array|int|null|string |
||||||
1527 | */ |
||||||
1528 | public static function cleanRequestVars( |
||||||
1529 | &$array, |
||||||
1530 | $name = null, |
||||||
1531 | $def = null, |
||||||
1532 | $strict = false, |
||||||
1533 | $lengthcheck = 15 |
||||||
1534 | ) { |
||||||
1535 | // Sanitise $_request for further use. This method gives more control and security. |
||||||
1536 | // Method is more for functionality rather than beauty at the moment, will correct later. |
||||||
1537 | unset($array['usercookie'], $array['PHPSESSID']); |
||||||
1538 | |||||||
1539 | if (\is_array($array) && null === $name) { |
||||||
1540 | $globals = []; |
||||||
1541 | foreach (\array_keys($array) as $k) { |
||||||
1542 | $value = \strip_tags(\trim($array[$k])); |
||||||
1543 | if (mb_strlen($value >= $lengthcheck)) { |
||||||
1544 | return null; |
||||||
1545 | } |
||||||
1546 | if (ctype_digit($value)) { |
||||||
1547 | $value = (int)$value; |
||||||
1548 | } else { |
||||||
1549 | if ($strict) { |
||||||
1550 | $value = \preg_replace('/\W/', '', \trim($value)); |
||||||
1551 | } |
||||||
1552 | $value = mb_strtolower((string)$value); |
||||||
1553 | } |
||||||
1554 | $globals[$k] = $value; |
||||||
1555 | } |
||||||
1556 | |||||||
1557 | return $globals; |
||||||
1558 | } |
||||||
1559 | if (!isset($array[$name]) || !\array_key_exists($name, $array)) { |
||||||
1560 | return $def; |
||||||
1561 | } |
||||||
1562 | $value = \strip_tags(\trim($array[$name])); |
||||||
1563 | |||||||
1564 | if (ctype_digit($value)) { |
||||||
1565 | $value = (int)$value; |
||||||
1566 | } else { |
||||||
1567 | if ($strict) { |
||||||
1568 | $value = \preg_replace('/\W/', '', \trim($value)); |
||||||
1569 | } |
||||||
1570 | $value = mb_strtolower((string)$value); |
||||||
1571 | } |
||||||
1572 | |||||||
1573 | return $value; |
||||||
1574 | } |
||||||
1575 | |||||||
1576 | /** |
||||||
1577 | * @param int $cid |
||||||
1578 | * |
||||||
1579 | * @return string |
||||||
1580 | */ |
||||||
1581 | public static function renderToolbar($cid = 0) |
||||||
1582 | { |
||||||
1583 | $toolbar = '[ '; |
||||||
1584 | if (self::checkGroups($cid, 'XTubeSubPerm')) { |
||||||
1585 | $toolbar .= '<a href="submit.php?cid=' . $cid . '">' . \_MD_XOOPSTUBE_SUBMITVIDEO . '</a> | '; |
||||||
1586 | } |
||||||
1587 | $toolbar .= '<a href="newlist.php?newvideoshowdays=7">' . \_MD_XOOPSTUBE_LATESTLIST . '</a> | <a href="topten.php?list=hit">' . \_MD_XOOPSTUBE_POPULARITY . '</a> | <a href="topten.php?list=rate">' . \_MD_XOOPSTUBE_TOPRATED . '</a> ]'; |
||||||
1588 | |||||||
1589 | return $toolbar; |
||||||
1590 | } |
||||||
1591 | |||||||
1592 | public static function getServerStatistics() |
||||||
1593 | { |
||||||
1594 | global $xoopsModule; |
||||||
1595 | echo '<fieldset style="border: #E8E8E8 1px solid;"> |
||||||
1596 | <legend style="display: inline; font-weight: bold; color: #0A3760;">' . \_AM_XOOPSTUBE_VIDEO_IMAGEINFO . '</legend> |
||||||
1597 | <div style="padding: 8px;"> |
||||||
1598 | <img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/icon/server.png" alt="" style="float: left; padding-right: 10px;"> |
||||||
1599 | <div>' . \_AM_XOOPSTUBE_VIDEO_SPHPINI . '</div>'; |
||||||
1600 | |||||||
1601 | // $safemode = ini_get('safe_mode') ? _AM_XOOPSTUBE_VIDEO_ON . _AM_XOOPSTUBE_VIDEO_SAFEMODEPROBLEMS : _AM_XOOPSTUBE_VIDEO_OFF; |
||||||
1602 | // $registerglobals = (ini_get('register_globals') === '') ? _AM_XOOPSTUBE_VIDEO_OFF : _AM_XOOPSTUBE_VIDEO_ON; |
||||||
1603 | $videos = \ini_get('file_uploads') ? \_AM_XOOPSTUBE_VIDEO_ON : \_AM_XOOPSTUBE_VIDEO_OFF; |
||||||
1604 | |||||||
1605 | $gdlib = \function_exists('gd_info') ? \_AM_XOOPSTUBE_VIDEO_GDON : \_AM_XOOPSTUBE_VIDEO_GDOFF; |
||||||
1606 | echo '<li>' . \_AM_XOOPSTUBE_VIDEO_GDLIBSTATUS . $gdlib; |
||||||
1607 | if (\function_exists('gd_info')) { |
||||||
1608 | if (true === $gdlib = gd_info()) { |
||||||
1609 | echo '<li>' . \_AM_XOOPSTUBE_VIDEO_GDLIBVERSION . '<b>' . $gdlib['GD Version'] . '</b>'; |
||||||
1610 | } |
||||||
1611 | } |
||||||
1612 | echo '<br><br>'; |
||||||
1613 | // echo '<li>' . _AM_XOOPSTUBE_VIDEO_SAFEMODESTATUS . $safemode; |
||||||
1614 | // echo '<li>' . _AM_XOOPSTUBE_VIDEO_REGISTERGLOBALS . $registerglobals; |
||||||
1615 | echo '<li>' . \_AM_XOOPSTUBE_VIDEO_SERVERUPLOADSTATUS . $videos; |
||||||
1616 | echo '</div>'; |
||||||
1617 | echo '</fieldset>'; |
||||||
1618 | } |
||||||
1619 | |||||||
1620 | // displayIcons() |
||||||
1621 | // |
||||||
1622 | // @param $time |
||||||
1623 | // @param integer $status |
||||||
1624 | // @param integer $counter |
||||||
1625 | // @return |
||||||
1626 | |||||||
1627 | /** |
||||||
1628 | * @param $time |
||||||
1629 | * @param int $status |
||||||
1630 | * @param int $counter |
||||||
1631 | * |
||||||
1632 | * @return string |
||||||
1633 | */ |
||||||
1634 | public static function displayIcons($time, $status = 0, $counter = 0) |
||||||
1635 | { |
||||||
1636 | global $xoopsModule; |
||||||
1637 | |||||||
1638 | $new = ''; |
||||||
1639 | $pop = ''; |
||||||
1640 | |||||||
1641 | $newdate = (\time() - (86400 * (int)$GLOBALS['xoopsModuleConfig']['daysnew'])); |
||||||
1642 | $popdate = (\time() - (86400 * (int)$GLOBALS['xoopsModuleConfig']['daysupdated'])); |
||||||
1643 | |||||||
1644 | if (3 != $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1645 | if ($newdate < $time) { |
||||||
1646 | if ((int)$status > 1) { |
||||||
1647 | if (1 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1648 | $new = ' <img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/icon/updated.gif" alt="" style="vertical-align: middle;">'; |
||||||
1649 | } |
||||||
1650 | if (2 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1651 | $new = '<em>' . \_MD_XOOPSTUBE_UPDATED . '</em>'; |
||||||
1652 | } |
||||||
1653 | } else { |
||||||
1654 | if (1 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1655 | $new = ' <img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/icon/new.gif" alt="" style="vertical-align: middle;">'; |
||||||
1656 | } |
||||||
1657 | if (2 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1658 | $new = '<em>' . \_MD_XOOPSTUBE_NEW . '</em>'; |
||||||
1659 | } |
||||||
1660 | } |
||||||
1661 | } |
||||||
1662 | if ($popdate > $time) { |
||||||
1663 | if ($counter >= $GLOBALS['xoopsModuleConfig']['popular']) { |
||||||
1664 | if (1 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1665 | $pop = ' <img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/icon/popular.png" alt="" style="vertical-align: middle;">'; |
||||||
1666 | } |
||||||
1667 | if (2 == $GLOBALS['xoopsModuleConfig']['displayicons']) { |
||||||
1668 | $pop = '<em>' . \_MD_XOOPSTUBE_POPULAR . '!</em>'; |
||||||
1669 | } |
||||||
1670 | } |
||||||
1671 | } |
||||||
1672 | } |
||||||
1673 | $icons = $new . ' ' . $pop; |
||||||
1674 | |||||||
1675 | return $icons; |
||||||
1676 | } |
||||||
1677 | |||||||
1678 | // Reusable Link Sorting Functions |
||||||
1679 | // convertOrderByIn() |
||||||
1680 | // @param $orderby |
||||||
1681 | // @return |
||||||
1682 | |||||||
1683 | /** |
||||||
1684 | * @param $orderby |
||||||
1685 | * |
||||||
1686 | * @return string |
||||||
1687 | */ |
||||||
1688 | public static function convertOrderByIn($orderby) |
||||||
1689 | { |
||||||
1690 | switch (\trim($orderby)) { |
||||||
1691 | case 'titleA': |
||||||
1692 | $orderby = 'title ASC'; |
||||||
1693 | break; |
||||||
1694 | case 'dateA': |
||||||
1695 | $orderby = 'published ASC'; |
||||||
1696 | break; |
||||||
1697 | case 'hitsA': |
||||||
1698 | $orderby = 'hits ASC'; |
||||||
1699 | break; |
||||||
1700 | case 'ratingA': |
||||||
1701 | $orderby = 'rating ASC'; |
||||||
1702 | break; |
||||||
1703 | case 'countryA': |
||||||
1704 | $orderby = 'country ASC'; |
||||||
1705 | break; |
||||||
1706 | case 'titleD': |
||||||
1707 | $orderby = 'title DESC'; |
||||||
1708 | break; |
||||||
1709 | case 'hitsD': |
||||||
1710 | $orderby = 'hits DESC'; |
||||||
1711 | break; |
||||||
1712 | case 'ratingD': |
||||||
1713 | $orderby = 'rating DESC'; |
||||||
1714 | break; |
||||||
1715 | case'dateD': |
||||||
1716 | $orderby = 'published DESC'; |
||||||
1717 | break; |
||||||
1718 | case 'countryD': |
||||||
1719 | $orderby = 'country DESC'; |
||||||
1720 | break; |
||||||
1721 | } |
||||||
1722 | |||||||
1723 | return $orderby; |
||||||
1724 | } |
||||||
1725 | |||||||
1726 | /** |
||||||
1727 | * @param $orderby |
||||||
1728 | * |
||||||
1729 | * @return string |
||||||
1730 | */ |
||||||
1731 | public static function convertOrderByTrans($orderby) |
||||||
1732 | { |
||||||
1733 | switch ($orderby) { |
||||||
1734 | case 'hits ASC': |
||||||
1735 | $orderByTrans = \_MD_XOOPSTUBE_POPULARITYLTOM; |
||||||
1736 | break; |
||||||
1737 | case 'hits DESC': |
||||||
1738 | $orderByTrans = \_MD_XOOPSTUBE_POPULARITYMTOL; |
||||||
1739 | break; |
||||||
1740 | case 'title ASC': |
||||||
1741 | $orderByTrans = \_MD_XOOPSTUBE_TITLEATOZ; |
||||||
1742 | break; |
||||||
1743 | case 'title DESC': |
||||||
1744 | $orderByTrans = \_MD_XOOPSTUBE_TITLEZTOA; |
||||||
1745 | break; |
||||||
1746 | case 'published ASC': |
||||||
1747 | $orderByTrans = \_MD_XOOPSTUBE_DATEOLD; |
||||||
1748 | break; |
||||||
1749 | case 'published DESC': |
||||||
1750 | $orderByTrans = \_MD_XOOPSTUBE_DATENEW; |
||||||
1751 | break; |
||||||
1752 | case 'rating ASC': |
||||||
1753 | $orderByTrans = \_MD_XOOPSTUBE_RATINGLTOH; |
||||||
1754 | break; |
||||||
1755 | case 'rating DESC': |
||||||
1756 | $orderByTrans = \_MD_XOOPSTUBE_RATINGHTOL; |
||||||
1757 | break; |
||||||
1758 | case'country ASC': |
||||||
1759 | $orderByTrans = \_MD_XOOPSTUBE_COUNTRYLTOH; |
||||||
1760 | break; |
||||||
1761 | case 'country DESC': |
||||||
1762 | $orderByTrans = \_MD_XOOPSTUBE_COUNTRYHTOL; |
||||||
1763 | break; |
||||||
1764 | } |
||||||
1765 | |||||||
1766 | return $orderByTrans; |
||||||
1767 | } |
||||||
1768 | |||||||
1769 | /** |
||||||
1770 | * @param $orderby |
||||||
1771 | * |
||||||
1772 | * @return string |
||||||
1773 | */ |
||||||
1774 | public static function convertOrderByOut($orderby) |
||||||
1775 | { |
||||||
1776 | switch ($orderby) { |
||||||
1777 | case 'title ASC': |
||||||
1778 | $orderby = 'titleA'; |
||||||
1779 | break; |
||||||
1780 | case 'published ASC': |
||||||
1781 | $orderby = 'dateA'; |
||||||
1782 | break; |
||||||
1783 | case 'hits ASC': |
||||||
1784 | $orderby = 'hitsA'; |
||||||
1785 | break; |
||||||
1786 | case 'rating ASC': |
||||||
1787 | $orderby = 'ratingA'; |
||||||
1788 | break; |
||||||
1789 | case 'country ASC': |
||||||
1790 | $orderby = 'countryA'; |
||||||
1791 | break; |
||||||
1792 | case 'title DESC': |
||||||
1793 | $orderby = 'titleD'; |
||||||
1794 | break; |
||||||
1795 | case 'published DESC': |
||||||
1796 | $orderby = 'dateD'; |
||||||
1797 | break; |
||||||
1798 | case 'hits DESC': |
||||||
1799 | $orderby = 'hitsD'; |
||||||
1800 | break; |
||||||
1801 | case 'rating DESC': |
||||||
1802 | $orderby = 'ratingD'; |
||||||
1803 | break; |
||||||
1804 | case 'country DESC': |
||||||
1805 | $orderby = 'countryD'; |
||||||
1806 | break; |
||||||
1807 | } |
||||||
1808 | |||||||
1809 | return $orderby; |
||||||
1810 | } |
||||||
1811 | |||||||
1812 | // updaterating() |
||||||
1813 | // @param $sel_id |
||||||
1814 | // @return updates rating data in itemtable for a given item |
||||||
1815 | |||||||
1816 | /** |
||||||
1817 | * @param $sel_id |
||||||
1818 | */ |
||||||
1819 | public static function updateRating($sel_id) |
||||||
1820 | { |
||||||
1821 | $query = 'SELECT rating FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_votedata') . ' WHERE lid=' . $sel_id; |
||||||
1822 | $voteresult = $GLOBALS['xoopsDB']->query($query); |
||||||
1823 | $votesDB = $GLOBALS['xoopsDB']->getRowsNum($voteresult); |
||||||
1824 | $totalrating = 0; |
||||||
1825 | while (list($rating) = $GLOBALS['xoopsDB']->fetchRow($voteresult)) { |
||||||
1826 | $totalrating += $rating; |
||||||
1827 | } |
||||||
1828 | $finalrating = $totalrating / $votesDB; |
||||||
1829 | $finalrating = \number_format($finalrating, 4); |
||||||
1830 | $sql = \sprintf('UPDATE `%s` SET rating = %u, votes = %u WHERE lid = %u', $GLOBALS['xoopsDB']->prefix('xoopstube_videos'), $finalrating, $votesDB, $sel_id); |
||||||
1831 | $GLOBALS['xoopsDB']->query($sql); |
||||||
1832 | } |
||||||
1833 | |||||||
1834 | // totalcategory() |
||||||
1835 | // @param integer $pid |
||||||
1836 | // @return |
||||||
1837 | |||||||
1838 | /** |
||||||
1839 | * @param int $pid |
||||||
1840 | * |
||||||
1841 | * @return int |
||||||
1842 | */ |
||||||
1843 | public static function getTotalCategoryCount($pid = 0) |
||||||
1844 | { |
||||||
1845 | $sql = 'SELECT cid FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_cat'); |
||||||
1846 | if ($pid > 0) { |
||||||
1847 | $sql .= ' WHERE pid = 0'; |
||||||
1848 | } |
||||||
1849 | $result = $GLOBALS['xoopsDB']->query($sql); |
||||||
1850 | $catlisting = 0; |
||||||
1851 | while (list($cid) = $GLOBALS['xoopsDB']->fetchRow($result)) { |
||||||
1852 | if (self::checkGroups($cid)) { |
||||||
1853 | ++$catlisting; |
||||||
1854 | } |
||||||
1855 | } |
||||||
1856 | |||||||
1857 | return $catlisting; |
||||||
1858 | } |
||||||
1859 | |||||||
1860 | // getTotalItems() |
||||||
1861 | // @param integer $sel_id |
||||||
1862 | // @param integer $get_child |
||||||
1863 | // @param integer $return_sql |
||||||
1864 | // @return |
||||||
1865 | |||||||
1866 | /** |
||||||
1867 | * @param int $sel_id |
||||||
1868 | * @param int $get_child |
||||||
1869 | * @param int $return_sql |
||||||
1870 | * |
||||||
1871 | * @return string |
||||||
1872 | */ |
||||||
1873 | public static function getTotalItems($sel_id = 0, $get_child = 0, $return_sql = 0) |
||||||
1874 | { |
||||||
1875 | global $mytree, $_check_array; |
||||||
1876 | |||||||
1877 | if ($sel_id > 0) { |
||||||
1878 | $sql = 'SELECT a.lid, a.cid, a.published FROM ' |
||||||
1879 | . $GLOBALS['xoopsDB']->prefix('xoopstube_videos') |
||||||
1880 | . ' a LEFT JOIN ' |
||||||
1881 | . $GLOBALS['xoopsDB']->prefix('xoopstube_altcat') |
||||||
1882 | . ' b' |
||||||
1883 | . ' ON b.lid=a.lid' |
||||||
1884 | . ' WHERE a.published > 0 AND a.published <= ' |
||||||
1885 | . \time() |
||||||
1886 | . ' AND (a.expired = 0 OR a.expired > ' |
||||||
1887 | . \time() |
||||||
1888 | . ') AND offline = 0 ' |
||||||
1889 | . ' AND (b.cid=a.cid OR (a.cid=' |
||||||
1890 | . $sel_id |
||||||
1891 | . ' OR b.cid=' |
||||||
1892 | . $sel_id |
||||||
1893 | . '))' |
||||||
1894 | . ' GROUP BY a.lid, a.cid, a.published'; |
||||||
1895 | } else { |
||||||
1896 | $sql = 'SELECT lid, cid, published FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_videos') . ' WHERE offline = 0 AND published > 0 AND published <= ' . \time() . ' AND (expired = 0 OR expired > ' . \time() . ')'; |
||||||
1897 | } |
||||||
1898 | if (1 == $return_sql) { |
||||||
1899 | return $sql; |
||||||
1900 | } |
||||||
1901 | |||||||
1902 | $count = 0; |
||||||
1903 | $published_date = 0; |
||||||
1904 | |||||||
1905 | $arr = []; |
||||||
1906 | $result = $GLOBALS['xoopsDB']->query($sql); |
||||||
1907 | while (list($lid, $cid, $published) = $GLOBALS['xoopsDB']->fetchRow($result)) { |
||||||
1908 | if (self::checkGroups()) { |
||||||
1909 | ++$count; |
||||||
1910 | $published_date = ($published > $published_date) ? $published : $published_date; |
||||||
1911 | } |
||||||
1912 | } |
||||||
1913 | |||||||
1914 | $child_count = 0; |
||||||
1915 | if (1 == $get_child) { |
||||||
1916 | $arr = $mytree->getAllChildId($sel_id); |
||||||
1917 | $size = \count($arr); |
||||||
1918 | foreach ($arr as $iValue) { |
||||||
1919 | $query2 = 'SELECT a.lid, a.published, a.cid FROM ' |
||||||
1920 | . $GLOBALS['xoopsDB']->prefix('xoopstube_videos') |
||||||
1921 | . ' a LEFT JOIN ' |
||||||
1922 | . $GLOBALS['xoopsDB']->prefix('xoopstube_altcat') |
||||||
1923 | . ' b' |
||||||
1924 | . ' ON b.lid = a.lid' |
||||||
1925 | . ' WHERE a.published > 0 AND a.published <= ' |
||||||
1926 | . \time() |
||||||
1927 | . ' AND (a.expired = 0 OR a.expired > ' |
||||||
1928 | . \time() |
||||||
1929 | . ') AND offline = 0' |
||||||
1930 | . ' AND (b.cid=a.cid OR (a.cid=' |
||||||
1931 | . $iValue |
||||||
1932 | . ' OR b.cid=' |
||||||
1933 | . $iValue |
||||||
1934 | . ')) GROUP BY a.lid, a.published, a.cid'; |
||||||
1935 | |||||||
1936 | $result2 = $GLOBALS['xoopsDB']->query($query2); |
||||||
1937 | while (list($lid, $published) = $GLOBALS['xoopsDB']->fetchRow($result2)) { |
||||||
1938 | if (0 == $published) { |
||||||
1939 | continue; |
||||||
1940 | } |
||||||
1941 | $published_date = ($published > $published_date) ? $published : $published_date; |
||||||
1942 | ++$child_count; |
||||||
1943 | } |
||||||
1944 | } |
||||||
1945 | } |
||||||
1946 | $info['count'] = $count + $child_count; |
||||||
1947 | $info['published'] = $published_date; |
||||||
1948 | |||||||
1949 | return $info; |
||||||
1950 | } |
||||||
1951 | |||||||
1952 | /** |
||||||
1953 | * @param string $indeximage |
||||||
1954 | * @param string $indexheading |
||||||
1955 | * |
||||||
1956 | * @return string |
||||||
1957 | */ |
||||||
1958 | public static function renderImageHeader($indeximage = '', $indexheading = '') |
||||||
1959 | { |
||||||
1960 | if ('' === $indeximage) { |
||||||
1961 | $result = $GLOBALS['xoopsDB']->query('SELECT indeximage, indexheading FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_indexpage')); |
||||||
1962 | [$indeximage, $indexheading] = $GLOBALS['xoopsDB']->fetchrow($result); |
||||||
1963 | } |
||||||
1964 | |||||||
1965 | $image = ''; |
||||||
1966 | if (!empty($indeximage)) { |
||||||
1967 | $image = self::displayImage($indeximage, 'index.php', $GLOBALS['xoopsModuleConfig']['mainimagedir'], $indexheading); |
||||||
1968 | } |
||||||
1969 | |||||||
1970 | return $image; |
||||||
1971 | } |
||||||
1972 | |||||||
1973 | /** |
||||||
1974 | * @param string $image |
||||||
1975 | * @param string $path |
||||||
1976 | * @param string $imgsource |
||||||
1977 | * @param string $alttext |
||||||
1978 | * |
||||||
1979 | * @return string |
||||||
1980 | */ |
||||||
1981 | public static function displayImage($image = '', $path = '', $imgsource = '', $alttext = '') |
||||||
1982 | { |
||||||
1983 | global $xoopsModule; |
||||||
1984 | |||||||
1985 | $showimage = ''; |
||||||
1986 | // Check to see if link is given |
||||||
1987 | if ($path) { |
||||||
1988 | $showimage = '<a href="' . $path . '">'; |
||||||
1989 | } |
||||||
1990 | // checks to see if the file is valid else displays default blank image |
||||||
1991 | if (\is_file(XOOPS_ROOT_PATH . "/{$imgsource}/{$image}")// && is_dir(XOOPS_ROOT_PATH . "/{$imgsource}/{$image}") |
||||||
1992 | ) { |
||||||
1993 | $showimage .= "<img src='" . XOOPS_URL . "/{$imgsource}/{$image}' border='0' title='" . $alttext . "' alt='" . $alttext . "'></a>"; |
||||||
1994 | } elseif ($GLOBALS['xoopsUser'] && $GLOBALS['xoopsUser']->isAdmin($xoopsModule->getVar('mid'))) { |
||||||
1995 | $showimage .= '<img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/brokenimg.png" alt="' . \_MD_XOOPSTUBE_ISADMINNOTICE . '"></a>'; |
||||||
1996 | } else { |
||||||
1997 | $showimage .= '<img src="' . XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/assets/images/blank.png" alt="' . $alttext . '"></a>'; |
||||||
1998 | } |
||||||
1999 | \clearstatcache(); |
||||||
2000 | |||||||
2001 | return $showimage; |
||||||
2002 | } |
||||||
2003 | |||||||
2004 | /** |
||||||
2005 | * @param $published |
||||||
2006 | * |
||||||
2007 | * @return array |
||||||
2008 | */ |
||||||
2009 | public static function isNewImage($published) |
||||||
2010 | { |
||||||
2011 | global $xoopsModule; |
||||||
2012 | |||||||
2013 | $oneday = (\time() - (86400 * 1)); |
||||||
2014 | $threedays = (\time() - (86400 * 3)); |
||||||
2015 | $week = (\time() - (86400 * 7)); |
||||||
2016 | |||||||
2017 | $path = 'modules/' . $xoopsModule->getVar('dirname') . '/assets/images/icon'; |
||||||
2018 | |||||||
2019 | if ($published > 0 && $published < $week) { |
||||||
2020 | $indicator['image'] = "$path/linkload4.png"; |
||||||
2021 | $indicator['alttext'] = \_MD_XOOPSTUBE_NEWLAST; |
||||||
2022 | } elseif ($published >= $week && $published < $threedays) { |
||||||
2023 | $indicator['image'] = "$path/linkload3.png"; |
||||||
2024 | $indicator['alttext'] = \_MD_XOOPSTUBE_NEWTHIS; |
||||||
2025 | } elseif ($published >= $threedays && $published < $oneday) { |
||||||
2026 | $indicator['image'] = "$path/linkload2.png"; |
||||||
2027 | $indicator['alttext'] = \_MD_XOOPSTUBE_THREE; |
||||||
2028 | } elseif ($published >= $oneday) { |
||||||
2029 | $indicator['image'] = "$path/linkload1.png"; |
||||||
2030 | $indicator['alttext'] = \_MD_XOOPSTUBE_TODAY; |
||||||
2031 | } else { |
||||||
2032 | $indicator['image'] = "$path/linkload.png"; |
||||||
2033 | $indicator['alttext'] = \_MD_XOOPSTUBE_NO_FILES; |
||||||
2034 | } |
||||||
2035 | |||||||
2036 | return $indicator; |
||||||
2037 | } |
||||||
2038 | |||||||
2039 | /** |
||||||
2040 | * @param $haystack |
||||||
2041 | * @param $needle |
||||||
2042 | * |
||||||
2043 | * @return string |
||||||
2044 | */ |
||||||
2045 | public static function findStringChar($haystack, $needle) |
||||||
2046 | { |
||||||
2047 | return mb_substr($haystack, 0, mb_strpos($haystack, $needle) + 1); |
||||||
2048 | } |
||||||
2049 | |||||||
2050 | /** |
||||||
2051 | * @param string $header |
||||||
2052 | * @param string $menu |
||||||
2053 | * @param string $extra |
||||||
2054 | * @param int $scount |
||||||
2055 | * |
||||||
2056 | * @return bool|null |
||||||
2057 | */ |
||||||
2058 | public static function renderAdminMenu($header = '', $menu = '', $extra = '', $scount = 4) |
||||||
2059 | { |
||||||
2060 | global $xoopsModule; |
||||||
2061 | |||||||
2062 | $_named_vidid = \xoops_getenv('SCRIPT_NAME'); |
||||||
2063 | if ($_named_vidid) { |
||||||
2064 | $thispage = \basename($_named_vidid); |
||||||
2065 | } |
||||||
2066 | |||||||
2067 | // $op = (isset($_GET['op'])) ? $op = '?op=' . $_GET['op'] : ''; |
||||||
2068 | $op = Request::getString('op', '', 'GET'); |
||||||
2069 | echo '<h4 style="color: #2F5376;">' . \_AM_XOOPSTUBE_MODULE_NAME . '</h4>'; |
||||||
2070 | echo ' |
||||||
2071 | <div style="font-size: 10px; text-align: left; color: #2F5376; padding: 2px 6px; line-height: 18px;"> |
||||||
2072 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2073 | <a href="../admin/index.php">' . \_AM_XOOPSTUBE_BINDEX . '</a> |
||||||
2074 | </span> |
||||||
2075 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2076 | <a href="../index.php">' . \_AM_XOOPSTUBE_GOMODULE . '</a> |
||||||
2077 | </span> |
||||||
2078 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2079 | <a href="../../system/admin.php?fct=preferences&op=showmod&mod=' . $xoopsModule->getVar('mid') . '">' . \_AM_XOOPSTUBE_PREFS . '</a> |
||||||
2080 | </span> |
||||||
2081 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2082 | <a href="../admin/permissions.php">' . \_AM_XOOPSTUBE_BPERMISSIONS . '</a> |
||||||
2083 | </span> |
||||||
2084 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2085 | <a href="../admin/myblocksadmin.php">' . \_AM_XOOPSTUBE_BLOCKADMIN . '</a> |
||||||
2086 | </span> |
||||||
2087 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2088 | <a href="../../system/admin.php?fct=modulesadmin&op=update&module=' . $xoopsModule->getVar('dirname') . '">' . \_AM_XOOPSTUBE_BUPDATE . '</a> |
||||||
2089 | </span> |
||||||
2090 | <span style="margin: 1px; padding: 4px; border: #E8E8E8 1px solid;"> |
||||||
2091 | <a href="../admin/about.php">' . \_AM_XOOPSTUBE_ABOUT . '</a> |
||||||
2092 | </span> |
||||||
2093 | </div><br>'; |
||||||
2094 | |||||||
2095 | if (empty($menu)) { |
||||||
2096 | // You can change this part to suit your own module. Defining this here will save you form having to do this each time. |
||||||
2097 | $menu = [ |
||||||
2098 | \_AM_XOOPSTUBE_MVIDEOS => 'main.php?op=edit', |
||||||
2099 | \_AM_XOOPSTUBE_MCATEGORY => 'category.php', |
||||||
2100 | \_AM_XOOPSTUBE_INDEXPAGE => 'indexpage.php', |
||||||
2101 | // _AM_XOOPSTUBE_MXOOPSTUBE => 'main.php?op=edit', |
||||||
2102 | \_AM_XOOPSTUBE_MUPLOADS => 'upload.php', |
||||||
2103 | \_AM_XOOPSTUBE_VUPLOADS => 'vupload.php', |
||||||
2104 | \_AM_XOOPSTUBE_MVOTEDATA => 'votedata.php', |
||||||
2105 | \_AM_XOOPSTUBE_MCOMMENTS => '../../system/admin.php?module=' . $xoopsModule->getVar('mid') . '&status=0&limit=100&fct=comments&selsubmit=Go', |
||||||
2106 | ]; |
||||||
2107 | } |
||||||
2108 | |||||||
2109 | if (!\is_array($menu)) { |
||||||
2110 | echo '<table width="100%" cellpadding="2" cellspacing="1" class="outer">'; |
||||||
2111 | echo '<tr><td class="even" align="center"><b>' . \_AM_XOOPSTUBE_NOMENUITEMS . '</b></td></tr></table><br>'; |
||||||
2112 | |||||||
2113 | return false; |
||||||
2114 | } |
||||||
2115 | |||||||
2116 | $oddnum = [ |
||||||
2117 | 1 => '1', |
||||||
2118 | 3 => '3', |
||||||
2119 | 5 => '5', |
||||||
2120 | 7 => '7', |
||||||
2121 | 9 => '9', |
||||||
2122 | 11 => '11', |
||||||
2123 | 13 => '13', |
||||||
2124 | ]; |
||||||
2125 | // number of rows per menu |
||||||
2126 | $menurows = \count($menu) / $scount; |
||||||
2127 | // total amount of rows to complete menu |
||||||
2128 | $menurow = \ceil($menurows) * $scount; |
||||||
2129 | // actual number of menuitems per row |
||||||
2130 | $rowcount = $menurow / \ceil($menurows); |
||||||
2131 | $count = 0; |
||||||
2132 | for ($i = \count($menu); $i < $menurow; ++$i) { |
||||||
2133 | $tempArray = [1 => null]; |
||||||
2134 | $menu = \array_merge($menu, $tempArray); |
||||||
2135 | ++$count; |
||||||
2136 | } |
||||||
2137 | |||||||
2138 | // Sets up the width of each menu cell |
||||||
2139 | $width = 100 / $scount; |
||||||
2140 | $width = \ceil($width); |
||||||
2141 | |||||||
2142 | $menucount = 0; |
||||||
2143 | $count = 0; |
||||||
2144 | // Menu table output |
||||||
2145 | echo '<table width="100%" cellpadding="2" cellspacing="1" class="outer" border="1"><tr>'; |
||||||
2146 | // Check to see if $menu is and array |
||||||
2147 | if (\is_array($menu)) { |
||||||
2148 | $classcounts = 0; |
||||||
2149 | $classcol[0] = 'even'; |
||||||
2150 | |||||||
2151 | for ($i = 1; $i < $menurow; ++$i) { |
||||||
2152 | ++$classcounts; |
||||||
2153 | if ($classcounts >= $scount) { |
||||||
2154 | if ('odd' === $classcol[$i - 1]) { |
||||||
2155 | $classcol[$i] = ('odd' === $classcol[$i - 1] && \in_array($classcounts, $oddnum)) ? 'even' : 'odd'; |
||||||
2156 | } else { |
||||||
2157 | $classcol[$i] = ('even' === $classcol[$i - 1] && \in_array($classcounts, $oddnum)) ? 'odd' : 'even'; |
||||||
2158 | } |
||||||
2159 | $classcounts = 0; |
||||||
2160 | } else { |
||||||
2161 | $classcol[$i] = ('even' === $classcol[$i - 1]) ? 'odd' : 'even'; |
||||||
2162 | } |
||||||
2163 | } |
||||||
2164 | unset($classcounts); |
||||||
2165 | |||||||
2166 | foreach ($menu as $menutitle => $menuvideo) { |
||||||
2167 | if ($thispage . $op == $menuvideo) { |
||||||
2168 | $classcol[$count] = 'outer'; |
||||||
2169 | } |
||||||
2170 | echo '<td class="' . $classcol[$count] . '" style="padding: 4px; text-align: center;" valign="middle" width="' . $width . '%">'; |
||||||
2171 | if (\is_string($menuvideo)) { |
||||||
2172 | echo '<a href="' . $menuvideo . '"><span style="font-size: small;">' . $menutitle . '</span></a></td>'; |
||||||
2173 | } else { |
||||||
2174 | echo ' </td>'; |
||||||
2175 | } |
||||||
2176 | ++$menucount; |
||||||
2177 | ++$count; |
||||||
2178 | // Break menu cells to start a new row if $count > $scount |
||||||
2179 | if ($menucount >= $scount) { |
||||||
2180 | echo '</tr>'; |
||||||
2181 | $menucount = 0; |
||||||
2182 | } |
||||||
2183 | } |
||||||
2184 | echo '</table><br>'; |
||||||
2185 | unset($count, $menucount); |
||||||
2186 | } |
||||||
2187 | // ###### Output warn messages for security ###### |
||||||
2188 | if (\is_dir(XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/update/')) { |
||||||
2189 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL1, XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/update/')); |
||||||
2190 | echo '<br>'; |
||||||
2191 | } |
||||||
2192 | |||||||
2193 | $_file = XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/update.php'; |
||||||
2194 | if (\file_exists($_file)) { |
||||||
2195 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL2, XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/update.php')); |
||||||
2196 | echo '<br>'; |
||||||
2197 | } |
||||||
2198 | |||||||
2199 | $path1 = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['mainimagedir']; |
||||||
2200 | if (!\is_dir($path1)) { |
||||||
2201 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path1)); |
||||||
2202 | echo '<br>'; |
||||||
2203 | } |
||||||
2204 | if (!\is_writable($path1)) { |
||||||
2205 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path1)); |
||||||
2206 | echo '<br>'; |
||||||
2207 | } |
||||||
2208 | |||||||
2209 | $path1_t = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['mainimagedir'] . '/thumbs'; |
||||||
2210 | if (!\is_dir($path1_t)) { |
||||||
2211 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path1_t)); |
||||||
2212 | echo '<br>'; |
||||||
2213 | } |
||||||
2214 | if (!\is_writable($path1_t)) { |
||||||
2215 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path1_t)); |
||||||
2216 | echo '<br>'; |
||||||
2217 | } |
||||||
2218 | |||||||
2219 | $path2 = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['videoimgdir']; |
||||||
2220 | if (!\is_dir($path2)) { |
||||||
2221 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path2)); |
||||||
2222 | echo '<br>'; |
||||||
2223 | } |
||||||
2224 | if (!\is_writable($path2)) { |
||||||
2225 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path2)); |
||||||
2226 | echo '<br>'; |
||||||
2227 | } |
||||||
2228 | |||||||
2229 | // $path2_t = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['videoimgdir'] . '/thumbs'; |
||||||
2230 | // if ( !is_dir( $path2_t ) || !is_writable( $path2_t ) ) { |
||||||
2231 | // xoops_error( sprintf( _AM_XOOPSTUBE_WARNINSTALL3, $path2_t ) ); |
||||||
2232 | // echo '<br>'; |
||||||
2233 | // } |
||||||
2234 | |||||||
2235 | $path3 = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['catimage']; |
||||||
2236 | if (!\is_dir($path3)) { |
||||||
2237 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path3)); |
||||||
2238 | echo '<br>'; |
||||||
2239 | } |
||||||
2240 | if (!\is_writable($path3)) { |
||||||
2241 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path3)); |
||||||
2242 | echo '<br>'; |
||||||
2243 | } |
||||||
2244 | |||||||
2245 | $path3_t = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['catimage'] . '/thumbs'; |
||||||
2246 | if (!\is_dir($path3_t)) { |
||||||
2247 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path3_t)); |
||||||
2248 | echo '<br>'; |
||||||
2249 | } |
||||||
2250 | if (!\is_writable($path3_t)) { |
||||||
2251 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path3_t)); |
||||||
2252 | echo '<br>'; |
||||||
2253 | } |
||||||
2254 | |||||||
2255 | $path4 = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['videodir']; |
||||||
2256 | if (!\is_dir($path4)) { |
||||||
2257 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL3, $path4)); |
||||||
2258 | echo '<br>'; |
||||||
2259 | } |
||||||
2260 | if (!\is_writable($path4)) { |
||||||
2261 | \xoops_error(\sprintf(\_AM_XOOPSTUBE_WARNINSTALL4, $path4)); |
||||||
2262 | echo '<br>'; |
||||||
2263 | } |
||||||
2264 | |||||||
2265 | echo '<h4 style="color: #2F5376;">' . $header . '</h4>'; |
||||||
2266 | if ($extra) { |
||||||
2267 | echo '<div>' . $extra . '</div>'; |
||||||
2268 | } |
||||||
2269 | |||||||
2270 | return null; |
||||||
2271 | } |
||||||
2272 | |||||||
2273 | /** |
||||||
2274 | * @param $selected |
||||||
2275 | * @param $dirarray |
||||||
2276 | * @param $namearray |
||||||
2277 | */ |
||||||
2278 | public static function getDirSelectOption($selected, $dirarray, $namearray) |
||||||
2279 | { |
||||||
2280 | echo "<select size='1' name='workd' onchange='location.href=\"upload.php?rootpath=\"+this.options[this.selectedIndex].value'>"; |
||||||
2281 | echo "<option value=''>--------------------------------------</option>"; |
||||||
2282 | foreach ($namearray as $namearray => $workd) { |
||||||
2283 | $opt_selected = ''; |
||||||
2284 | if ($workd == $selected) { |
||||||
2285 | $opt_selected = 'selected'; |
||||||
2286 | } |
||||||
2287 | echo '<option value="' . \htmlspecialchars($namearray, \ENT_QUOTES) . '" $opt_selected>' . $workd . '</option>'; |
||||||
2288 | } |
||||||
2289 | echo '</select>'; |
||||||
2290 | } |
||||||
2291 | |||||||
2292 | // /** |
||||||
2293 | // * @param $selected |
||||||
2294 | // * @param $dirarray |
||||||
2295 | // * @param $namearray |
||||||
2296 | // */ |
||||||
2297 | // public static function getDirSelectOption($selected, $dirarray, $namearray) |
||||||
2298 | // { |
||||||
2299 | // echo "<select size='1' name='workd' onchange='location.href=\"vupload.php?rootpath=\"+this.options[this.selectedIndex].value'>"; |
||||||
2300 | // echo "<option value=''>--------------------------------------</option>"; |
||||||
2301 | // foreach ($namearray as $namearray => $workd) { |
||||||
2302 | // $opt_selected = ''; |
||||||
2303 | // if ($workd == $selected) { |
||||||
2304 | // $opt_selected = 'selected'; |
||||||
2305 | // } |
||||||
2306 | // echo '<option value="' . htmlspecialchars($namearray, ENT_QUOTES) . '" $opt_selected>' . $workd . '</option>'; |
||||||
2307 | // } |
||||||
2308 | // echo '</select>'; |
||||||
2309 | // } |
||||||
2310 | |||||||
2311 | /** |
||||||
2312 | * @param $FILES |
||||||
2313 | * @param string $uploaddir |
||||||
2314 | * @param string $allowed_mimetypes |
||||||
2315 | * @param string $redirecturl |
||||||
2316 | * @param int $redirect |
||||||
2317 | * @param int $usertype |
||||||
2318 | * |
||||||
2319 | * @return array|null |
||||||
2320 | */ |
||||||
2321 | public static function uploadFiles( |
||||||
2322 | $FILES, |
||||||
2323 | $uploaddir = 'uploads', |
||||||
2324 | $allowed_mimetypes = '', |
||||||
2325 | $redirecturl = 'index.php', // $num = 0, |
||||||
2326 | $redirect = 0, |
||||||
2327 | $usertype = 1 |
||||||
2328 | ) { |
||||||
2329 | global $FILES, $xoopsModule; |
||||||
2330 | |||||||
2331 | $down = []; |
||||||
2332 | // require_once XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/class/uploader.php'; |
||||||
2333 | // require_once __DIR__ . '/uploader.php'; |
||||||
2334 | // require XOOPS_ROOT_PATH . '/class/uploader.php'; |
||||||
2335 | |||||||
2336 | if (empty($allowed_mimetypes)) { |
||||||
2337 | $allowed_mimetypes = self::getMimeType($FILES['userfile']['name'], $usertype); |
||||||
2338 | } |
||||||
2339 | $upload_dir = XOOPS_ROOT_PATH . '/' . $uploaddir . '/'; |
||||||
2340 | |||||||
2341 | $maxfilesize = $GLOBALS['xoopsModuleConfig']['maxfilesize']; |
||||||
2342 | |||||||
2343 | $maxfilewidth = $GLOBALS['xoopsModuleConfig']['maximgwidth']; |
||||||
2344 | $maxfileheight = $GLOBALS['xoopsModuleConfig']['maximgheight']; |
||||||
2345 | |||||||
2346 | $uploader = new MediaUploader($upload_dir, $allowed_mimetypes, $maxfilesize, $maxfilewidth, $maxfileheight); |
||||||
2347 | $uploader->noAdminSizeCheck(1); |
||||||
2348 | //if ($uploader->fetchMedia(Request::getArray('xoops_upload_file[0]', array(), 'POST'))) { |
||||||
2349 | if ($uploader->fetchMedia(Request::getArray('xoops_upload_file', '', 'POST')[0])) { |
||||||
2350 | if (!$uploader->upload()) { |
||||||
2351 | $errors = $uploader->getErrors(); |
||||||
2352 | \redirect_header($redirecturl, 2, $errors); |
||||||
2353 | } elseif ($redirect) { |
||||||
2354 | \redirect_header($redirecturl, 1, \_AM_XOOPSTUBE_UPLOADFILE); |
||||||
2355 | } else { |
||||||
2356 | if (\is_file($uploader->savedDestination)) { |
||||||
2357 | $down['url'] = XOOPS_URL . '/' . $uploaddir . '/' . mb_strtolower($uploader->savedFileName); |
||||||
2358 | $down['size'] = \filesize(XOOPS_ROOT_PATH . '/' . $uploaddir . '/' . mb_strtolower($uploader->savedFileName)); |
||||||
2359 | } |
||||||
2360 | |||||||
2361 | return $down; |
||||||
2362 | } |
||||||
2363 | } else { |
||||||
2364 | $errors = $uploader->getErrors(); |
||||||
2365 | \redirect_header($redirecturl, 1, $errors); |
||||||
2366 | } |
||||||
2367 | |||||||
2368 | return null; |
||||||
2369 | } |
||||||
2370 | |||||||
2371 | /** |
||||||
2372 | * @param $heading |
||||||
2373 | */ |
||||||
2374 | public static function renderCategoryListHeader($heading) |
||||||
2375 | { |
||||||
2376 | echo ' |
||||||
2377 | <h4 style="font-weight: bold; color: #0A3760;">' . $heading . '</h4> |
||||||
2378 | <table width="100%" cellspacing="1" class="outer" summary> |
||||||
2379 | <tr> |
||||||
2380 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ID . '</th> |
||||||
2381 | <th style=" font-size: smaller;"><b>' . \_AM_XOOPSTUBE_FCATEGORY_TITLE . '</th> |
||||||
2382 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_FCATEGORY_WEIGHT . '</th> |
||||||
2383 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_FCATEGORY_CIMAGE . '</th> |
||||||
2384 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_CATSPONSOR . '</th> |
||||||
2385 | <!-- <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_PUBLISH . '</th> |
||||||
2386 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_EXPIRE . '</th> |
||||||
2387 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ONLINE . '</th> |
||||||
2388 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ACTION . '</th> --> |
||||||
2389 | </tr> |
||||||
2390 | '; |
||||||
2391 | } |
||||||
2392 | |||||||
2393 | /** |
||||||
2394 | * @param $published |
||||||
2395 | */ |
||||||
2396 | public static function renderCategoryListBody($published) |
||||||
2397 | { |
||||||
2398 | global $xtubeImageArray; |
||||||
2399 | |||||||
2400 | $xtubemyts = new TextSanitizer(); |
||||||
2401 | |||||||
2402 | $lid = $published['lid']; |
||||||
2403 | $cid = $published['cid']; |
||||||
2404 | |||||||
2405 | $title = '<a href="../singlevideo.php?cid=' . $published['cid'] . '&lid=' . $published['lid'] . '">' . $xtubemyts->htmlSpecialCharsStrip(\trim($published['title'])) . '</a>'; |
||||||
2406 | $maintitle = \urlencode(\htmlspecialchars(\trim($published['title']), \ENT_QUOTES | \ENT_HTML5)); |
||||||
2407 | $cattitle = '<a href="../viewcat.php?cid=' . $published['cid'] . '">' . self::getCategoryTitle($published['cid']) . '</a>'; |
||||||
2408 | $submitter = self::getLinkedUserNameFromId($published['submitter']); |
||||||
2409 | $returnsource = \xtubeReturnSource($published['vidsource']); |
||||||
2410 | $submitted = self::getTimestamp(\formatTimestamp($published['date'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])); |
||||||
2411 | $publish = ($published['published'] > 0) ? self::getTimestamp(\formatTimestamp($published['published'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])) : 'Not Published'; |
||||||
2412 | $expires = $published['expired'] ? self::getTimestamp(\formatTimestamp($published['expired'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])) : \_AM_XOOPSTUBE_MINDEX_NOTSET; |
||||||
2413 | |||||||
2414 | if ((($published['expired'] && $published['expired'] > \time()) || 0 == $published['expired']) |
||||||
2415 | && ($published['published'] && $published['published'] < \time()) |
||||||
2416 | && 0 == $published['offline']) { |
||||||
2417 | $published_status = $xtubeImageArray['online']; |
||||||
2418 | } elseif (($published['expired'] && $published['expired'] < \time()) && 0 == $published['offline']) { |
||||||
2419 | $published_status = $xtubeImageArray['expired']; |
||||||
2420 | } else { |
||||||
2421 | $published_status = (0 == $published['published']) ? '<a href="newvideos.php">' . $xtubeImageArray['offline'] . '</a>' : $xtubeImageArray['offline']; |
||||||
2422 | } |
||||||
2423 | |||||||
2424 | if (200 == $published['vidsource']) { |
||||||
2425 | $icon = '<a href="main.php?op=edit&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_EDIT . '">' . $xtubeImageArray['editimg'] . '</a> '; |
||||||
2426 | } else { |
||||||
2427 | $icon = '<a href="main.php?op=edit&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_EDIT . '">' . $xtubeImageArray['editimg'] . '</a> '; |
||||||
2428 | } |
||||||
2429 | $icon .= '<a href="main.php?op=delete&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_DELETE . '">' . $xtubeImageArray['deleteimg'] . '</a> '; |
||||||
2430 | $icon .= '<a href="altcat.php?op=main&cid=' . $cid . '&lid=' . $lid . '&title=' . $published['title'] . '" title="' . \_AM_XOOPSTUBE_ALTCAT_CREATEF . '">' . $xtubeImageArray['altcat'] . '</a>'; |
||||||
2431 | |||||||
2432 | echo ' |
||||||
2433 | <tr style="text-align: center; font-size: smaller;"> |
||||||
2434 | <td class="head">' . $lid . '</span></td> |
||||||
2435 | <td class="even" style="text-align: left;">' . $title . '</td> |
||||||
2436 | <td class="even">' . $returnsource . '</td> |
||||||
2437 | <td class="even">' . $cattitle . '</td> |
||||||
2438 | <td class="even">' . $submitter . '</td> |
||||||
2439 | <td class="even">' . $publish . '</td> |
||||||
2440 | <td class="even">' . $expires . '</td> |
||||||
2441 | <td class="even" style="width: 4%;">' . $published_status . '</td> |
||||||
2442 | <td class="even" style="text-align: center; width: 6%; white-space: nowrap;">' . $icon . '</td> |
||||||
2443 | </tr>'; |
||||||
2444 | // unset($published); |
||||||
2445 | } |
||||||
2446 | |||||||
2447 | /** |
||||||
2448 | * @param $pubrowamount |
||||||
2449 | * @param $start |
||||||
2450 | * @param string $art |
||||||
2451 | * @param string $_this |
||||||
2452 | * @param $align |
||||||
2453 | * |
||||||
2454 | * @return bool|null |
||||||
2455 | */ |
||||||
2456 | public static function setPageNavigationCategoryList( |
||||||
2457 | $pubrowamount, |
||||||
2458 | $start, |
||||||
2459 | $art, |
||||||
2460 | $_this, |
||||||
2461 | $align |
||||||
2462 | ) { |
||||||
2463 | if ($pubrowamount < $GLOBALS['xoopsModuleConfig']['admin_perpage']) { |
||||||
2464 | return false; |
||||||
2465 | } |
||||||
2466 | // Display Page Nav if published is > total display pages amount. |
||||||
2467 | require_once XOOPS_ROOT_PATH . '/class/pagenav.php'; |
||||||
2468 | $pagenav = new \XoopsPageNav($pubrowamount, $GLOBALS['xoopsModuleConfig']['admin_perpage'], $start, 'st' . $art, $_this); |
||||||
2469 | echo '<div style="text-align: ' . $align . '; padding: 8px;">' . $pagenav->renderNav() . '</div>'; |
||||||
2470 | |||||||
2471 | return null; |
||||||
2472 | } |
||||||
2473 | |||||||
2474 | public static function renderCategoryListFooter() |
||||||
2475 | { |
||||||
2476 | echo '<tr style="text-align: center;"> |
||||||
2477 | <td class="head" colspan="7">' . \_AM_XOOPSTUBE_MINDEX_NOVIDEOSFOUND . '</td> |
||||||
2478 | </tr>'; |
||||||
2479 | } |
||||||
2480 | |||||||
2481 | /** |
||||||
2482 | * @param $heading |
||||||
2483 | */ |
||||||
2484 | public static function renderVideoListHeader($heading) |
||||||
2485 | { |
||||||
2486 | echo ' |
||||||
2487 | <h4 style="font-weight: bold; color: #0A3760;">' . $heading . '</h4> |
||||||
2488 | <table width="100%" cellspacing="1" class="outer" summary> |
||||||
2489 | <tr> |
||||||
2490 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ID . '</th> |
||||||
2491 | <th style=" font-size: smaller;"><b>' . \_AM_XOOPSTUBE_MINDEX_TITLE . '</th> |
||||||
2492 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_VIDSOURCE2 . '</th> |
||||||
2493 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_CATTITLE . '</th> |
||||||
2494 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_POSTER . '</th> |
||||||
2495 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_PUBLISH . '</th> |
||||||
2496 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_EXPIRE . '</th> |
||||||
2497 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ONLINE . '</th> |
||||||
2498 | <th style="text-align: center; font-size: smaller;">' . \_AM_XOOPSTUBE_MINDEX_ACTION . '</th> |
||||||
2499 | </tr> |
||||||
2500 | '; |
||||||
2501 | } |
||||||
2502 | |||||||
2503 | /** |
||||||
2504 | * @param $published |
||||||
2505 | */ |
||||||
2506 | public static function renderVideoListBody($published) |
||||||
2507 | { |
||||||
2508 | global $xtubeImageArray, $pathIcon16; |
||||||
2509 | |||||||
2510 | $xtubemyts = new TextSanitizer(); |
||||||
2511 | |||||||
2512 | $lid = $published['lid']; |
||||||
2513 | $cid = $published['cid']; |
||||||
2514 | |||||||
2515 | $title = '<a href="../singlevideo.php?cid=' . $published['cid'] . '&lid=' . $published['lid'] . '">' . $xtubemyts->htmlSpecialChars(\trim($published['title']), \ENT_QUOTES | \ENT_HTML5) . '</a>'; |
||||||
2516 | $maintitle = \urlencode(\htmlspecialchars(\trim($published['title']), \ENT_QUOTES | \ENT_HTML5)); |
||||||
2517 | $cattitle = '<a href="../viewcat.php?cid=' . $published['cid'] . '">' . self::getCategoryTitle($published['cid']) . '</a>'; |
||||||
2518 | $submitter = self::getLinkedUserNameFromId($published['submitter']); |
||||||
2519 | $returnsource = \xtubeReturnSource($published['vidsource']); |
||||||
2520 | $submitted = self::getTimestamp(\formatTimestamp($published['date'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])); |
||||||
2521 | $publish = ($published['published'] > 0) ? self::getTimestamp(\formatTimestamp($published['published'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])) : 'Not Published'; |
||||||
2522 | $expires = $published['expired'] ? self::getTimestamp(\formatTimestamp($published['expired'], $GLOBALS['xoopsModuleConfig']['dateformatadmin'])) : \_AM_XOOPSTUBE_MINDEX_NOTSET; |
||||||
2523 | |||||||
2524 | if ((($published['expired'] && (int)$published['expired'] > \time()) || 0 === (int)$published['expired']) |
||||||
2525 | && ($published['published'] && (int)$published['published'] < \time()) |
||||||
2526 | && 0 === (int)$published['offline']) { |
||||||
2527 | $published_status = '<a href="main.php?op=toggle&lid=' . $lid . '&offline=' . (int)$published['offline'] . '"><img src="' . $pathIcon16 . '/1.png' . '"></a>'; |
||||||
2528 | } elseif (($published['expired'] && (int)$published['expired'] < \time()) && 0 === (int)$published['offline']) { |
||||||
2529 | $published_status = $xtubeImageArray['expired']; |
||||||
2530 | } else { |
||||||
2531 | $published_status = (0 === (int)$published['published']) ? '<a href="newvideos.php">' . $xtubeImageArray['offline'] . '</a>' : '<a href="main.php?op=toggle&lid=' . $lid . '&offline=' . $published['offline'] . '"><img src="' . $pathIcon16 . '/0.png' . '"></a>'; |
||||||
2532 | } |
||||||
2533 | |||||||
2534 | if (200 == $published['vidsource']) { |
||||||
2535 | $icon = '<a href="main.php?op=edit&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_EDIT . '">' . $xtubeImageArray['editimg'] . '</a> '; |
||||||
2536 | } else { |
||||||
2537 | $icon = '<a href="main.php?op=edit&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_EDIT . '">' . $xtubeImageArray['editimg'] . '</a> '; |
||||||
2538 | } |
||||||
2539 | $icon .= '<a href="main.php?op=delete&lid=' . $lid . '" title="' . \_AM_XOOPSTUBE_ICO_DELETE . '">' . $xtubeImageArray['deleteimg'] . '</a> '; |
||||||
2540 | $icon .= '<a href="altcat.php?op=main&cid=' . $cid . '&lid=' . $lid . '&title=' . $published['title'] . '" title="' . \_AM_XOOPSTUBE_ALTCAT_CREATEF . '">' . $xtubeImageArray['altcat'] . '</a>'; |
||||||
2541 | |||||||
2542 | echo ' |
||||||
2543 | <tr style="text-align: center; font-size: smaller;"> |
||||||
2544 | <td class="head">' . $lid . '</span></td> |
||||||
2545 | <td class="even" style="text-align: left;">' . $title . '</td> |
||||||
2546 | <td class="even">' . $returnsource . '</td> |
||||||
2547 | <td class="even">' . $cattitle . '</td> |
||||||
2548 | <td class="even">' . $submitter . '</td> |
||||||
2549 | <td class="even">' . $publish . '</td> |
||||||
2550 | <td class="even">' . $expires . '</td> |
||||||
2551 | <td class="even" style="width: 4%;">' . $published_status . '</td> |
||||||
2552 | <td class="even" style="text-align: center; width: 6%; white-space: nowrap;">' . $icon . '</td> |
||||||
2553 | </tr>'; |
||||||
2554 | // unset($published); |
||||||
2555 | } |
||||||
2556 | |||||||
2557 | /** |
||||||
2558 | * @param $catt |
||||||
2559 | * |
||||||
2560 | * @return mixed |
||||||
2561 | */ |
||||||
2562 | public static function getCategoryTitle($catt) |
||||||
2563 | { |
||||||
2564 | $sql = 'SELECT title FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_cat') . ' WHERE cid=' . $catt; |
||||||
2565 | $result = $GLOBALS['xoopsDB']->query($sql); |
||||||
2566 | $result = $GLOBALS['xoopsDB']->fetchArray($result); |
||||||
2567 | |||||||
2568 | return $result['title']; |
||||||
2569 | } |
||||||
2570 | |||||||
2571 | public static function renderVideoListFooter() |
||||||
2572 | { |
||||||
2573 | echo '<tr style="text-align: center;"> |
||||||
2574 | <td class="head" colspan="7">' . \_AM_XOOPSTUBE_MINDEX_NOVIDEOSFOUND . '</td> |
||||||
2575 | </tr>'; |
||||||
2576 | } |
||||||
2577 | |||||||
2578 | /** |
||||||
2579 | * @param $pubrowamount |
||||||
2580 | * @param $start |
||||||
2581 | * @param string $art |
||||||
2582 | * @param string $_this |
||||||
2583 | * @param $align |
||||||
2584 | * |
||||||
2585 | * @return bool|null |
||||||
2586 | */ |
||||||
2587 | public static function setPageNavigationVideoList($pubrowamount, $start, $art, $_this, $align) |
||||||
2588 | { |
||||||
2589 | if ($pubrowamount < $GLOBALS['xoopsModuleConfig']['admin_perpage']) { |
||||||
2590 | return false; |
||||||
2591 | } |
||||||
2592 | // Display Page Nav if published is > total display pages amount. |
||||||
2593 | require_once XOOPS_ROOT_PATH . '/class/pagenav.php'; |
||||||
2594 | $pagenav = new \XoopsPageNav($pubrowamount, $GLOBALS['xoopsModuleConfig']['admin_perpage'], $start, 'st' . $art, $_this); |
||||||
2595 | echo '<div style="text-align: ' . $align . '; padding: 8px;">' . $pagenav->renderNav() . '</div>'; |
||||||
2596 | |||||||
2597 | return null; |
||||||
2598 | } |
||||||
2599 | |||||||
2600 | /** |
||||||
2601 | * @param $document |
||||||
2602 | * |
||||||
2603 | * @return array|string|string[]|null |
||||||
2604 | */ |
||||||
2605 | public static function convertHtml2text($document) |
||||||
2606 | { |
||||||
2607 | // PHP Manual:: function preg_replace |
||||||
2608 | // $document should contain an HTML document. |
||||||
2609 | // This will remove HTML tags, javascript sections |
||||||
2610 | // and white space. It will also convert some |
||||||
2611 | // common HTML entities to their text equivalent. |
||||||
2612 | // Credits : newbb2 |
||||||
2613 | $search = [ |
||||||
2614 | "'<script[^>]*?>.*?</script>'si", // Strip out javascript |
||||||
2615 | "'<img.*?>'si", // Strip out img tags |
||||||
2616 | "'<[\/\!]*?[^<>]*?>'si", // Strip out HTML tags |
||||||
2617 | "'([\r\n])[\s]+'", // Strip out white space |
||||||
2618 | "'&(quot|#34);'i", // Replace HTML entities |
||||||
2619 | "'&(amp|#38);'i", |
||||||
2620 | "'&(lt|#60);'i", |
||||||
2621 | "'&(gt|#62);'i", |
||||||
2622 | "'&(nbsp|#160);'i", |
||||||
2623 | "'&(iexcl|#161);'i", |
||||||
2624 | "'&(cent|#162);'i", |
||||||
2625 | "'&(pound|#163);'i", |
||||||
2626 | "'&(copy|#169);'i", |
||||||
2627 | ]; // evaluate as php |
||||||
2628 | |||||||
2629 | $replace = [ |
||||||
2630 | '', |
||||||
2631 | '', |
||||||
2632 | '', |
||||||
2633 | '\\1', |
||||||
2634 | '"', |
||||||
2635 | '&', |
||||||
2636 | '<', |
||||||
2637 | '>', |
||||||
2638 | ' ', |
||||||
2639 | \chr(161), |
||||||
2640 | \chr(162), |
||||||
2641 | \chr(163), |
||||||
2642 | \chr(169), |
||||||
2643 | ]; |
||||||
2644 | |||||||
2645 | $text = \preg_replace($search, $replace, $document); |
||||||
2646 | |||||||
2647 | \preg_replace_callback( |
||||||
2648 | '/&#(\d+);/', |
||||||
2649 | static function ($matches) { |
||||||
2650 | return \chr($matches[1]); |
||||||
2651 | }, |
||||||
2652 | $document |
||||||
2653 | ); |
||||||
2654 | |||||||
2655 | return $text; |
||||||
2656 | } |
||||||
2657 | |||||||
2658 | // Check if Tag module is installed |
||||||
2659 | |||||||
2660 | /** |
||||||
2661 | * @return bool |
||||||
2662 | */ |
||||||
2663 | public static function isModuleTagInstalled() |
||||||
2664 | { |
||||||
2665 | static $isModuleTagInstalled; |
||||||
2666 | if (!isset($isModuleTagInstalled)) { |
||||||
2667 | /** @var \XoopsModuleHandler $moduleHandler */ |
||||||
2668 | $moduleHandler = \xoops_getHandler('module'); |
||||||
2669 | $tag_mod = $moduleHandler->getByDirname('tag'); |
||||||
2670 | if (!$tag_mod) { |
||||||
2671 | $tag_mod = false; |
||||||
2672 | } else { |
||||||
2673 | $isModuleTagInstalled = 1 == $tag_mod->getVar('isactive'); |
||||||
2674 | } |
||||||
2675 | } |
||||||
2676 | |||||||
2677 | return $isModuleTagInstalled; |
||||||
2678 | } |
||||||
2679 | |||||||
2680 | // Add item_tag to Tag-module |
||||||
2681 | |||||||
2682 | /** |
||||||
2683 | * @param $lid |
||||||
2684 | * @param $item_tag |
||||||
2685 | */ |
||||||
2686 | public static function updateTag($lid, $item_tag) |
||||||
2687 | { |
||||||
2688 | global $xoopsModule; |
||||||
2689 | if (self::isModuleTagInstalled()) { |
||||||
2690 | require_once XOOPS_ROOT_PATH . '/modules/tag/include/formtag.php'; |
||||||
2691 | $tagHandler = \XoopsModules\Tag\Helper::getInstance()->getHandler('Tag'); // xoops_getModuleHandler('tag', 'tag'); |
||||||
2692 | $tagHandler->updateByItem($item_tag, $lid, $xoopsModule->getVar('dirname'), 0); |
||||||
2693 | } |
||||||
2694 | } |
||||||
2695 | |||||||
2696 | /** |
||||||
2697 | * @param $lid |
||||||
2698 | */ |
||||||
2699 | public static function updateCounter($lid) |
||||||
2700 | { |
||||||
2701 | $sql = 'UPDATE ' . $GLOBALS['xoopsDB']->prefix('xoopstube_videos') . ' SET hits=hits+1 WHERE lid=' . (int)$lid; |
||||||
2702 | $result = $GLOBALS['xoopsDB']->queryF($sql); |
||||||
2703 | } |
||||||
2704 | |||||||
2705 | /** |
||||||
2706 | * @param $banner_id |
||||||
2707 | * |
||||||
2708 | * @return null|string |
||||||
2709 | */ |
||||||
2710 | public static function getBannerFromBannerId($banner_id) |
||||||
2711 | { |
||||||
2712 | ###### Hack by www.stefanosilvestrini.com ###### |
||||||
2713 | $db = \XoopsDatabaseFactory::getDatabaseConnection(); |
||||||
2714 | $bresult = $db->query('SELECT COUNT(*) FROM ' . $db->prefix('banner') . ' WHERE bid=' . $banner_id); |
||||||
2715 | [$numrows] = $db->fetchRow($bresult); |
||||||
2716 | if ($numrows > 1) { |
||||||
2717 | --$numrows; |
||||||
2718 | try { |
||||||
2719 | $bannum = \random_int(0, $numrows); |
||||||
2720 | } catch (\Exception $e) { |
||||||
2721 | } |
||||||
2722 | } else { |
||||||
2723 | $bannum = 0; |
||||||
2724 | } |
||||||
2725 | if ($numrows > 0) { |
||||||
2726 | $bresult = $db->query('SELECT * FROM ' . $db->prefix('banner') . ' WHERE bid=' . $banner_id, 1, $bannum); |
||||||
2727 | [$bid, $cid, $imptotal, $impmade, $clicks, $imageurl, $clickurl, $date, $htmlbanner, $htmlcode] = $db->fetchRow($bresult); |
||||||
2728 | if ($GLOBALS['xoopsConfig']['my_ip'] == \xoops_getenv('REMOTE_ADDR')) { |
||||||
2729 | // EMPTY |
||||||
2730 | } else { |
||||||
2731 | $db->queryF(\sprintf('UPDATE `%s` SET impmade = impmade+1 WHERE bid = %u', $db->prefix('banner'), $bid)); |
||||||
2732 | } |
||||||
2733 | /* Check if this impression is the last one and print the banner */ |
||||||
2734 | if ($imptotal == $impmade) { |
||||||
2735 | $newid = $db->genId($db->prefix('bannerfinish') . '_bid_seq'); |
||||||
2736 | $sql = \sprintf('INSERT INTO `%s` (bid, cid, impressions, clicks, datestart, dateend) VALUES (%u, %u, %u, %u, %u, %u)', $db->prefix('bannerfinish'), $newid, $cid, $impmade, $clicks, $date, \time()); |
||||||
2737 | $db->queryF($sql); |
||||||
2738 | $db->queryF(\sprintf('DELETE FROM `%s` WHERE bid = %u', $db->prefix('banner'), $bid)); |
||||||
2739 | } |
||||||
2740 | if ($htmlbanner) { |
||||||
2741 | $bannerobject = $htmlcode; |
||||||
2742 | } else { |
||||||
2743 | $bannerobject = '<div align="center"><a href="' . XOOPS_URL . '/banners.php?op=click&bid=' . $bid . '" target="_blank">'; |
||||||
2744 | if (false !== mb_stripos($imageurl, '.swf')) { |
||||||
2745 | $bannerobject .= '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="https://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0" width="468" height="60">' |
||||||
2746 | . '<param name="movie" value="' |
||||||
2747 | . $imageurl |
||||||
2748 | . '"></param>' |
||||||
2749 | . '<param name="quality" value="high"></param>' |
||||||
2750 | . '<embed src="' |
||||||
2751 | . $imageurl |
||||||
2752 | . '" quality="high" pluginspage="https://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash" type="application/x-shockwave-flash" width="468" height="60">' |
||||||
2753 | . '</embed>' |
||||||
2754 | . '</object>'; |
||||||
2755 | } else { |
||||||
2756 | $bannerobject .= '<img src="' . $imageurl . '" alt="">'; |
||||||
2757 | } |
||||||
2758 | $bannerobject .= '</a></div>'; |
||||||
2759 | } |
||||||
2760 | |||||||
2761 | return $bannerobject; |
||||||
2762 | } |
||||||
2763 | |||||||
2764 | return null; |
||||||
2765 | } |
||||||
2766 | |||||||
2767 | /** |
||||||
2768 | * @param $client_id |
||||||
2769 | * |
||||||
2770 | * @return null|string |
||||||
2771 | */ |
||||||
2772 | public static function getBannerFromClientId($client_id) |
||||||
2773 | { |
||||||
2774 | ###### Hack by www.stefanosilvestrini.com ###### |
||||||
2775 | $db = \XoopsDatabaseFactory::getDatabaseConnection(); |
||||||
2776 | $bresult = $db->query('SELECT COUNT(*) FROM ' . $db->prefix('banner') . ' WHERE cid=' . $client_id); |
||||||
2777 | [$numrows] = $db->fetchRow($bresult); |
||||||
2778 | if ($numrows > 1) { |
||||||
2779 | --$numrows; |
||||||
2780 | try { |
||||||
2781 | $bannum = \random_int(0, $numrows); |
||||||
2782 | } catch (\Exception $e) { |
||||||
2783 | } |
||||||
2784 | } else { |
||||||
2785 | $bannum = 0; |
||||||
2786 | } |
||||||
2787 | if ($numrows > 0) { |
||||||
2788 | $bresult = $db->query('SELECT * FROM ' . $db->prefix('banner') . ' WHERE cid=' . $client_id . ' ORDER BY rand()', 1, $bannum); |
||||||
2789 | [$bid, $cid, $imptotal, $impmade, $clicks, $imageurl, $clickurl, $date, $htmlbanner, $htmlcode] = $db->fetchRow($bresult); |
||||||
2790 | if ($GLOBALS['xoopsConfig']['my_ip'] == \xoops_getenv('REMOTE_ADDR')) { |
||||||
2791 | // EMPTY |
||||||
2792 | } else { |
||||||
2793 | $db->queryF(\sprintf('UPDATE `%s` SET impmade = impmade+1 WHERE bid = %u', $db->prefix('banner'), $bid)); |
||||||
2794 | } |
||||||
2795 | /* Check if this impression is the last one and print the banner */ |
||||||
2796 | if ($imptotal == $impmade) { |
||||||
2797 | $newid = $db->genId($db->prefix('bannerfinish') . '_bid_seq'); |
||||||
2798 | $sql = \sprintf('INSERT INTO `%s` (bid, cid, impressions, clicks, datestart, dateend) VALUES (%u, %u, %u, %u, %u, %u)', $db->prefix('bannerfinish'), $newid, $cid, $impmade, $clicks, $date, \time()); |
||||||
2799 | $db->queryF($sql); |
||||||
2800 | $db->queryF(\sprintf('DELETE FROM `%s` WHERE bid = %u', $db->prefix('banner'), $bid)); |
||||||
2801 | } |
||||||
2802 | if ($htmlbanner) { |
||||||
2803 | $bannerobject = $htmlcode; |
||||||
2804 | } else { |
||||||
2805 | $bannerobject = '<div align="center"><a href="' . XOOPS_URL . '/banners.php?op=click&bid=' . $bid . '" target="_blank">'; |
||||||
2806 | if (false !== mb_stripos($imageurl, '.swf')) { |
||||||
2807 | $bannerobject .= '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="https://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0" width="468" height="60">' |
||||||
2808 | . '<param name="movie" value="' |
||||||
2809 | . $imageurl |
||||||
2810 | . '"></param>' |
||||||
2811 | . '<param name="quality" value="high"></param>' |
||||||
2812 | . '<embed src="' |
||||||
2813 | . $imageurl |
||||||
2814 | . '" quality="high" pluginspage="https://www.macromedia.com/shockwave/download/index.cgi?P1_Prod_Version=ShockwaveFlash" type="application/x-shockwave-flash" width="468" height="60">' |
||||||
2815 | . '</embed>' |
||||||
2816 | . '</object>'; |
||||||
2817 | } else { |
||||||
2818 | $bannerobject .= '<img src="' . $imageurl . '" alt="">'; |
||||||
2819 | } |
||||||
2820 | $bannerobject .= '</a></div>'; |
||||||
2821 | } |
||||||
2822 | |||||||
2823 | return $bannerobject; |
||||||
2824 | } |
||||||
2825 | |||||||
2826 | return null; |
||||||
2827 | } |
||||||
2828 | |||||||
2829 | public static function setNoIndexNoFollow() |
||||||
2830 | { |
||||||
2831 | global $xoopsTpl; |
||||||
2832 | if (\is_object($GLOBALS['xoTheme'])) { |
||||||
2833 | $GLOBALS['xoTheme']->addMeta('meta', 'robots', 'noindex,nofollow'); |
||||||
2834 | } else { |
||||||
2835 | $xoopsTpl->assign('xoops_meta_robots', 'noindex,nofollow'); |
||||||
2836 | } |
||||||
2837 | } |
||||||
2838 | |||||||
2839 | /** |
||||||
2840 | * @param $userid |
||||||
2841 | * |
||||||
2842 | * @return string |
||||||
2843 | */ |
||||||
2844 | public static function getLinkedUserNameFromId($userid) |
||||||
2845 | { |
||||||
2846 | $userid = (int)$userid; |
||||||
2847 | if ($userid > 0) { |
||||||
2848 | /** @var \XoopsMemberHandler $memberHandler */ |
||||||
2849 | $memberHandler = \xoops_getHandler('member'); |
||||||
2850 | $user = $memberHandler->getUser($userid); |
||||||
2851 | if (\is_object($user)) { |
||||||
2852 | $linkeduser = '<a href="' . XOOPS_URL . '/userinfo.php?uid=' . $userid . '">' . $user->getVar('uname') . '</a>'; |
||||||
2853 | |||||||
2854 | return $linkeduser; |
||||||
2855 | } |
||||||
2856 | } |
||||||
2857 | |||||||
2858 | return $GLOBALS['xoopsConfig']['anonymous']; |
||||||
2859 | } |
||||||
2860 | |||||||
2861 | /** |
||||||
2862 | * @param $time |
||||||
2863 | * |
||||||
2864 | * @return string |
||||||
2865 | */ |
||||||
2866 | public static function getTimestamp($time) |
||||||
2867 | { |
||||||
2868 | $moduleDirName = \basename(\dirname(__DIR__)); |
||||||
2869 | \xoops_loadLanguage('local', $moduleDirName); |
||||||
2870 | |||||||
2871 | $trans = [ |
||||||
2872 | 'Monday' => \_XOOPSTUBE_MONDAY, |
||||||
2873 | 'Tuesday' => \_XOOPSTUBE_TUESDAY, |
||||||
2874 | 'Wednesday' => \_XOOPSTUBE_WEDNESDAY, |
||||||
2875 | 'Thursday' => \_XOOPSTUBE_THURSDAY, |
||||||
2876 | 'Friday' => \_XOOPSTUBE_FRIDAY, |
||||||
2877 | 'Saturday' => \_XOOPSTUBE_SATURDAY, |
||||||
2878 | 'Sunday' => \_XOOPSTUBE_SUNDAY, |
||||||
2879 | 'Mon' => \_XOOPSTUBE_MON, |
||||||
2880 | 'Tue' => \_XOOPSTUBE_TUE, |
||||||
2881 | 'Wed' => \_XOOPSTUBE_WED, |
||||||
2882 | 'Thu' => \_XOOPSTUBE_THU, |
||||||
2883 | 'Fri' => \_XOOPSTUBE_FRI, |
||||||
2884 | 'Sat' => \_XOOPSTUBE_SAT, |
||||||
2885 | 'Sun' => \_XOOPSTUBE_SUN, |
||||||
2886 | 'January' => \_XOOPSTUBE_JANUARI, |
||||||
2887 | 'February' => \_XOOPSTUBE_FEBRUARI, |
||||||
2888 | 'March' => \_XOOPSTUBE_MARCH, |
||||||
2889 | 'April' => \_XOOPSTUBE_APRIL, |
||||||
2890 | 'May' => \_XOOPSTUBE_MAY, |
||||||
2891 | 'June' => \_XOOPSTUBE_JUNE, |
||||||
2892 | 'July' => \_XOOPSTUBE_JULY, |
||||||
2893 | 'August' => \_XOOPSTUBE_AUGUST, |
||||||
2894 | 'September' => \_XOOPSTUBE_SEPTEMBER, |
||||||
2895 | 'October' => \_XOOPSTUBE_OCTOBER, |
||||||
2896 | 'November' => \_XOOPSTUBE_NOVEMBER, |
||||||
2897 | 'December' => \_XOOPSTUBE_DECEMBER, |
||||||
2898 | 'Jan' => \_XOOPSTUBE_JAN, |
||||||
2899 | 'Feb' => \_XOOPSTUBE_FEB, |
||||||
2900 | 'Mar' => \_XOOPSTUBE_MAR, |
||||||
2901 | 'Apr' => \_XOOPSTUBE_APR, |
||||||
2902 | // 'May' => _XOOPSTUBE_MAY2, |
||||||
2903 | 'Jun' => \_XOOPSTUBE_JUN, |
||||||
2904 | 'Jul' => \_XOOPSTUBE_JUL, |
||||||
2905 | 'Aug' => \_XOOPSTUBE_AUG, |
||||||
2906 | 'Sep' => \_XOOPSTUBE_SEP, |
||||||
2907 | 'Oct' => \_XOOPSTUBE_OCT, |
||||||
2908 | 'Nov' => \_XOOPSTUBE_NOV, |
||||||
2909 | 'Dec' => \_XOOPSTUBE_DEC, |
||||||
2910 | ]; |
||||||
2911 | $timestamp = strtr($time, $trans); |
||||||
2912 | |||||||
2913 | return $timestamp; |
||||||
2914 | } |
||||||
2915 | |||||||
2916 | /** |
||||||
2917 | * Do some basic file checks and stuff. |
||||||
2918 | * Author: Andrew Mills Email: [email protected] |
||||||
2919 | * from amReviews module |
||||||
2920 | */ |
||||||
2921 | public static function fileChecks() |
||||||
2922 | { |
||||||
2923 | echo '<fieldset>'; |
||||||
2924 | echo '<legend style="color: #990000; font-weight: bold;">' . \_AM_XOOPSTUBE_FILECHECKS . '</legend>'; |
||||||
2925 | |||||||
2926 | $dirPhotos = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['catimage']; |
||||||
2927 | $dirVideos = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['videodir']; |
||||||
2928 | $dirScreenshots = XOOPS_ROOT_PATH . '/' . $GLOBALS['xoopsModuleConfig']['videoimgdir']; |
||||||
2929 | |||||||
2930 | if (\file_exists($dirPhotos)) { |
||||||
2931 | if (!\is_writable($dirPhotos)) { |
||||||
2932 | echo '<span style=" color: red; font-weight: bold;">Warning:</span> ' . \_AM_XOOPSTUBE_UNABLE_TO_WRITE . $dirPhotos . '<br>'; |
||||||
2933 | } else { |
||||||
2934 | echo '<span style=" color: green; font-weight: bold;">OK:</span> ' . $dirPhotos . '<br>'; |
||||||
2935 | } |
||||||
2936 | } else { |
||||||
2937 | echo '<span style=" color: red; font-weight: bold;">' . \_AM_XOOPSTUBE_WARNING . '</span> ' . $dirPhotos . ' <span style=" color: red; ">' . \_AM_XOOPSTUBE_NOT_EXISTS . '</span> <br>'; |
||||||
2938 | } |
||||||
2939 | // photothumbdir |
||||||
2940 | if (\file_exists($dirVideos)) { |
||||||
2941 | if (!\is_writable($dirVideos)) { |
||||||
2942 | echo '<span style=" color: red; font-weight: bold;">' . \_AM_XOOPSTUBE_WARNING . '</span> ' . \_AM_XOOPSTUBE_UNABLE_TO_WRITE . $dirVideos . '<br>'; |
||||||
2943 | } else { |
||||||
2944 | echo '<span style=" color: green; font-weight: bold;">OK:</span> ' . $dirVideos . '<br>'; |
||||||
2945 | } |
||||||
2946 | } else { |
||||||
2947 | echo '<span style=" color: red; font-weight: bold;">' . \_AM_XOOPSTUBE_WARNING . '</span> ' . $dirVideos . ' <span style=" color: red; ">' . \_AM_XOOPSTUBE_NOT_EXISTS . '</span> <br>'; |
||||||
2948 | } |
||||||
2949 | // photohighdir |
||||||
2950 | if (\file_exists($dirScreenshots)) { |
||||||
2951 | if (!\is_writable($dirScreenshots)) { |
||||||
2952 | echo '<span style=" color: red; font-weight: bold;">Warning:</span> ' . \_AM_XOOPSTUBE_UNABLE_TO_WRITE . $dirScreenshots . '<br>'; |
||||||
2953 | } else { |
||||||
2954 | echo '<span style=" color: green; font-weight: bold;">OK:</span> ' . $dirScreenshots . '<br>'; |
||||||
2955 | } |
||||||
2956 | } else { |
||||||
2957 | echo '<span style=" color: red; font-weight: bold;">' . \_AM_XOOPSTUBE_WARNING . '</span> ' . $dirScreenshots . ' <span style=" color: red; ">' . \_AM_XOOPSTUBE_NOT_EXISTS . '</span> <br>'; |
||||||
2958 | } |
||||||
2959 | |||||||
2960 | /** |
||||||
2961 | * Some info. |
||||||
2962 | */ |
||||||
2963 | $uploads = \ini_get('file_uploads') ? \_AM_XOOPSTUBE_UPLOAD_ON : \_AM_XOOPSTUBE_UPLOAD_OFF; |
||||||
2964 | echo '<br>'; |
||||||
2965 | echo '<ul>'; |
||||||
2966 | echo '<li>' . \_AM_XOOPSTUBE_UPLOADMAX . '<b>' . \ini_get('upload_max_filesize') . '</b></li>'; |
||||||
2967 | echo '<li>' . \_AM_XOOPSTUBE_POSTMAX . '<b>' . \ini_get('post_max_size') . '</b></li>'; |
||||||
2968 | echo '<li>' . \_AM_XOOPSTUBE_UPLOADS . '<b>' . $uploads . '</b></li>'; |
||||||
2969 | |||||||
2970 | $gdinfo = gd_info(); |
||||||
2971 | if (\function_exists('gd_info')) { |
||||||
2972 | echo '<li>' . \_AM_XOOPSTUBE_GDIMGSPPRT . '<b>' . \_AM_XOOPSTUBE_GDIMGON . '</b></li>'; |
||||||
2973 | echo '<li>' . \_AM_XOOPSTUBE_GDIMGVRSN . '<b>' . $gdinfo['GD Version'] . '</b></li>'; |
||||||
2974 | } else { |
||||||
2975 | echo '<li>' . \_AM_XOOPSTUBE_GDIMGSPPRT . '<b>' . \_AM_XOOPSTUBE_GDIMGOFF . '</b></li>'; |
||||||
2976 | } |
||||||
2977 | echo '</ul>'; |
||||||
2978 | |||||||
2979 | //$inithingy = ini_get_all(); |
||||||
2980 | //print_r($inithingy); |
||||||
2981 | |||||||
2982 | echo '</fieldset>'; |
||||||
2983 | } |
||||||
2984 | |||||||
2985 | /** |
||||||
2986 | * @param $path |
||||||
2987 | * @param int $mode |
||||||
2988 | * @param $fileSource |
||||||
2989 | * @param null $fileTarget |
||||||
2990 | */ |
||||||
2991 | public static function createDirectory($path, $mode, $fileSource, $fileTarget = null) |
||||||
2992 | { |
||||||
2993 | if (!\is_dir($path)) { |
||||||
2994 | if (!\mkdir($path, $mode) && !\is_dir($path)) { |
||||||
2995 | throw new \RuntimeException(\sprintf('Directory "%s" was not created', $path)); |
||||||
2996 | } |
||||||
2997 | file_put_contents($path . '/index.html', '<script>history.go(-1);</script>'); |
||||||
2998 | if (!empty($fileSource) && !empty($fileTarget)) { |
||||||
2999 | @\copy($fileSource, $fileTarget); |
||||||
3000 | } |
||||||
0 ignored issues
–
show
It seems like you do not handle an error condition for
copy() . This can introduce security issues, and is generally not recommended.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
If you suppress an error, we recommend checking for the error condition explicitly: // For example instead of
@mkdir($dir);
// Better use
if (@mkdir($dir) === false) {
throw new \RuntimeException('The directory '.$dir.' could not be created.');
}
![]() |
|||||||
3001 | } |
||||||
3002 | \chmod($path, $mode); |
||||||
3003 | } |
||||||
3004 | |||||||
3005 | /** |
||||||
3006 | * @return string |
||||||
3007 | */ |
||||||
3008 | public static function getLetters() |
||||||
3009 | { |
||||||
3010 | global $xoopsModule; |
||||||
3011 | |||||||
3012 | $letterchoice = '<div>' . \_MD_XOOPSTUBE_BROWSETOTOPIC . '</div>'; |
||||||
3013 | $alphabet = \getXtubeAlphabet(); |
||||||
3014 | $num = \count($alphabet) - 1; |
||||||
3015 | $counter = 0; |
||||||
3016 | $distinctDbLetters_arr = []; |
||||||
3017 | $sql = 'SELECT DISTINCT (UPPER(LEFT(title, 1))) AS letter FROM ' . $GLOBALS['xoopsDB']->prefix('xoopstube_videos WHERE expired = 0 AND offline = 0'); |
||||||
3018 | $result = $GLOBALS['xoopsDB']->query($sql); |
||||||
3019 | if ($result) { |
||||||
3020 | while (false !== ($row = $GLOBALS['xoopsDB']->fetchArray($result))) { |
||||||
3021 | $distinctDbLetters_arr[] = $row['letter']; |
||||||
3022 | } |
||||||
3023 | } |
||||||
3024 | unset($sql); |
||||||
3025 | |||||||
3026 | // while (list(, $ltr) = each($alphabet)) { |
||||||
3027 | foreach ($alphabet as $key => $ltr) { |
||||||
3028 | if (\in_array($ltr, $distinctDbLetters_arr)) { |
||||||
3029 | $letterchoice .= '<a class="xoopstube_letters xoopstube_letters_green" href="'; |
||||||
3030 | } else { |
||||||
3031 | $letterchoice .= '<a class="xoopstube_letters" href="'; |
||||||
3032 | } |
||||||
3033 | $letterchoice .= XOOPS_URL . '/modules/' . $xoopsModule->getVar('dirname') . '/viewcat.php?letter=' . $ltr . '">' . $ltr . '</a>'; |
||||||
3034 | if ($counter == \round($num / 2)) { |
||||||
3035 | $letterchoice .= '<br>'; |
||||||
3036 | } elseif ($counter !== $num) { |
||||||
3037 | $letterchoice .= ' '; |
||||||
3038 | } |
||||||
3039 | ++$counter; |
||||||
3040 | } |
||||||
3041 | |||||||
3042 | return $letterchoice; |
||||||
3043 | } |
||||||
3044 | |||||||
3045 | /** |
||||||
3046 | * @return mixed|string |
||||||
3047 | */ |
||||||
3048 | public static function getLettersChoice() |
||||||
3049 | { |
||||||
3050 | global $xoopsModule; |
||||||
3051 | |||||||
3052 | $moduleDirName = $xoopsModule->getVar('dirname'); |
||||||
3053 | // require_once XOOPS_ROOT_PATH . "/modules/$moduleDirName/class/$moduleDirName.php"; |
||||||
3054 | $helper = Helper::getInstance(); |
||||||
3055 | |||||||
3056 | $a = $helper->getHandler('Videos'); |
||||||
3057 | $b = $a->getActiveCriteria(); |
||||||
3058 | $moduleDirName = \basename(\dirname(__DIR__)); |
||||||
3059 | |||||||
3060 | $criteria = $helper->getHandler('Videos')->getActiveCriteria(); |
||||||
3061 | $criteria->setGroupby('UPPER(LEFT(title,1))'); |
||||||
3062 | $countsByLetters = $helper->getHandler($moduleDirName)->getCounts($criteria); |
||||||
3063 | // Fill alphabet array |
||||||
0 ignored issues
–
show
The method
getCounts() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
3064 | $alphabet = \getXtubeAlphabet(); |
||||||
3065 | $alphabet_array = []; |
||||||
3066 | foreach ($alphabet as $letter) { |
||||||
3067 | $letter_array = []; |
||||||
3068 | if (isset($countsByLetters[$letter])) { |
||||||
3069 | $letter_array['letter'] = $letter; |
||||||
3070 | $letter_array['count'] = $countsByLetters[$letter]; |
||||||
3071 | $letter_array['url'] = '' . XOOPS_URL . "/modules/$moduleDirName/viewcat.php?letter={$letter}"; |
||||||
3072 | } else { |
||||||
3073 | $letter_array['letter'] = $letter; |
||||||
3074 | $letter_array['count'] = 0; |
||||||
3075 | $letter_array['url'] = ''; |
||||||
3076 | } |
||||||
3077 | $alphabet_array[$letter] = $letter_array; |
||||||
3078 | unset($letter_array); |
||||||
3079 | } |
||||||
3080 | // Render output |
||||||
3081 | if (!isset($GLOBALS['xoTheme']) || !\is_object($GLOBALS['xoTheme'])) { |
||||||
3082 | require_once $GLOBALS['xoops']->path('class/theme.php'); |
||||||
3083 | $GLOBALS['xoTheme'] = new \xos_opal_Theme(); |
||||||
3084 | } |
||||||
3085 | require_once $GLOBALS['xoops']->path('class/template.php'); |
||||||
3086 | $letterschoiceTpl = new \XoopsTpl(); |
||||||
3087 | $letterschoiceTpl->caching = 0; // Disable cache |
||||||
3088 | $letterschoiceTpl->assign('alphabet', $alphabet_array); |
||||||
3089 | $html = $letterschoiceTpl->fetch('db:' . $helper->getModule()->dirname() . '_common_letterschoice.tpl'); |
||||||
3090 | unset($letterschoiceTpl); |
||||||
3091 | |||||||
3092 | return $html; |
||||||
3093 | } |
||||||
3094 | |||||||
3095 | /** |
||||||
3096 | * Recursively sort categories by level and weight |
||||||
3097 | * |
||||||
3098 | * @param int $pid |
||||||
3099 | * @param int $level |
||||||
3100 | * |
||||||
3101 | * @return array array of arrays: 'pid', 'cid', 'level', 'category' as array |
||||||
3102 | * |
||||||
3103 | * @access public |
||||||
3104 | * @author luciorota |
||||||
3105 | */ |
||||||
3106 | public static function sortCategories($pid = 0, $level = 0) |
||||||
3107 | { |
||||||
3108 | $helper = Helper::getInstance(); |
||||||
3109 | |||||||
3110 | $sorted = []; |
||||||
3111 | $criteria = new \CriteriaCompo(); |
||||||
3112 | $criteria->add(new \Criteria('pid', $pid)); |
||||||
3113 | $criteria->setSort('weight'); |
||||||
3114 | $criteria->setOrder('ASC'); |
||||||
3115 | $subCategoryObjs = $helper->getHandler('Category')->getObjects($criteria); |
||||||
3116 | if (\count($subCategoryObjs) > 0) { |
||||||
0 ignored issues
–
show
The method
getObjects() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of said class. However, the method does not exist in XoopsRankHandler or XoUserHandler . Are you sure you never get one of those?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
3117 | ++$level; |
||||||
3118 | foreach ($subCategoryObjs as $subCategoryObj) { |
||||||
3119 | $pid = $subCategoryObj->getVar('pid'); |
||||||
3120 | $cid = $subCategoryObj->getVar('cid'); |
||||||
3121 | $sorted[] = ['pid' => $pid, 'cid' => $cid, 'level' => $level, 'category' => $subCategoryObj->toArray()]; |
||||||
3122 | if (false !== ($subSorted = self::sortCategories($cid, $level))) { |
||||||
3123 | $sorted = \array_merge($sorted, $subSorted); |
||||||
3124 | } |
||||||
3125 | } |
||||||
3126 | } |
||||||
3127 | |||||||
3128 | return $sorted; |
||||||
3129 | } |
||||||
3130 | |||||||
3131 | /** |
||||||
3132 | * Create download by letter choice bar/menu |
||||||
3133 | * updated starting from this idea https://xoops.org/modules/news/article.php?storyid=6497 |
||||||
3134 | * |
||||||
3135 | * @return string html |
||||||
3136 | * |
||||||
3137 | * @access public |
||||||
3138 | * @author luciorota |
||||||
3139 | */ |
||||||
3140 | // public static function lettersChoice() |
||||||
3141 | // { |
||||||
3142 | // /** @var Helper $helper */ |
||||||
3143 | // $helper = Helper::getInstance(); |
||||||
3144 | // |
||||||
3145 | // $criteria = $helper->getHandler('Videos')->getActiveCriteria(); |
||||||
3146 | // $criteria->setGroupby('UPPER(LEFT(title,1))'); |
||||||
3147 | // $countsByLetters = $helper->getHandler('Videos')->getCounts($criteria); |
||||||
3148 | // // Fill alphabet array |
||||||
3149 | // $alphabet = getLocalAlphabet(); |
||||||
3150 | // $alphabetArray = []; |
||||||
3151 | // foreach ($alphabet as $letter) { |
||||||
3152 | // $letter_array = []; |
||||||
3153 | // if (isset($countsByLetters[$letter])) { |
||||||
3154 | // $letter_array['letter'] = $letter; |
||||||
3155 | // $letter_array['count'] = $countsByLetters[$letter]; |
||||||
3156 | // $letter_array['url'] = XOOPS_URL . "/modules/{$helper->getModule()->dirname()}/viewcat.php?list={$letter}"; |
||||||
3157 | // } else { |
||||||
3158 | // $letter_array['letter'] = $letter; |
||||||
3159 | // $letter_array['count'] = 0; |
||||||
3160 | // $letter_array['url'] = ''; |
||||||
3161 | // } |
||||||
3162 | // $alphabetArray[$letter] = $letter_array; |
||||||
3163 | // unset($letter_array); |
||||||
3164 | // } |
||||||
3165 | // // Render output |
||||||
3166 | // if (!isset($GLOBALS['xoTheme']) || !is_object($GLOBALS['xoTheme'])) { |
||||||
3167 | // require_once $GLOBALS['xoops']->path('/class/theme.php'); |
||||||
3168 | // $GLOBALS['xoTheme'] = new \xos_opal_Theme(); |
||||||
3169 | // } |
||||||
3170 | // require_once $GLOBALS['xoops']->path('class/template.php'); |
||||||
3171 | // $letterschoiceTpl = new \XoopsTpl(); |
||||||
3172 | // $letterschoiceTpl->caching = false; // Disable cache |
||||||
3173 | // $letterschoiceTpl->assign('alphabet', $alphabetArray); |
||||||
3174 | // $html = $letterschoiceTpl->fetch("db:{$helper->getModule()->dirname()}_common_letterschoice.tpl"); |
||||||
3175 | // unset($letterschoiceTpl); |
||||||
3176 | // |
||||||
3177 | // return $html; |
||||||
3178 | // } |
||||||
3179 | |||||||
3180 | //=============== from WF-Downloads ====================================== |
||||||
3181 | |||||||
3182 | /** |
||||||
3183 | * @return bool |
||||||
3184 | */ |
||||||
3185 | public static function isUserAdmin() |
||||||
3186 | { |
||||||
3187 | $helper = Helper::getInstance(); |
||||||
3188 | |||||||
3189 | static $xtubeIsAdmin; |
||||||
3190 | |||||||
3191 | if (isset($xtubeIsAdmin)) { |
||||||
3192 | return $xtubeIsAdmin; |
||||||
3193 | } |
||||||
3194 | |||||||
3195 | if (!$GLOBALS['xoopsUser']) { |
||||||
3196 | $xtubeIsAdmin = false; |
||||||
3197 | } else { |
||||||
3198 | $xtubeIsAdmin = $GLOBALS['xoopsUser']->isAdmin($helper->getModule()->getVar('mid')); |
||||||
3199 | } |
||||||
3200 | |||||||
3201 | return $xtubeIsAdmin; |
||||||
3202 | } |
||||||
3203 | |||||||
3204 | //from Lexikon |
||||||
3205 | |||||||
3206 | /** |
||||||
3207 | * @return int |
||||||
3208 | */ |
||||||
3209 | public static function countCats() |
||||||
3210 | { |
||||||
3211 | global $xoopsUser, $xoopsModule; |
||||||
3212 | $grouppermHandler = \xoops_getHandler('groupperm'); |
||||||
3213 | $groups = \is_object($xoopsUser) ? $xoopsUser->getGroups() : XOOPS_GROUP_ANONYMOUS; |
||||||
3214 | $totalcats = $grouppermHandler->getItemIds('lexikon_view', $groups, $xoopsModule->getVar('mid')); |
||||||
3215 | |||||||
0 ignored issues
–
show
The method
getItemIds() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsGroupPermHandler or XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
3216 | return \count($totalcats); |
||||||
3217 | } |
||||||
3218 | |||||||
3219 | /** |
||||||
3220 | * @return mixed |
||||||
3221 | */ |
||||||
3222 | public static function countWords() |
||||||
3223 | { |
||||||
3224 | global $xoopsUser, $xoopsDB; |
||||||
3225 | $grouppermHandler = \xoops_getHandler('groupperm'); |
||||||
3226 | $groups = \is_object($xoopsUser) ? $xoopsUser->getGroups() : XOOPS_GROUP_ANONYMOUS; |
||||||
3227 | /** @var \XoopsModuleHandler $moduleHandler */ |
||||||
3228 | $moduleHandler = \xoops_getHandler('module'); |
||||||
3229 | $module = $moduleHandler->getByDirname('lexikon'); |
||||||
3230 | $module_id = $module->getVar('mid'); |
||||||
3231 | $allowed_cats = $grouppermHandler->getItemIds('lexikon_view', $groups, $module_id); |
||||||
3232 | $catids = \implode(',', $allowed_cats); |
||||||
3233 | $catperms = " AND categoryID IN ($catids) "; |
||||||
3234 | |||||||
3235 | $pubwords = $xoopsDB->query('SELECT * FROM ' . $xoopsDB->prefix('lxentries') . " WHERE submit = '0' AND offline ='0' AND request = '0' " . $catperms . ' '); |
||||||
3236 | $publishedwords = $xoopsDB->getRowsNum($pubwords); |
||||||
3237 | |||||||
3238 | return $publishedwords; |
||||||
3239 | } |
||||||
3240 | |||||||
3241 | /** |
||||||
3242 | * @return array |
||||||
3243 | */ |
||||||
3244 | public static function getCategoryArray() |
||||||
3245 | { |
||||||
3246 | global $xoopsDB, $xoopsUser, $xoopsModule; |
||||||
3247 | $helper = Helper::getInstance(); |
||||||
3248 | $myts = \MyTextSanitizer::getInstance(); |
||||||
3249 | $groups = \is_object($xoopsUser) ? $xoopsUser->getGroups() : XOOPS_GROUP_ANONYMOUS; |
||||||
3250 | $grouppermHandler = \xoops_getHandler('groupperm'); |
||||||
3251 | $block0 = []; |
||||||
3252 | $count = 1; |
||||||
3253 | $resultcat = $xoopsDB->query('SELECT categoryID, name, total, logourl FROM ' . $xoopsDB->prefix('lxcategories') . ' ORDER BY weight ASC'); |
||||||
3254 | while (list($catID, $name, $total, $logourl) = $xoopsDB->fetchRow($resultcat)) { |
||||||
3255 | if ($grouppermHandler->checkRight('lexikon_view', $catID, $groups, $xoopsModule->getVar('mid'))) { |
||||||
3256 | $catlinks = []; |
||||||
0 ignored issues
–
show
The method
checkRight() does not exist on XoopsObjectHandler . It seems like you code against a sub-type of XoopsObjectHandler such as XoopsGroupPermHandler or XoopsPersistableObjectHandler .
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
![]() |
|||||||
3257 | ++$count; |
||||||
3258 | if ($logourl && 'https://' !== $logourl) { |
||||||
3259 | $logourl = \htmlspecialchars($logourl, \ENT_QUOTES | \ENT_HTML5); |
||||||
3260 | } else { |
||||||
3261 | $logourl = ''; |
||||||
3262 | } |
||||||
3263 | $xoopsModule = \XoopsModule::getByDirname('lexikon'); |
||||||
3264 | $catlinks['id'] = (int)$catID; |
||||||
3265 | $catlinks['total'] = (int)$total; |
||||||
3266 | $catlinks['linktext'] = \htmlspecialchars($name, \ENT_QUOTES | \ENT_HTML5); |
||||||
3267 | $catlinks['image'] = $logourl; |
||||||
3268 | $catlinks['count'] = $count; |
||||||
3269 | |||||||
3270 | $block0['categories'][] = $catlinks; |
||||||
3271 | } |
||||||
3272 | } |
||||||
3273 | |||||||
3274 | return $block0; |
||||||
3275 | } |
||||||
3276 | |||||||
3277 | /** |
||||||
3278 | * @return array |
||||||
3279 | */ |
||||||
3280 | public static function getAlphaArray() |
||||||
3281 | { |
||||||
3282 | global $xoopsUser, $xoopsDB, $xoopsModule; |
||||||
3283 | $grouppermHandler = \xoops_getHandler('groupperm'); |
||||||
3284 | $groups = \is_object($xoopsUser) ? $xoopsUser->getGroups() : XOOPS_GROUP_ANONYMOUS; |
||||||
3285 | /** @var \XoopsModuleHandler $moduleHandler */ |
||||||
3286 | $moduleHandler = \xoops_getHandler('module'); |
||||||
3287 | $module = $moduleHandler->getByDirname('lexikon'); |
||||||
3288 | $module_id = $module->getVar('mid'); |
||||||
3289 | $allowed_cats = $grouppermHandler->getItemIds('lexikon_view', $groups, $module_id); |
||||||
3290 | $catids = \implode(',', $allowed_cats); |
||||||
3291 | $catperms = " AND categoryID IN ($catids) "; |
||||||
3292 | $alpha = []; |
||||||
3293 | /** |
||||||
3294 | * @param $a |
||||||
3295 | * @return null|string|string[] |
||||||
3296 | */ |
||||||
3297 | function unichr($a) |
||||||
3298 | { |
||||||
3299 | return mb_convert_encoding(\pack('N', $a), mb_internal_encoding(), 'UCS-4BE'); |
||||||
3300 | } |
||||||
3301 | |||||||
3302 | for ($a = 48; $a < (48 + 10); ++$a) { |
||||||
3303 | $letterlinks = []; |
||||||
3304 | $initial = unichr($a); |
||||||
3305 | $sql = $xoopsDB->query('SELECT entryID FROM ' . $xoopsDB->prefix('lxentries') . " WHERE init = '$initial' AND submit = '0' AND offline ='0' AND request = '0' " . $catperms . ' '); |
||||||
3306 | $howmany = $xoopsDB->getRowsNum($sql); |
||||||
3307 | $letterlinks['total'] = $howmany; |
||||||
3308 | $letterlinks['id'] = unichr($a); |
||||||
3309 | $letterlinks['linktext'] = unichr($a); |
||||||
3310 | |||||||
3311 | $alpha['initial'][] = $letterlinks; |
||||||
3312 | } |
||||||
3313 | for ($a = 65; $a < (65 + 26); ++$a) { |
||||||
3314 | $letterlinks = []; |
||||||
3315 | $initial = unichr($a); |
||||||
3316 | $sql = $xoopsDB->query('SELECT entryID FROM ' . $xoopsDB->prefix('lxentries') . " WHERE init = '$initial' AND submit = '0' AND offline ='0' AND request = '0' " . $catperms . ' '); |
||||||
3317 | $howmany = $xoopsDB->getRowsNum($sql); |
||||||
3318 | $letterlinks['total'] = $howmany; |
||||||
3319 | $letterlinks['id'] = unichr($a); |
||||||
3320 | $letterlinks['linktext'] = unichr($a); |
||||||
3321 | |||||||
3322 | $alpha['initial'][] = $letterlinks; |
||||||
3323 | } |
||||||
3324 | /*for ($a = 1040; $a < (1040 + 32); ++$a) { |
||||||
3325 | $letterlinks = []; |
||||||
3326 | $initial = unichr($a); |
||||||
3327 | $sql = $xoopsDB->query('SELECT entryID FROM ' |
||||||
3328 | . $xoopsDB->prefix('lxentries') |
||||||
3329 | . " WHERE init = '$initial' AND submit = '0' AND offline ='0' AND request = '0' " |
||||||
3330 | . $catperms |
||||||
3331 | . ''); |
||||||
3332 | $howmany = $xoopsDB->getRowsNum($sql); |
||||||
3333 | $letterlinks['total'] = $howmany; |
||||||
3334 | $letterlinks['id'] = unichr($a); |
||||||
3335 | $letterlinks['linktext'] = unichr($a); |
||||||
3336 | $alpha['initial'][] = $letterlinks; |
||||||
3337 | }*/ |
||||||
3338 | |||||||
3339 | return $alpha; |
||||||
3340 | } |
||||||
3341 | |||||||
3342 | /** |
||||||
3343 | * chr() with unicode support |
||||||
3344 | * I found this on this site https://en.php.net/chr |
||||||
3345 | * don't take credit for this. |
||||||
3346 | * @param $initials |
||||||
3347 | * @return string |
||||||
3348 | */ |
||||||
3349 | public static function getUchr($initials) |
||||||
3350 | { |
||||||
3351 | if (\is_scalar($initials)) { |
||||||
3352 | $initials = \func_get_args(); |
||||||
3353 | } |
||||||
3354 | $str = ''; |
||||||
3355 | foreach ($initials as $init) { |
||||||
3356 | $str .= \html_entity_decode('&#' . $init . ';', \ENT_NOQUOTES, 'UTF-8'); |
||||||
3357 | } |
||||||
3358 | |||||||
3359 | return $str; |
||||||
3360 | } |
||||||
3361 | } |
||||||
3362 |
Let?s assume that you have a directory layout like this:
and let?s assume the following content of
Bar.php
:If both files
OtherDir/Foo.php
andSomeDir/Foo.php
are loaded in the same runtime, you will see a PHP error such as the following:PHP Fatal error: Cannot use SomeDir\Foo as Foo because the name is already in use in OtherDir/Foo.php
However, as
OtherDir/Foo.php
does not necessarily have to be loaded and the error is only triggered if it is loaded beforeOtherDir/Bar.php
, this problem might go unnoticed for a while. In order to prevent this error from surfacing, you must import the namespace with a different alias: