mirror of
https://github.com/e107inc/e107.git
synced 2025-01-18 05:09:05 +01:00
117 lines
2.4 KiB
PHP
117 lines
2.4 KiB
PHP
<?php
|
|
/**
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2016 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
*/
|
|
|
|
$_E107['debug'] = false;
|
|
$_E107['no_forceuserupdate'] = true;
|
|
$_E107['no_menus'] = true;
|
|
$_E107['allow_guest'] = false; // allow crons to run while in members-only mode.
|
|
$_E107['no_maintenance'] = true;
|
|
// error_reporting(0); // suppress all errors
|
|
require_once("../../class2.php");
|
|
|
|
|
|
class e107InlineEdit
|
|
{
|
|
|
|
function __construct()
|
|
{
|
|
|
|
$token = e107::getParser()->filter($_POST['token']);
|
|
|
|
$perm = (string) $_SESSION['editable'][$token]['perm'];
|
|
|
|
if(!ADMIN || !e_AJAX_REQUEST || !isset($_SESSION['editable'][$token]) || !getperms($perm))
|
|
{
|
|
$ret['msg'] = "Access Denied";
|
|
$ret['status'] = 'error';
|
|
echo json_encode($ret);
|
|
return false;
|
|
|
|
}
|
|
|
|
$keys = array('sc','id','token');
|
|
foreach($keys as $k)
|
|
{
|
|
if(empty($_POST[$k])){ return; }
|
|
}
|
|
|
|
// unset($_SESSION['editable'][$token]);
|
|
$shortcode = e107::getParser()->filter($_POST['sc']);
|
|
|
|
$ret = array();
|
|
$id = intval($_POST['id']);
|
|
$table = $_SESSION['editable'][$token]['table'];
|
|
$field = $_SESSION['editable'][$token]['shortcodes'][$shortcode]['field'];
|
|
$pid = $_SESSION['editable'][$token]['pid'];
|
|
$type = $_SESSION['editable'][$token]['shortcodes'][$shortcode]['type'];
|
|
|
|
|
|
if(empty($field) || empty($pid) || empty($table))
|
|
{
|
|
$ret['msg'] = "Missing Data";
|
|
$ret['status'] = 'error';
|
|
echo json_encode($ret);
|
|
return false;
|
|
}
|
|
|
|
|
|
$content = e107::getParser()->toDB($_POST['content']);
|
|
|
|
$srch = array("<!-- bbcode-html-start -->","<!-- bbcode-html-end -->","[html]","[/html]");
|
|
$content = str_replace($srch,'',$content);
|
|
$content = trim($content);
|
|
|
|
if($type == 'html')
|
|
{
|
|
$content = '[html]'.$content.'[/html]';
|
|
}
|
|
else
|
|
{
|
|
$content = strip_tags($content);
|
|
}
|
|
|
|
$update = array(
|
|
$field => $content,
|
|
'WHERE' => $pid ." = ".$id . " LIMIT 1"
|
|
);
|
|
|
|
// print_r($table);
|
|
// print_r($update);
|
|
|
|
if(e107::getDb()->update($table, $update) !== false)
|
|
{
|
|
$ret['msg'] = "Saved"; // LAN_UPDATED; or LAN_SAVED
|
|
$ret['status'] = 'ok';
|
|
}
|
|
else //FIXME only display error when query fails..
|
|
{
|
|
$ret['msg'] = "Saving Failed"; // LAN_UPDATED_FAILED;
|
|
$ret['status'] = 'error';
|
|
return false;
|
|
}
|
|
|
|
|
|
echo json_encode($ret);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
new e107InlineEdit;
|
|
|
|
|
|
exit;
|
|
|