<?php if(!defined('entry'))define('entry', true); /* =========================== gelato CMS - A PHP based tumblelog CMS development version http://www.gelatocms.com/ gelato CMS is a free software licensed under the GPL 2.0 Copyright (C) 2007 by Pedro Santana <pecesama at gmail dot com> =========================== */ ?> <?php require('../entry.php'); global $user, $conf, $tumble; #$template = new plantillas("admin"); $theme = new themes; $isEdition = (isset($_GET["edit"])) ? true : false; $postId = ($isEdition) ? $_GET["edit"] : NULL; $theme->set('isEdition',$isEdition); $theme->set('postId',$postId); $theme->set('pagination',''); if (get_magic_quotes_gpc()) { foreach($_GET as $k=>$get){ $_GET[$k]=stripslashes($get); } } if ($user->isAuthenticated()) { if (isset($_GET["delete"])) { $tumble->deletePost($_GET['delete']); header("Location: index.php?deleted=true"); die(); } if(isset($_POST["btnAdd"])){ unset($_POST["btnAdd"]); $_POST['type'] = type2Number($_POST['type']); if ($_POST["type"]=="2") { // is Photo type if (isset($_POST["url"]) && $_POST["url"]!="") { $photoName = getFileName($_POST["url"]); if (!$tumble->savePhoto($_POST["url"])) { header("Location: ".$conf->urlGelato."/admin/index.php?photo=false"); die(); } $_POST["url"] = "../uploads/".sanitizeName($photoName); } if ( move_uploaded_file( $_FILES['photo']['tmp_name'], "../uploads/".sanitizeName($_FILES['photo']['name']) ) ) { $_POST["url"] = "../uploads/".sanitizeName($_FILES['photo']['name']); } unset($_POST["photo"]); unset($_POST["MAX_FILE_SIZE"]); } if ($_POST["type"]=="7") { // is MP3 type set_time_limit(300); $mp3Name = getFileName($_POST["url"]); if (!$tumble->saveMP3($_POST["url"])) { header("Location: ".$conf->urlGelato."/admin/index.php?mp3=false"); die(); } if (isMP3($remoteFileName)) { $_POST["url"] = $conf->urlGelato."/uploads/".$mp3Name; } } if (!get_magic_quotes_gpc()) { $_POST["title"] = addslashes($_POST["title"]); $_POST["description"] = addslashes($_POST["description"]); } /* $textile = new Textile(); $_POST["title"] = $textile->TextileThis(removeBadTags($_POST["title"],true)); $_POST["description"] = $textile->TextileThis(removeBadTags($_POST["description"])); */ $_POST["title"] = removeBadTags($_POST["title"],true); $_POST["description"] = removeBadTags($_POST["description"]); if (isset($_POST["id_post"]) and is_numeric($_POST["id_post"]) and $_POST["id_post"]>0) { $tumble->modifyPost($_POST, $_POST["id_post"]); } else { if ($tumble->addPost($_POST)) { header("Location: ".$conf->urlGelato."/admin/index.php?added=true"); die(); } else { header("Location: ".$conf->urlGelato."/admin/index.php?error=2&des=".$tumble->merror); die(); } } } else { if ($isEdition) { $post = $tumble->getPost($postId); } $admin_includes = ""; $trigger->call('admin_includes'); $theme->set('admin_includes',$admin_includes); $theme->set('version',version()); $theme->set('conf', array( 'urlGelato'=>$conf->urlGelato, 'richText'=>$conf->richText )); $theme->set('new',isset($_GET['new'])?$_GET['new']:''); $theme->set('information',false); $theme->set('error',false); if($conf->check_version){ $present = version(); $lastest = _file_get_contents("http://www.gelatocms.com/vgel.txt"); if ($present < $lastest) $theme->set('information',__("A new gelato version has been released and is ready <a href=\"http://www.gelatocms.com/\">for download</a>.")); } $actions = array( 'deleted'=>false, 'modified'=>false, 'added'=>false ); if(isset($_GET['deleted']) and $_GET['deleted']=='true'){ $theme->set('exito',__("The post has been eliminated successfully.")); $actions['deleted'] = true; } if(isset($_GET["modified"]) and $_GET["modified"]==true){ $theme->set('exito',__("The post has been modified successfully.")); $actions['modified']=true; } if(isset($_GET["added"]) and $_GET["added"]==true) { $theme->set('exito',__("The post has been added successfully.")); $actions['added']=true; } $theme->set('action',$actions); if (isset($_GET["error"]) and $_GET["error"]==2) $theme->set('error',__("Error on the database server:")." </strong>".$_GET["des"]); if (isset($_GET["mp3"]) and $_GET["mp3"]=='false') $theme->set('error',__("Not an MP3 file or an upload problem.")); if (isset($_GET["photo"]) and $_GET["photo"]=='false') $theme->set('error',__("Not a photo file or an upload problem.")); if ($isEdition) { switch ($post["type"]) { case "1": $_GET["new"] = "post"; break; case "2": $_GET["new"] = "photo"; break; case "3": $_GET["new"] = "quote"; break; case "4": $_GET["new"] = "url"; break; case "5": $_GET["new"] = "conversation"; break; case "6": $_GET["new"] = "video"; break; case "7": $_GET["new"] = "mp3"; break; } } $date = ($isEdition) ? strtotime($post["date"]) : gmmktime(); $title = ($isEdition) ? htmlspecialchars(stripslashes($post["title"])) : ""; $body = ($isEdition) ? stripslashes($post["description"]) : ""; $url = ($isEdition) ? $post["url"] : ""; if (!isset($_GET['new'])) $_GET['new'] = 'post'; $form = new themes; $form->set('date',$date); $form->set('id_user',$_SESSION['user_id']); $form->set('type',$_GET["new"]); $form->set('editBody',$body); switch ($_GET["new"]) { case "post": $form->set('editTitle',$title); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_post.htm')); break; case "photo": $url = str_replace("../", $conf->urlGelato."/", $url); $form->set('editUrl',$url); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_photo.htm')); break; case "quote": $form->set('editTitle',$title); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_quote.htm')); break; case "url": $form->set('editTitle',$title); $form->set('editUrl',$url); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_link.htm')); break; case "conversation": $form->set('editTitle',$title); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_conversation.htm')); break; case "video": $form->set('editUrl',$url); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_video.htm')); break; case "mp3": $form->set('editUrl',$url); $theme->set('form',$form->fetch(Absolute_Path.'admin/themes/admin/template_add_mp3.htm')); break; } if (!$isEdition){ if (isset($_GET["page"])) $page_num = $_GET["page"]; else $page_num = NULL; $limit=$conf->postLimit; if(isset($page_num) && is_numeric($page_num) && $page_num>0)// Is defined the page and is numeric? $from = (($page_num-1) * $limit); else $from = 0; $rs = $tumble->getPosts($limit, $from); $theme->set('Posts_Number',$tumble->contarRegistros()); $rows = array(); if ($tumble->contarRegistros()>0) { while($register = mysql_fetch_array($rs)) { $row['postType'] = type2Text($tumble->getType($register["id_post"])); $formatedDate = gmdate("M d", strtotime($register["date"])+transform_offset($conf->offsetTime)); $strEnd=($conf->urlFriendly) ? "/" : ""; $permalink = $conf->urlGelato.($conf->urlFriendly?"/post/":"/index.php?post=").$register["id_post"].$strEnd; $register["title"] = stripslashes($register["title"]); $register["description"] = stripslashes($register["description"]); $row['Id_Post'] = $register["id_post"]; $row['Date_Added'] = $formatedDate; $row['Permalink'] = $permalink; switch ($tumble->getType($register["id_post"])) { case "1": $row['Title'] = $register["title"]; $row['Body'] = $register["description"]; break; case "2": $fileName = "../uploads/".getFileName($register["url"]); $x = @getimagesize($fileName); if ($x[0] > 100) $photoPath = $conf->urlGelato."/classes/imgsize.php?w=100&img=".$register["url"]; else $photoPath = $register["url"]; $effect = " href=\"".str_replace("../", $conf->urlGelato."/", $register["url"])."\" rel=\"lightbox\""; $row['PhotoURL'] = $photoPath; $row['PhotoAlt'] = strip_tags($register["description"]); $row['Caption'] = $register["description"]; $row['Effect'] = $effect; break; case "3": $row['Quote'] = $register["description"]; $row['Source'] = $register["title"]; break; case "4": if($conf->shorten_links) $register["url"] = _file_get_contents("http://api.abbrr.com/api.php?out=link&url=".$register["url"]); $register["title"] = ($register["title"]=="")? $register["url"] : $register["title"]; $row['URL'] = $register["url"]; $row['Name'] = $register["title"]; $row['Description'] = $register["description"]; break; case "5": $row['Title'] = $register["title"]; $row['Conversation'] = $tumble->formatConversation($register["description"]); break; case "6": $row['Video'] = $tumble->getVideoPlayer($register["url"]); $row['Caption'] = $register["description"]; break; case "7": $row['Mp3'] = $tumble->getMp3Player($register["url"]); $row['Caption'] = $register["description"]; break; } $rows[] = $row; } $p = new pagination; $p->items($tumble->getPostsNumber()); $p->limit($limit); $p->currentPage(isset($page_num) ? $page_num : 1); $theme->set('pagination',$p->getPagination()); $theme->set('rows',$rows); }else{ $theme->set('error',__("No posts in this tumblelog.")); } } $theme->display(Absolute_Path.'admin/themes/admin/index.htm'); } } else { header("Location: ".$conf->urlGelato."/login.php"); } ?>