
LCARS is a template for the GetSimple CMS that mimics the monitor appearance in the television series Star Trek: The Next Generation
76 lines
2.3 KiB
PHP
76 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Display Available Themes
|
|
*
|
|
* This file spits out a list of available themes to the control panel.
|
|
* This is provided thru an ajax call.
|
|
*
|
|
* @package GetSimple
|
|
* @subpackage Available-Themes
|
|
*/
|
|
|
|
// Include common.php
|
|
include('common.php');
|
|
login_cookie_check();
|
|
|
|
// JSON output of pages for ckeditor select
|
|
if(isset($_REQUEST['list_pages_json'])) {
|
|
include_once('plugin_functions.php');
|
|
include_once('caching_functions.php');
|
|
getPagesXmlValues();
|
|
header('Content-type: application/json');
|
|
echo list_pages_json();
|
|
die();
|
|
}
|
|
|
|
// Make sure register globals don't make this hackable again.
|
|
if (isset($TEMPLATE)) unset($TEMPLATE);
|
|
|
|
/**
|
|
* Sanitise first
|
|
* @todo Maybe use Anti-XSS on this instead?
|
|
*/
|
|
if (isset($_GET['dir'])) {
|
|
$TEMPLATE = '';
|
|
$segments = explode('/',implode('/',explode('\\',$_GET['dir'])));
|
|
foreach ($segments as $part) if ($part !== '..') $TEMPLATE .= $part.'/';
|
|
$TEMPLATE = preg_replace('/\/+/','/',$TEMPLATE);
|
|
if (strlen($TEMPLATE)<=0||$TEMPLATE=='/') unset($TEMPLATE);
|
|
}
|
|
|
|
// Send back list of theme files from a certain directory for theme-edit.php
|
|
if (isset($TEMPLATE)) {
|
|
$TEMPLATE_FILE = ''; $template = ''; $theme_templates = '';
|
|
|
|
if ($template == '') { $template = 'template.php'; }
|
|
|
|
if(!filepath_is_safe(GSTHEMESPATH . $TEMPLATE,GSTHEMESPATH)) die();
|
|
|
|
$templates = directoryToArray(GSTHEMESPATH . $TEMPLATE . '/', true);
|
|
$allowed_extensions=array('php','css','js','html','htm');
|
|
$theme_templates .= '<select class="text" id="theme_files" style="width:425px;" name="f" >';
|
|
foreach ($templates as $file) {
|
|
$extension=pathinfo($file,PATHINFO_EXTENSION);
|
|
if (in_array($extension, $allowed_extensions)){
|
|
$filename=pathinfo($file,PATHINFO_BASENAME);
|
|
$filenamefull=substr(strstr($file,'/theme/'.$TEMPLATE.'/'),strlen('/theme/'.$TEMPLATE.'/'));
|
|
if ($TEMPLATE_FILE == $filename){
|
|
$sel="selected";
|
|
} else {
|
|
$sel="";
|
|
}
|
|
if ($filename == 'template.php'){
|
|
$templatename=i18n_r('DEFAULT_TEMPLATE');
|
|
} else {
|
|
$templatename=$filenamefull;
|
|
}
|
|
$theme_templates .= '<option '.$sel.' value="'.$templatename.'" >'.$templatename.'</option>';
|
|
}
|
|
}
|
|
|
|
$theme_templates .= "</select>";
|
|
|
|
echo $theme_templates;
|
|
}
|
|
?>
|