noodles/_public.php

247 lines
6.8 KiB
PHP
Raw Normal View History

2021-09-08 22:53:13 +00:00
<?php
/**
2021-09-08 23:05:05 +00:00
* @brief noodles, a plugin for Dotclear 2
*
* @package Dotclear
2021-09-08 23:05:05 +00:00
* @subpackage Plugin
*
2021-09-08 23:05:05 +00:00
* @author Jean-Christian Denis and contributors
*
* @copyright Jean-Christian Denis
* @copyright GPL-2.0 https://www.gnu.org/licenses/gpl-2.0.html
*/
2021-09-09 07:12:31 +00:00
if (!defined('DC_RC_PATH')) {
return null;
}
2021-09-08 22:53:13 +00:00
2021-09-09 07:12:31 +00:00
if (!$core->blog->settings->noodles->noodles_active) {
return null;
}
2021-09-08 22:53:13 +00:00
2021-09-09 07:12:31 +00:00
include dirname(__FILE__) . '/inc/_default_noodles.php';
require_once dirname(__FILE__) . '/inc/_noodles_functions.php';
2021-09-08 22:53:13 +00:00
2021-09-09 07:12:31 +00:00
$core->addBehavior('publicHeadContent', ['publicNoodles', 'publicHeadContent']);
2021-09-08 22:53:13 +00:00
2021-09-09 07:12:31 +00:00
$core->tpl->setPath($core->tpl->getPath(), dirname(__FILE__) . '/default-templates');
2021-09-08 22:53:13 +00:00
global $__noodles;
$__noodles = noodles::decode($core->blog->settings->noodles->noodles_object);
2021-09-09 07:12:31 +00:00
if ($__noodles->isEmpty()) {
$__noodles = $__default_noodles;
2021-09-09 07:12:31 +00:00
}
2021-09-08 22:53:13 +00:00
//$GLOBALS['__noodles'] =& $__noodles;
2021-11-01 09:28:22 +00:00
foreach ($__noodles->noodles() as $noodle) {
2021-09-09 07:12:31 +00:00
if ($noodle->active && $noodle->hasPhpCallback()) {
$noodle->phpCallback($core);
2021-09-09 07:12:31 +00:00
}
2021-09-08 22:53:13 +00:00
}
class publicNoodles
{
public static function publicHeadContent($core)
{
2021-10-30 19:53:30 +00:00
echo
dcUtils::cssLoad($core->blog->url . $core->url->getURLFor('noodlescss')) .
2021-11-01 09:28:22 +00:00
dcUtils::jsLoad($core->blog->url . $core->url->getBase('noodlesmodule') . '/js/jquery.noodles.js') .
2021-10-30 19:53:30 +00:00
dcUtils::jsLoad($core->blog->url . $core->url->getURLFor('noodlesjs'));
}
}
class urlNoodles extends dcUrlHandlers
{
public static function css($args)
{
global $core, $__noodles;
2021-10-30 19:53:30 +00:00
$css = '';
2021-11-01 09:28:22 +00:00
foreach ($__noodles->noodles() as $noodle) {
2021-09-09 07:12:31 +00:00
if (!$noodle->active || !$noodle->hasJsCallback()) {
continue;
}
$css .= '.noodles-' . $noodle->id() . '{' . $noodle->css . '}' . "\n";
}
2021-10-30 19:53:30 +00:00
header('Content-Type: text/css; charset=UTF-8');
echo $css;
exit;
}
public static function js($args)
{
global $core, $__noodles;
$targets = [];
2021-11-01 09:28:22 +00:00
foreach ($__noodles->noodles() as $noodle) {
2021-10-30 19:53:30 +00:00
if (!$noodle->active || !$noodle->hasJsCallback()) {
continue;
}
2021-11-01 09:28:22 +00:00
$targets[] = '$(\'' . html::escapeJS($noodle->target) . '\').noodles({' .
2021-10-30 19:53:30 +00:00
' imgId:\'' . html::escapeJS($noodle->id()) . '\',' .
' imgPlace:\'' . html::escapeJS($noodle->place) . '\'' .
'});';
2021-09-09 07:12:31 +00:00
}
2021-10-30 19:53:30 +00:00
header('Content-Type: text/javascript; charset=UTF-8');
2021-11-01 09:28:22 +00:00
echo
2021-10-30 19:53:30 +00:00
"\$(function(){if(!document.getElementById){return;} \n" .
"\$.fn.noodles.defaults.service_url = '" . html::escapeJS($core->blog->url . $core->url->getBase('noodlesservice') . '/') . "'; \n" .
"\$.fn.noodles.defaults.service_func = '" . html::escapeJS('getNoodle') . "'; \n" .
implode("\n", $targets) .
"})\n";
2021-09-08 22:53:13 +00:00
2021-10-30 19:53:30 +00:00
exit;
}
public static function service($args)
{
global $core;
header('Content-Type: text/xml; charset=UTF-8');
$rsp = new xmlTag('rsp');
$i = !empty($_POST['noodleId']) ? $_POST['noodleId'] : null;
$c = !empty($_POST['noodleContent']) ? $_POST['noodleContent'] : null;
2021-09-09 07:12:31 +00:00
if (!$core->blog->settings->noodles->noodles_active) {
$rsp->status = 'failed';
$rsp->message(__('noodles is disabled on this blog'));
echo $rsp->toXML(1);
2021-11-01 09:28:22 +00:00
return false;
}
2021-09-09 07:12:31 +00:00
if ($i === null || $c === null) {
$rsp->status = 'failed';
$rsp->message(__('noodles failed because of missing informations'));
echo $rsp->toXML(1);
2021-11-01 09:28:22 +00:00
return false;
}
2021-09-09 07:12:31 +00:00
try {
$__noodles = noodles::decode($core->blog->settings->noodles->noodles_object);
2021-09-09 07:12:31 +00:00
if ($__noodles->isEmpty()) {
$__noodles = $GLOBALS['__default_noodles'];
}
2021-11-01 09:28:22 +00:00
} catch (Excetpion $e) {
$rsp->status = 'failed';
$rsp->message(__('Failed to load default noodles'));
echo $rsp->toXML(1);
2021-11-01 09:28:22 +00:00
return false;
}
2021-09-09 07:12:31 +00:00
if (!$__noodles->exists($i)) {
$rsp->status = 'failed';
$rsp->message(__('Failed to load noodle'));
echo $rsp->toXML(1);
2021-11-01 09:28:22 +00:00
return false;
}
$m = $__noodles->get($i)->jsCallback($__noodles->get($i), $c);
$s = $__noodles->get($i)->size;
$r = $__noodles->get($i)->rating;
2021-11-01 09:28:22 +00:00
$d = $core->blog->settings->noodles->noodles_image ?
2021-09-09 07:12:31 +00:00
urlencode(noodlesLibImagePath::getUrl($core, 'noodles')) : '';
2021-10-30 20:42:09 +00:00
$u = $core->blog->settings->noodles->noodles_api;
if (empty($u)) {
$u = 'http://www.gravatar.com/';
}
2021-09-09 07:12:31 +00:00
if (!$m) {
$m = 'nobody@nowhere.tld';
}
if (!$s) {
$s = 32;
}
if (!$r) {
$r = 'g';
}
2021-11-01 09:28:22 +00:00
$m = md5(strtolower(trim($m)));
$im = new xmlTag('noodle');
$im->size = $s;
2021-11-01 09:28:22 +00:00
$im->src = sprintf('%savatar/%s?s=%s&amp;r=%s&amp;d=%s', $u, $m, $s, $r, $d);
$rsp->insertNode($im);
$rsp->status = 'ok';
echo $rsp->toXML(1);
exit;
}
public static function noodles($args)
{
global $core;
2021-09-09 07:12:31 +00:00
if (!$core->blog->settings->noodles->noodles_active) {
self::p404();
2021-11-01 09:28:22 +00:00
return;
}
2021-09-09 07:12:31 +00:00
if (!preg_match('#^(.*?)$#', $args, $m)) {
self::p404();
2021-11-01 09:28:22 +00:00
return;
}
$f = $m[1];
2021-09-09 07:12:31 +00:00
if (!($f = self::searchTplFiles($f))) {
self::p404();
2021-11-01 09:28:22 +00:00
return;
}
2021-09-09 07:12:31 +00:00
$allowed_types = ['png', 'jpg', 'jpeg', 'gif', 'css', 'js', 'swf'];
if (!in_array(files::getExtension($f), $allowed_types)) {
self::p404();
2021-11-01 09:28:22 +00:00
return;
}
$type = files::getMimeType($f);
2021-09-09 07:12:31 +00:00
header('Content-Type: ' . $type . '; charset=UTF-8');
header('Content-Length: ' . filesize($f));
2021-11-01 09:28:22 +00:00
if ($type != 'text/css' || $core->blog->settings->system->url_scan == 'path_info') {
readfile($f);
2021-09-09 07:12:31 +00:00
} else {
echo preg_replace(
2021-11-01 09:28:22 +00:00
'#url\((?!(http:)|/)#',
'url(' . $core->blog->url . $core->url->getBase('noodlesmodule') . '/',
2021-09-09 07:12:31 +00:00
file_get_contents($f)
);
}
exit;
}
# Search noodles files like JS, CSS in default-templates subdirectories
private static function searchTplFiles($file)
{
2021-11-01 09:28:22 +00:00
if (strstr($file, '..') !== false) {
return false;
}
$paths = $GLOBALS['core']->tpl->getPath();
2021-11-01 09:28:22 +00:00
foreach ($paths as $path) {
if (preg_match('/tpl(\/|)$/', $path)) {
2021-09-09 07:12:31 +00:00
$path = path::real($path . '/..');
}
2021-09-09 07:12:31 +00:00
if (file_exists($path . '/' . $file)) {
return $path . '/' . $file;
}
}
2021-11-01 09:28:22 +00:00
return false;
}
}