function event_ExecuteEditor(&$data) { global $lang, $manager; if ($data['sheet'] == 'background') { if ($_SERVER['REQUEST_METHOD'] == 'POST') { $res = sql::query("\r\n\t\t\t\t\t\tREPLACE INTO \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_background\r\n\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "', \r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\timage='" . addslashes($_REQUEST['image']) . "', \r\n\t\t\t\t\t\t\tmodified=NOW()\r\n\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/background?revision=" . $data['params']['revision']); exit; } $res = sql::query("\r\n\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t* \r\n\t\t\t\t\tFROM \r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_background\r\n\t\t\t\t\tWHERE \r\n\t\t\t\t\t\tid='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t"); if ($row = sql::fetch_array($res)) { $image = $row['image']; } else { $image = ''; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set('id', $data['params']['id']); $tpl->set('revision', $data['params']['revision']); $tpl->set('image', $image); $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerJavascript('/core/assets/javascript/modaldialog.js'); $data['page']->assets->registerCSS($this->localAsset('editor.css')); } }
function event_ExecuteEditor(&$data) { global $lang, $manager, $user; if (isset($manager->types[$data['type']]['content']['story']) && $data['sheet'] == 'contents') { // Retrieve story $res = sql::query("\n\t\t\t\t\tSELECT \n\t\t\t\t\t\t*\n\t\t\t\t\tFROM \n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_story \n\t\t\t\t\tWHERE \n\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "' AND\n\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "'\n\t\t\t\t"); if ($row = sql::fetch_array($res, MYSQL_ASSOC)) { $story = $row; } else { $story = array('text' => ''); } if ($_SERVER['REQUEST_METHOD'] == 'POST') { $_POST['text'] = filter::images($_POST['text']); $_POST['text'] = filter::html($_POST['text']); $res = sql::query("\n\t\t\t\t\t\tREPLACE INTO \n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_story \n\t\t\t\t\t\tSET \n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "', \n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\n\t\t\t\t\t\t\ttext='" . addslashes($_POST['text']) . "'\n\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/contents?revision=" . $data['params']['revision']); exit; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set('story', $story); $tpl->set('id', $data['params']['id']); $tpl->set('revision', $data['params']['revision']); $data['template']->append('content', $tpl->fetch()); } }
function event_ExecuteEditor(&$data) { global $lang, $manager; if ($data['type'] == 'external' && $data['sheet'] == 'external') { if ($_SERVER['REQUEST_METHOD'] == 'POST') { if ($_REQUEST['url'] != 'http://') { $res = sql::query("\r\n\t\t\t\t\t\t\tREPLACE \r\n\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_external\r\n\t\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "',\r\n\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t\turl='" . addslashes($_REQUEST['url']) . "'\r\n\t\t\t\t\t\t"); } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/external?revision=" . $data['params']['revision']); exit; } $res = sql::query("\r\n\t\t\t\t\tSELECT\r\n\t\t\t\t\t\t*\r\n\t\t\t\t\tFROM\r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_external\r\n\t\t\t\t\tWHERE\r\n\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t"); $tpl = new Template($this->getTemplate('editor.template')); if ($row = sql::fetch_array($res)) { $tpl->set("url", $row['url']); } else { $tpl->set("url", 'http://'); } $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); $data['template']->append('content', $tpl->fetch()); } }
function event_ExecuteEditor(&$data) { global $lang, $manager; if (isset($manager->types[$data['type']]['content']['links']) && $data['sheet'] == 'links') { // Define a list of errors $errors = array(); $links = array(); $res = sql::query("\r\n\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t* \r\n\t\t\t\t\tFROM\r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_links\r\n\t\t\t\t\tWHERE\r\n\t\t\t\t\t\tID = '" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\trevision = '" . $data['params']['revision'] . "'\r\n\t\t\t\t"); while ($row = sql::fetch_array($res, MYSQL_ASSOC)) { $links[$row['link']] = $row; } if ($_SERVER['REQUEST_METHOD'] == 'POST') { $res = sql::query("\r\n\t\t\t\t\t\tDELETE FROM \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_links \r\n\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t\t"); if (is_array($_POST['links'])) { $position = 0; while (list(, $v) = each($_POST['links'])) { $res = sql::query("\r\n\t\t\t\t\t\t\t\tINSERT INTO \r\n\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_links \r\n\t\t\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "', \r\n\t\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t\t\tposition='" . $position . "',\r\n\t\t\t\t\t\t\t\t\turl='" . addslashes($v['url']) . "', \r\n\t\t\t\t\t\t\t\t\ttitle='" . addslashes($v['title']) . "',\r\n\t\t\t\t\t\t\t\t\ttarget='" . addslashes($v['target']) . "'\r\n\t\t\t\t\t\t\t"); $position++; } } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/links?revision=" . $data['params']['revision']); exit; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set("links", $links); $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); if (count($errors)) { $data['template']->append('error', implode(', ', $errors)); } $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerJavascript('/core/assets/javascript/modaldialog.js'); $data['page']->assets->registerCSS($this->localAsset('editor.css')); $data['page']->assets->registerJavascript($this->localAsset('editor.js')); } }
function event_ExecuteEditor(&$data) { global $tree, $language; if ($data['sheet'] == 'seo') { if ($_SERVER['REQUEST_METHOD'] == 'POST') { $keywords = isset($_POST['keywords']) ? trim($_POST['keywords']) : ''; $description = isset($_POST['description']) ? trim($_POST['description']) : ''; $res = sql::query("\r\n\t\t\t\t\t\tREPLACE INTO \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_seo\r\n\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "',\r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\tkeywords='" . addslashes($keywords) . "',\r\n\t\t\t\t\t\t\tdescription='" . addslashes($description) . "'\r\n\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/seo?revision=" . $data['params']['revision']); exit; } $res = sql::query("\r\n\t\t\t\t\tSELECT\r\n\t\t\t\t\t\t*\r\n\t\t\t\t\tFROM\r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_seo\r\n\t\t\t\t\tWHERE\r\n\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t"); if (!($row = sql::fetch_array($res))) { $row = array('keywords' => '', 'description' => ''); } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set('seo', $row); $tpl->set('id', $data['params']['id']); $tpl->set("revision", $data['params']['revision']); $data['template']->append('content', $tpl->fetch()); } }
function event_ExecuteEditor(&$data) { global $lang, $manager; if (isset($manager->types[$data['type']]['content']['movie']) && $data['sheet'] == 'movie') { if (isset($_REQUEST['json']) && $_REQUEST['json'] == 'list') { $res = sql::query("\r\n\t\t\t\t\t\tSELECT\r\n\t\t\t\t\t\t\t*\r\n\t\t\t\t\t\tFROM\r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie\r\n\t\t\t\t\t\tWHERE\r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t\t"); $tpl = new Template($this->getTemplate('json.template')); if ($movie = sql::fetch_array($res)) { $tpl->set("movie", $movie); } echo $tpl->fetch(); exit; } if (isset($_REQUEST['json']) && $_REQUEST['json'] == 'delete') { $res = sql::query("\r\n\t\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t\t* \r\n\t\t\t\t\t\tFROM \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie\r\n\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t\t"); if ($row = sql::fetch_array($res)) { $directory = _BASE_MEDIA_ . 'movies/'; if (file_exists($directory . $row['filename'])) { unlink($directory . $row['filename']); } $res = sql::query("\r\n\t\t\t\t\t\t\tDELETE FROM \r\n\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie\r\n\t\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t\t\t"); } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); exit; } if ($_SERVER['REQUEST_METHOD'] == 'POST') { /* Upload */ if (isset($_FILES['Filedata'])) { if ($_FILES['Filedata']['error'] == UPLOAD_ERR_OK && is_uploaded_file($_FILES['Filedata']['tmp_name'])) { $directory = _BASE_MEDIA_ . 'movies/'; $original = $_FILES['Filedata']['name']; $contenttype = files::getCleanContentType($_FILES['Filedata']['type'], $_FILES['Filedata']['name']); $filename = files::getUniqueName($contenttype, $directory); if (files::allowedContentType($contenttype, 'movie')) { // Insert into database... move_uploaded_file($_FILES['Filedata']['tmp_name'], $directory . $filename); $res = sql::query("\r\n\t\t\t\t\t\t\t\t\tINSERT INTO\r\n\t\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie \r\n\t\t\t\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "', \r\n\t\t\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t\t\t\tfilename='" . addslashes($filename) . "', \r\n\t\t\t\t\t\t\t\t\t\tname='" . addslashes($original) . "',\r\n\t\t\t\t\t\t\t\t\t\ttype='" . addslashes($contenttype) . "', \r\n\t\t\t\t\t\t\t\t\t\tsize='" . addslashes($_FILES['Filedata']['size']) . "',\r\n\t\t\t\t\t\t\t\t\t\twidth=320,\r\n\t\t\t\t\t\t\t\t\t\theight=240,\r\n\t\t\t\t\t\t\t\t\t\tautostart=0\r\n\t\t\t\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); // Workaround for a Flash bug on OS X.. We need to send back content... any content will do echo " "; flush(); exit; } else { header("HTTP/1.1 415 Unsupported Media Type"); header("Status: 415 Unsupported Media Type"); exit; } } else { switch ($_FILES['Filedata']['error']) { case UPLOAD_ERR_INI_SIZE: case UPLOAD_ERR_FORM_SIZE: header("HTTP/1.1 413 Request Entity Too Large"); header("Status: 413 Request Entity Too Large"); exit; case UPLOAD_ERR_NO_FILE: case UPLOAD_ERR_PARTIAL: default: header("HTTP/1.1 400 Bad Request"); header("Status: 400 Bad Request"); exit; } } } else { // Update size and autostart $autostart = isset($_REQUEST['autostart']) ? intval($_REQUEST['autostart']) : 0; $width = isset($_REQUEST['size']) ? intval($_REQUEST['size']) : 320; switch ($width) { case 320: $height = 240; case 640: $height = 480; default: $height = round($width / 4 * 3); } $res = sql::query("\r\n\t\t\t\t\t\t\tUPDATE\r\n\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie\r\n\t\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t\twidth='" . addslashes($width) . "',\r\n\t\t\t\t\t\t\t\theight='" . addslashes($height) . "',\r\n\t\t\t\t\t\t\t\tautostart='" . addslashes($autostart) . "'\r\n\t\t\t\t\t\t\tWHERE\r\n\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t\t\t"); } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/movie?revision=" . $data['params']['revision']); exit; } $res = sql::query("\r\n\t\t\t\t\tSELECT\r\n\t\t\t\t\t\t*\r\n\t\t\t\t\tFROM\r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_movie\r\n\t\t\t\t\tWHERE\r\n\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\trevision='" . $data['params']['revision'] . "'\r\n\t\t\t\t"); $tpl = new Template($this->getTemplate('editor.template')); if ($movie = sql::fetch_array($res)) { $tpl->set("movie", $movie); } $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); $tpl->set("filemask", files::getFilemask('movie')); $tpl->set("ticket", ticket::generate($data['params']['id'])); $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerJavascript('/core/assets/javascript/plugin.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/flash.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/upload.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/progress.js'); $data['page']->assets->registerJavascript($this->localAsset('editor.js')); $data['page']->assets->registerJavascript($this->localAsset('player.js')); } }
function event_ExecuteEditor(&$data) { global $lang, $manager; if (isset($manager->types[$data['type']]['content']['files']) && ($data['sheet'] == 'attachments' || $data['sheet'] == 'files')) { if (isset($_REQUEST['json']) && $_REQUEST['json'] == 'list') { $tpl = new Template($this->getTemplate('json.template')); if ($data['sheet'] == 'files') { $tpl->set("files", $this->_files_list($data['params']['id'], $data['params']['revision'])); } else { $tpl->set("files", $this->_attachments_list($data['params']['id'], $data['params']['revision'])); } echo $tpl->fetch(); exit; } if (isset($_REQUEST['json']) && $_REQUEST['json'] == 'delete') { $res = sql::query("\r\n\t\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t\t* \r\n\t\t\t\t\t\tFROM \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_files \r\n\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND \r\n\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "' AND \r\n\t\t\t\t\t\t\tfilename='" . addslashes($_POST['delete']) . "'\r\n\t\t\t\t\t"); if ($row = sql::fetch_array($res)) { $directory = _BASE_MEDIA_ . 'files/'; if (file_exists($directory . $row['filename'])) { unlink($directory . $row['filename']); } $res = sql::query("\r\n\t\t\t\t\t\t\tDELETE FROM \r\n\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_files \r\n\t\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND \r\n\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "' AND \r\n\t\t\t\t\t\t\t\tfilename='" . addslashes($row['filename']) . "'\r\n\t\t\t\t\t\t"); } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); exit; } if ($_SERVER['REQUEST_METHOD'] == 'POST') { if (isset($_REQUEST['files']) && is_array($_REQUEST['files'])) { // Update title and position while (list($id, $file) = each($_REQUEST['files'])) { $res = sql::query("\r\n\t\t\t\t\t\t\t\tUPDATE\r\n\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_files \r\n\t\t\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t\t\ttitle='" . addslashes($file['title']) . "',\r\n\t\t\t\t\t\t\t\t\tposition='" . addslashes($file['position']) . "'\r\n\t\t\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "' AND \r\n\t\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "' AND \r\n\t\t\t\t\t\t\t\t\tfilename='" . addslashes($id) . "'\r\n\t\t\t\t\t\t\t"); } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); } if (isset($_FILES['Filedata'])) { $flashUsed = preg_match('/Flash/i', $_SERVER['HTTP_USER_AGENT']); if ($_FILES['Filedata']['error'] == UPLOAD_ERR_OK && is_uploaded_file($_FILES['Filedata']['tmp_name'])) { $directory = _BASE_MEDIA_ . 'files/'; $original = $_FILES['Filedata']['name']; $contenttype = files::getCleanContentType($_FILES['Filedata']['type'], $_FILES['Filedata']['name']); $filename = files::getUniqueName($contenttype, $directory); if (files::allowedContentType($contenttype)) { // Insert into database... @move_uploaded_file($_FILES['Filedata']['tmp_name'], $directory . $filename); $attachment = $data['sheet'] == 'files' ? 0 : 1; $res = sql::query("\r\n\t\t\t\t\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t\t\t\t\t*\r\n\t\t\t\t\t\t\t\t\tFROM\r\n\t\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_files \r\n\t\t\t\t\t\t\t\t\tWHERE\r\n\t\t\t\t\t\t\t\t\t\tID = " . $data['params']['id'] . " AND\r\n\t\t\t\t\t\t\t\t\t\trevision = " . $data['params']['revision'] . " AND\r\n\t\t\t\t\t\t\t\t\t\tattachment = " . $attachment . "\r\n\t\t\t\t\t\t\t\t\tORDER BY\r\n\t\t\t\t\t\t\t\t\t\tposition DESC\r\n\t\t\t\t\t\t\t\t\tLIMIT 1\r\n\t\t\t\t\t\t\t\t"); if ($row = sql::fetch_array($res)) { $position = $row['position'] + 1; } else { $position = 0; } $res = sql::query("\r\n\t\t\t\t\t\t\t\t\tINSERT INTO \r\n\t\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_files \r\n\t\t\t\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\t\t\t\tID='" . $data['params']['id'] . "', \r\n\t\t\t\t\t\t\t\t\t\trevision='" . $data['params']['revision'] . "', \r\n\t\t\t\t\t\t\t\t\t\tfilename='" . addslashes($filename) . "', \r\n\t\t\t\t\t\t\t\t\t\tname='" . addslashes($original) . "',\r\n\t\t\t\t\t\t\t\t\t\ttype='" . addslashes($contenttype) . "', \r\n\t\t\t\t\t\t\t\t\t\ttitle='" . addslashes($original) . "',\r\n\t\t\t\t\t\t\t\t\t\tsize='" . addslashes($_FILES['Filedata']['size']) . "',\r\n\t\t\t\t\t\t\t\t\t\tposition='" . $position . "',\r\n\t\t\t\t\t\t\t\t\t\tattachment='" . $attachment . "',\r\n\t\t\t\t\t\t\t\t\t\tmodified=NOW()\r\n\t\t\t\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); if (!$flashUsed) { header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); } else { // Workaround for a Flash bug on OS X.. We need to send back content... any content will do echo " "; flush(); } } else { if ($flashUsed) { header("HTTP/1.1 415 Unsupported Media Type"); header("Status: 415 Unsupported Media Type"); } else { header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); } } exit; } else { switch ($_FILES['Filedata']['error']) { case UPLOAD_ERR_INI_SIZE: case UPLOAD_ERR_FORM_SIZE: if ($flashUsed) { header("HTTP/1.1 413 Request Entity Too Large"); header("Status: 413 Request Entity Too Large"); } else { header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); } break; case UPLOAD_ERR_NO_FILE: case UPLOAD_ERR_PARTIAL: if ($flashUsed) { header("HTTP/1.1 400 Bad Request"); header("Status: 400 Bad Request"); } else { header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); } break; case UPLOAD_ERR_NO_TMP_DIR: case UPLOAD_ERR_CANT_WRITE: case UPLOAD_ERR_EXTENSION: default: if ($flashUsed) { header("HTTP/1.1 500 Internal Error"); header("Status: 500 Internal Error"); } else { header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); } break; } exit; } } header("Location: " . url::item($data['params']['id'], 'edit') . "/" . $data['sheet'] . "?revision=" . $data['params']['revision']); exit; } $tpl = new Template($this->getTemplate('editor.template')); if ($data['sheet'] == 'files') { $tpl->set("files", $this->_files_list($data['params']['id'], $data['params']['revision'])); } else { $tpl->set("files", $this->_attachments_list($data['params']['id'], $data['params']['revision'])); } $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); $tpl->set("filemask", files::getFilemask()); $tpl->set("ticket", ticket::generate($data['params']['id'])); $tpl->set("sheet", $data['sheet']); $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerJavascript('/core/assets/javascript/plugin.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/flash.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/upload.js'); $data['page']->assets->registerJavascript('/core/assets/javascript/progress.js'); $data['page']->assets->registerCSS($this->localAsset('editor.css')); $data['page']->assets->registerJavascript($this->localAsset('editor.js')); } }
function event_ExecuteEditor(&$data) { global $lang, $manager, $user; if (isset($manager->types[$data['type']]['content']['form']) && $data['sheet'] == 'form') { $structure = $this->getStructure($data['params']['id'], $data['params']['revision']); if ($_SERVER['REQUEST_METHOD'] == 'POST') { // First delete the original... $this->event_DeleteRevision($data['params']); // Create the new structure sql::query("\r\n\t\t\t\t\t\tINSERT INTO\r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_form\r\n\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "',\r\n\t\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t`button` = '" . addslashes($_REQUEST['button']) . "',\r\n\t\t\t\t\t\t\t`email` = '" . addslashes($_REQUEST['email']) . "'\r\n\t\t\t\t\t"); while (list($id, $element) = each($_REQUEST['elements'])) { if (isset($element['options'])) { if ($element['type'] == 'checkbox') { $default = array(); reset($element['options']); while (list(, $option) = each($element['options'])) { if (isset($option['default'])) { $default[] = $option['title']; } } $element['default'] = implode(',', $default); } else { if ($element['default'] != '0') { $element['default'] = $element['options'][$element['default']]['title']; } else { $element['default'] = ''; } } } sql::query("\r\n\t\t\t\t\t\t\tINSERT INTO\r\n\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_form_elements\r\n\t\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t\t`form` = '" . $data['params']['id'] . "',\r\n\t\t\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t\t`order` = '" . intval($element['position']) . "',\r\n\t\t\t\t\t\t\t\t`type` = '" . addslashes($element['type']) . "',\r\n\t\t\t\t\t\t\t\t`title` = '" . addslashes($element['title']) . "',\r\n\t\t\t\t\t\t\t\t`size` = '" . intval($element['size']) . "',\r\n\t\t\t\t\t\t\t\t`default` = '" . addslashes($element['default']) . "',\r\n\t\t\t\t\t\t\t\t`action` = '" . addslashes($element['action']) . "',\r\n\t\t\t\t\t\t\t\t`required` = '" . (isset($element['required']) ? 1 : 0) . "'\r\n\t\t\t\t\t\t"); $element_id = sql::insert_id(); if (isset($element['options'])) { reset($element['options']); while (list(, $option) = each($element['options'])) { sql::query("\r\n\t\t\t\t\t\t\t\t\tINSERT INTO\r\n\t\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_form_elements_options\r\n\t\t\t\t\t\t\t\t\tSET\r\n\t\t\t\t\t\t\t\t\t\t`element` = '" . $element_id . "',\r\n\t\t\t\t\t\t\t\t\t\t`order` = '" . intval($option['order']) . "',\r\n\t\t\t\t\t\t\t\t\t\t`title` = '" . addslashes($option['title']) . "'\r\n\t\t\t\t\t\t\t\t"); } } } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/form?revision=" . $data['params']['revision']); exit; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); if ($structure) { $tpl->set("structure", $this->getJSON($structure)); $tpl->set("email", $structure['email']); $tpl->set("button", $structure['button']); } else { $tpl->set("structure", '[ ]'); $tpl->set("email", ''); $tpl->set("button", ''); } $tpl->set("types", array('text' => $user->lang->s('typetext'), 'textarea' => $user->lang->s('typetextarea'), 'email' => $user->lang->s('typeemail'), 'select' => $user->lang->s('typeselect'), 'radio' => $user->lang->s('typeradio'), 'checkbox' => $user->lang->s('typecheckbox'), 'country' => $user->lang->s('typecountry'), 'explaination' => $user->lang->s('typeexplaination'), 'header' => $user->lang->s('typeheader'), 'button' => $user->lang->s('typebutton'))); $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerCSS($this->localAsset('editor.css')); $data['page']->assets->registerJavascript($this->localAsset('editor.js')); } }
function event_ExecuteEditor(&$data) { global $lang, $manager, $user; if (isset($manager->types[$data['type']]['content']['collection']) && $data['sheet'] == 'collection') { // Retrieve story $res = sql::query("\n\t\t\t\t\tSELECT \n\t\t\t\t\t\t*\n\t\t\t\t\tFROM \n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_collection \n\t\t\t\t\tWHERE \n\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "' AND\n\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "'\n\t\t\t\t"); if ($row = sql::fetch_array($res, MYSQL_ASSOC)) { $type = $row['type']; } else { $type = ''; } if ($_SERVER['REQUEST_METHOD'] == 'POST') { $res = sql::query("\n\t\t\t\t\t\tREPLACE INTO \n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_collection \n\t\t\t\t\t\tSET \n\t\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "', \n\t\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "',\n\t\t\t\t\t\t\t`type` = '" . addslashes($_POST['type']) . "',\n\t\t\t\t\t\t\t`limit` = " . intval($_POST['limit']) . ",\n\t\t\t\t\t\t\t`sort` = " . (isset($_POST['reverse']) ? 0 - $_POST['sort'] : $_POST['sort']) . "\n\t\t\t\t\t"); // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/collection?revision=" . $data['params']['revision']); exit; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set('type', $type); $tpl->set('limit', $row['limit']); $tpl->set('sort', $row['sort']); $tpl->set('types', $manager->types()); $tpl->set('id', $data['params']['id']); $tpl->set('revision', $data['params']['revision']); $data['template']->append('content', $tpl->fetch()); } }
function event_ExecuteEditor(&$data) { global $lang, $manager; if (isset($manager->types[$data['type']]['content']['slides']) && $data['sheet'] == 'slides') { // Define a list of errors $errors = array(); if ($_SERVER['REQUEST_METHOD'] == 'POST') { mysql_query("\r\n\t\t\t\t\t\tDELETE FROM \r\n\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_slides\r\n\t\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "'\r\n\t\t\t\t\t"); if (is_array($_POST['slides'])) { $position = 0; while (list(, $slide) = each($_POST['slides'])) { mysql_query("\r\n\t\t\t\t\t\t\t\tINSERT INTO \r\n\t\t\t\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_slides \r\n\t\t\t\t\t\t\t\tSET \r\n\t\t\t\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "', \r\n\t\t\t\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "',\r\n\t\t\t\t\t\t\t\t\t`position` = '" . $position . "',\r\n\t\t\t\t\t\t\t\t\t`thumbnail` = '" . addslashes($slide['thumbnail']) . "', \r\n\t\t\t\t\t\t\t\t\t`image` = '" . addslashes($slide['image']) . "', \r\n\t\t\t\t\t\t\t\t\t`title` = '" . addslashes($slide['title']) . "', \r\n\t\t\t\t\t\t\t\t\t`description` = '" . addslashes($slide['description']) . "'\r\n\t\t\t\t\t\t\t"); $position++; } } // Mark this action as a modification revisions::updateModificationDate($data['params']['id'], $data['params']['revision']); header("Location: " . url::item($data['params']['id'], 'edit') . "/slides?revision=" . $data['params']['revision']); exit; } // Load... $slides = array(); $res = mysql_query("\r\n\t\t\t\t\tSELECT \r\n\t\t\t\t\t\t*\r\n\t\t\t\t\tFROM \r\n\t\t\t\t\t\t" . _TABLE_PREFIX_ . "contents_slides\r\n\t\t\t\t\tWHERE \r\n\t\t\t\t\t\t`ID` = '" . $data['params']['id'] . "' AND\r\n\t\t\t\t\t\t`revision` = '" . $data['params']['revision'] . "'\r\n\t\t\t\t"); while ($row = mysql_fetch_array($res, MYSQL_ASSOC)) { $row['description'] = preg_replace('/\\s+/', ' ', $row['description']); $slides[] = $row; } $tpl = new Template($this->getTemplate('editor.template')); $tpl->set("slides", $slides); $tpl->set("id", $data['params']['id']); $tpl->set("revision", $data['params']['revision']); if (count($errors)) { $data['template']->append('error', implode(', ', $errors)); } $data['template']->append('content', $tpl->fetch()); // Make sure the following assets are included $data['page']->assets->registerJavascript('/core/assets/javascript/modaldialog.js'); $data['page']->assets->registerCSS($this->localAsset('editor.css')); $data['page']->assets->registerJavascript($this->localAsset('editor.js')); } }