1
0
mirror of https://github.com/phpbb/phpbb.git synced 2025-10-24 13:16:16 +02:00
Files
php-phpbb/phpBB/adm/admin_styles.php
Paul S. Owen 7e97dbdabd That shouldn't be there ...
git-svn-id: file:///svn/phpbb/trunk@4425 89ea8834-ac86-4346-8a33-228a782c2dd0
2003-08-23 18:20:25 +00:00

3373 lines
104 KiB
PHP

<?php
// -------------------------------------------------------------
//
// $Id$
//
// FILENAME : admin_styles.php
// STARTED : Thu Aug 7 2003
// COPYRIGHT : © 2003 phpBB Group
// WWW : http://www.phpbb.com/
// LICENCE : GPL vs2.0 [ see /docs/COPYING ]
//
// -------------------------------------------------------------
// TODO
// For M-3
// BBCode support
// Replace template/s, stylesheet, images, etc.
// Previews of templates, imagesets, themes ... unified
// Security review
if (!empty($setmodules))
{
if (!$auth->acl_get('a_styles'))
{
return;
}
$filename = basename(__FILE__);
$module['STYLE']['MANAGE_STYLE'] = "$filename$SID&amp;mode=style";
$module['STYLE']['MANAGE_TEMPLATE'] = "$filename$SID&amp;mode=template";
$module['STYLE']['MANAGE_THEME'] = "$filename$SID&amp;mode=theme";
$module['STYLE']['MANAGE_IMAGESET'] = "$filename$SID&amp;mode=imageset";
return;
}
define('IN_PHPBB', 1);
// Include files
$phpbb_root_path = '../';
require($phpbb_root_path . 'extension.inc');
require('pagestart.' . $phpEx);
// Do we have styles admin permissions?
if (!$auth->acl_get('a_styles'))
{
trigger_error($user->lang['NO_ADMIN']);
}
// Get some vars
$update = (isset($_POST['update'])) ? true : false;
$mode = (isset($_REQUEST['mode'])) ? htmlspecialchars($_REQUEST['mode']) : '';
$id = (isset($_REQUEST['id'])) ? intval($_REQUEST['id']) : '';
if (isset($_REQUEST['action']))
{
$action = htmlspecialchars($_REQUEST['action']);
}
else
{
$action = '';
if (isset($_POST['add']))
{
$action = 'add';
}
else if (isset($_POST['preview']))
{
$action = 'preview';
}
}
// Set some basic vars
$error = $cfg = array();
$safe_mode = (@ini_get('safe_mode') || @strtolower(ini_get('safe_mode')) == 'on') ? true : false;
$file_uploads = (@ini_get('file_uploads') || strtolower(@ini_get('file_uploads')) == 'on') ? true : false;
// Generate list of archive types inc. regexp | match
$archive_types = '<u>.tar</u>';
$archive_preg = '\.tar';
foreach (array('tar.gz' => 'zlib', 'tar.bz2' => 'bz2', 'zip' => 'zlib') as $type => $module)
{
if (!@extension_loaded($module))
{
continue;
}
$archive_types .= ", <u>.$type</u>";
$archive_preg .= '|\.' . preg_quote($type);
}
// --------------------
// Start program proper
// --------------------
// Mode indepedent actions
switch ($action)
{
case 'export':
if ($id)
{
export($mode, $id);
}
break;
case 'add':
case 'install':
case 'details':
install($mode, $action, $id);
break;
case 'delete':
if ($id)
{
remove($mode, $id);
}
break;
}
// Mode based actions
switch ($mode)
{
// STYLES
case 'style':
switch ($action)
{
case 'activate':
case 'deactivate':
if ($id == $config['default_style'])
{
trigger_error($user->lang['DEACTIVATE_DEFAULT']);
}
$sql = 'UPDATE ' . STYLES_TABLE . '
SET style_active = ' . (($action == 'activate') ? 1 : 0) . '
WHERE style_id = ' . $id;
$db->sql_query($sql);
// Set style to default for any member using deactivated style
$sql = 'UPDATE ' . USERS_TABLE . '
SET user_style = ' . $config['default_style'] . "
WHERE user_style = $id";
$db->sql_query($sql);
break;
}
frontend('style', array('delete', 'export'));
break;
// TEMPLATES
case 'template':
$tpllist = array(
'misc' => array(
'confirm_body.html', 'faq_body.html', 'index_body.html', 'message_body.html', 'viewonline_body.html',
),
'includes' => array(
'overall_footer.html', 'overall_header.html', 'simple_footer.html', 'simple_header.html', 'searchbox.html', 'jumpbox.html',
),
'forum' => array(
'viewforum_body.html', 'viewforum_subforum.html',
),
'topic' => array(
'viewtopic_attach_body.html', 'viewtopic_body.html', 'viewtopic_print.html',
),
'group' => array(
'gcp_body.html', 'gcp_pending_info.html', 'gcp_user_body.html',
),
'user' => array(
'ucp_agreement.html', 'ucp_footer.html', 'ucp_header.html', 'ucp_main.html', 'ucp_pm_body.html', 'ucp_pm_popup.html', 'ucp_pm_preview.html', 'ucp_pm_read.html', 'ucp_prefs.html', 'ucp_profile.html', 'ucp_register.html', 'ucp_remind.html',
),
'profile' => array(
'memberlist_body.html', 'memberlist_email.html', 'memberlist_im.html', 'memberlist_view.html',
),
'mod' => array(
'mcp_forum.html', 'mcp_foruminfo.html', 'mcp_front.html', 'mcp_header.html', 'mcp_jumpbox.html', 'mcp_move.html', 'mcp_post.html', 'mcp_queue.html', 'mcp_reports.html', 'mcp_topic.html', 'mcp_viewlogs.html', 'report_body.html',
),
'search' => array(
'search_body.html', 'search_results_posts.html', 'search_results_topics.html',
),
'posting' => array(
'posting_attach_body.html', 'posting_body.html', 'posting_poll_body.html', 'posting_preview.html', 'posting_smilies.html', 'posting_topic_review.html',
),
'login' => array(
'login_body.html', 'login_forum.html',
),
'custom' => array(),
);
// Lights, Camera ...
switch ($action)
{
case 'edit':
$tplcols = (isset($_POST['tplcols'])) ? max(20, intval($_POST['tplcols'])) : 80;
$tplrows = (isset($_POST['tplrows'])) ? max(5, intval($_POST['tplrows'])) : 20;
$tplname = (isset($_POST['tplname'])) ? htmlspecialchars($_POST['tplname']) : '';
$tpldata = (!empty($_POST['tpldata'])) ? stripslashes($_POST['tpldata']) : ''; // NB : STRIPSLASHED!
if ($id)
{
$sql = 'SELECT *
FROM ' . STYLES_TPL_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
if (!(extract($db->sql_fetchrow($result))))
{
trigger_error($user->lang['NO_TEMPLATE']);
}
$db->sql_freeresult($result);
// User wants to submit data ...
if ($update)
{
// Where is the template stored?
if (!$template_storedb && is_writeable("{$phpbb_root_path}styles/$template_path/template/$tplname"))
{
if (!($fp = fopen("{$phpbb_root_path}styles/$template_path/template/$tplname", 'wb')))
{
trigger_error($user->lang['NO_TEMPLATE']);
}
$stylesheet = fwrite($fp, $tpldata);
fclose($fp);
}
else
{
$db->sql_transaction('begin');
if (!$template_storedb)
{
// We change the path to one relative to the root rather than the theme folder
$sql = 'UPDATE ' . STYLES_TPL_TABLE . '
SET template_storedb = 1
WHERE template_id = ' . $id;
$db->sql_query($sql);
$filelist = filelist("{$phpbb_root_path}styles/$template_path/template");
$filelist = array('/template' => $filelist['']);
store_templates('insert', $id, $template_path, $filelist);
}
$sql = 'UPDATE ' . STYLES_TPLDATA_TABLE . "
SET template_data = '" . $db->sql_escape($tpldata) . "', template_mtime = " . time() . "
WHERE template_id = $id
AND template_filename = '" . $db->sql_escape($tplname) . "'";
$db->sql_query($sql);
$db->sql_transaction('commit');
}
@unlink("{$phpbb_root_path}cache/tpl_{$template_name}_$tplname.$phpEx");
$error[] = $user->lang['TEMPLATE_UPDATED'];
add_log('admin', 'LOG_EDIT_TEMPLATE', $template_name, $tplname);
}
$test_ary = array();
foreach ($tpllist as $category => $tpl_ary)
{
$test_ary = array_merge($test_ary, $tpl_ary);
}
if (!$template_storedb)
{
$dp = @opendir("{$phpbb_root_path}styles/$template_path/template");
while ($file = readdir($dp))
{
if (!strstr($file, 'bbcode.') && strstr($file, '.html') && !in_array($file, $test_ary) && is_file("{$phpbb_root_path}styles/$template_path/template/$file"))
{
$tpllist['custom'][] = $file;
}
}
closedir($dp);
unset($matches);
unset($test_ary);
if ($tplname)
{
if (!($fp = fopen("{$phpbb_root_path}styles/$template_path/template/$tplname", 'r')))
{
trigger_error($user->lang['NO_TEMPLATE']);
}
$tpldata = fread($fp, filesize("{$phpbb_root_path}styles/$template_path/template/$tplname"));
fclose($fp);
}
}
else
{
$sql = 'SELECT *
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
if (!strstr($row['template_filename'], 'bbcode.') && !in_array($row['template_filename'], $test_ary))
{
$tpllist['custom'][] = $row['template_filename'];
}
if ($row['template_filename'] == $tplname)
{
$tpldata = $row['template_data'];
}
}
$db->sql_freeresult($result);
}
// List of included templates
if ($tplname)
{
preg_match_all('#<!\-\- INCLUDE (.*?) \-\->#', $tpldata, $included_tpls);
$included_tpls = $included_tpls[1];
}
}
unset($test_ary);
// Generate list of template options
$tpl_options = '';
ksort($tpllist);
foreach ($tpllist as $category => $tpl_ary)
{
sort($tpl_ary);
$tpl_options .= '<option class="sep">' . $category . '</option>';
foreach ($tpl_ary as $tpl_file)
{
$selected = ($tpl_file == $tplname) ? ' selected="selected"' : '';
$tpl_options .= '<option value="' . $tpl_file . '"' . $selected . '>' . (($category == 'custom') ? $tpl_file : $tpl_file) . '</option>';
}
}
// Output page
adm_page_header($user->lang['EDIT_TEMPLATE']);
?>
<h1><?php echo $user->lang['EDIT_TEMPLATE']; ?></h1>
<p><?php echo $user->lang['EDIT_TEMPLATE_EXPLAIN']; ?></p>
<p><?php echo $user->lang['SELECTED_TEMPLATE'] . ": <b>$template_name</b>"; ?></p>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;id=$template_id&amp;action=$action"; ?>"><table cellspacing="1" cellpadding="1" border="0" align="center">
<tr>
<td align="right"><?php echo $user->lang['SELECT_TEMPLATE']; ?>: <select name="tplname" onchange="if (this.options[this.selectedIndex].value != '') this.form.submit();"><?php echo $tpl_options; ?></select>&nbsp; <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
</tr>
<tr>
<td><table class="bg" cellspacing="1" cellpadding="4" border="0">
<tr>
<td class="cat"><?php echo $user->lang['TEXT_COLUMNS']; ?>: <input class="post" type="text" name="tplcols" size="3" maxlength="3" value="<?php echo $tplcols; ?>" /> &nbsp;<?php echo $user->lang['TEXT_ROWS']; ?>: <input class="post" type="text" name="tplrows" size="3" maxlength="3" value="<?php echo $tplrows; ?>" />&nbsp; <input class="btnlite" type="submit" value="<?php echo $user->lang['UPDATE']; ?>" /></td>
</tr>
<?php
if (sizeof($error))
{
?>
<tr>
<td class="row1" style="color:green" align="center"><?php echo implode('<br />', $error); ?></td>
</tr>
<?php
}
?>
<tr>
<th><?php echo $user->lang['RAW_HTML']; ?></th>
</tr>
<tr>
<td class="row2" align="center"><textarea class="post" style="font-family:'Courier New', monospace;font-size:9pt;line-height:125%;" cols="<?php echo $tplcols; ?>" rows="<?php echo $tplrows; ?>" name="tpldata"><?php echo htmlspecialchars($tpldata); ?></textarea></td>
</tr>
<tr>
<td class="cat" align="center"><input class="btnlite" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />&nbsp;&nbsp;<input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
</tr>
</table></td>
</tr>
</table></form>
<?php
adm_page_footer();
break;
case 'cache':
$source = (!empty($_GET['source'])) ? htmlspecialchars($_GET['source']) : '';
$file_ary = (!empty($_POST['delete'])) ? array_map('htmlspecialchars', $_POST['delete']) : '';
$sql = 'SELECT *
FROM ' . STYLES_TPL_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
if (!(extract($db->sql_fetchrow($result))))
{
trigger_error($user->lang['NO_TEMPLATE']);
}
$db->sql_freeresult($result);
$cache_prefix = "tpl_$template_path";
// User wants to delete one or more files ...
if ($_POST['update'] && $file_ary)
{
foreach ($file_ary as $file)
{
$file = "{$phpbb_root_path}cache/{$cache_prefix}_$file.html.$phpEx";
if (file_exists($file) && is_file($file))
{
@unlink($file);
}
}
unset($file_ary);
add_log('admin', 'LOG_CLEAR_TPLCACHE', $template_name);
trigger_error($user->lang['TEMPLATE_CACHE_CLEARED']);
}
// Someone wants to see the cached source ... so we'll highlight it,
// add line numbers and indent it appropriately. This could be nasty
// on larger source files ...
if ($source && file_exists("{$phpbb_root_path}cache/{$cache_prefix}_$source.html.$phpEx"))
{
adm_page_header($user->lang['TEMPLATE_CACHE']);
?>
<h1><?php echo $_GET['source']; ?></h1>
<?php
$marker = time();
$code = implode("$marker", file("{$phpbb_root_path}cache/{$cache_prefix}_$source.html.$phpEx"));
$conf = array('highlight.bg', 'highlight.comment', 'highlight.default', 'highlight.html', 'highlight.keyword', 'highlight.string');
foreach ($conf as $ini_var)
{
@ini_set($ini_var, str_replace('highlight.', 'syntax', $ini_var));
}
ob_start();
highlight_string($code);
$code = ob_get_contents();
ob_end_clean();
$str_from = array('<font color="syntax', '</font>', '<code>', '</code>','[', ']', '.');
$str_to = array('<span class="syntax', '</span>', '', '', '&#91;', '&#93;', '&#46;');
if ($remove_tags)
{
$str_from[] = '<span class="syntaxdefault">&lt;?php&nbsp;</span>';
$str_to[] = '';
$str_from[] = '<span class="syntaxdefault">&lt;?php&nbsp;';
$str_to[] = '<span class="syntaxdefault">';
$str_from[] = '<span class="syntaxdefault">?&gt;</span>';
$str_to[] = '';
}
$code = str_replace($str_from, $str_to, $code);
$code = preg_replace('#^(<span class="[a-z_]+">)\n?(.*?)\n?(</span>)$#is', '\1\2\3', $code);
$code = explode("$marker", $code);
?>
<table width="95%" cellspacing="0" cellpadding="0" border="0" align="center">
<?php
$i = $j = 1;
$length = strlen(sizeof($code));
$indent = str_repeat('&nbsp;', $length);
foreach ($code as $key => $line)
{
?>
<tr valign="top">
<td class="sourcenum" align="right"><?php echo $i; ?>&nbsp;&nbsp;</td>
<td class="source"><?php
echo $indent . $line;
$i++;
if (strlen($i) > $j)
{
$indent = substr($indent, 0, -6);
$j++;
}
unset($code[$key]);
?></td>
</tr>
<?php
}
?>
</table>
<br clear="all" />
<?php
adm_page_footer();
}
if ($template_storedb)
{
$sql = 'SELECT template_filename, template_mtime
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $template_id";
$result = $db->sql_query($sql);
$filemtime = array();
while ($row = $db->sql_fetchrow($result))
{
$filemtime[$row['template_filename']] = $row['template_mtime'];
}
$db->sql_freeresult($result);
}
// Open the cache directory and grab a list of the relevant cached templates.
// We also grab some other details such as when the compiled template was
// created, when the original template was modified and the cached filesize
if (!($dp = @opendir("{$phpbb_root_path}cache")))
{
trigger_error($user->lang['ERR_TPLCACHE_READ']);
}
$tplcache_ary = array();
while ($file = readdir($dp))
{
if (is_file($phpbb_root_path . 'cache/' . $file) && strstr($file, $cache_prefix))
{
$filename = preg_replace('#^' . $cache_prefix . '_(.*?)\.html\.' . $phpEx . '$#i', '\1', $file);
$tplcache_ary[$filename]['cache'] = filemtime("{$phpbb_root_path}cache/$file");
$tplcache_ary[$filename]['size'] = filesize("{$phpbb_root_path}cache/$file");
$tplcache_ary[$filename]['src'] = (!$template_storedb) ? filemtime("{$phpbb_root_path}styles/$template_path/template/$filename.html") : $filemtime[$filename . '.html'] ;
}
}
closedir($dp);
// Output the page
adm_page_header($user->lang['TEMPLATE_CACHE']);
?>
<script language="Javascript" type="text/javascript">
<!--
function marklist(match, status)
{
len = eval('document.' + match + '.length');
for (i = 0; i < len; i++)
{
eval('document.' + match + '.elements[i].checked = ' + status);
}
}
function viewsource(url)
{
window.open(url, '_source', 'HEIGHT=550,resizable=yes,scrollbars=yes,WIDTH=750');
return false;
}
//-->
</script>
<h1><?php echo $user->lang['TEMPLATE_CACHE']; ?></h1>
<p><?php echo $user->lang['TEMPLATE_CACHE_EXPLAIN']; ?></p>
<form name="tplcache" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$action&amp;id=$template_id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th nowrap="nowrap"><?php echo $user->lang['CACHE_FILENAME']; ?></th>
<th nowrap="nowrap"><?php echo $user->lang['CACHE_FILESIZE']; ?></th>
<th nowrap="nowrap"><?php echo $user->lang['CACHE_CACHED']; ?></th>
<th nowrap="nowrap"><?php echo $user->lang['CACHE_MODIFIED']; ?></th>
<th width="1%"><?php echo $user->lang['MARK']; ?></th>
</tr>
<?php
if (sizeof($tplcache_ary))
{
foreach ($tplcache_ary as $filename => $times_ary)
{
$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
?>
<tr>
<td class="<?php echo $row_class; ?>" nowrap="nowrap"><a href="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$action&amp;id=$template_id&amp;source=$filename"; ?>" onclick="viewsource('<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$action&amp;id=$template_id&amp;source=$filename"; ?>');return false"><?php echo $filename; ?></a></td>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo sprintf('%.1f KB', $times_ary['size'] / 1024); ?></td>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo $user->format_date($times_ary['cache']); ?></td>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo $user->format_date($times_ary['src']); ?></td>
<td class="<?php echo $row_class; ?>" width="1%" align="center"><input type="checkbox" name="delete[]" value="<?php echo $filename; ?>" /></td>
</tr>
<?php
}
}
else
{
?>
<tr>
<td class="row1" colspan="5" align="center"><?php echo $user->lang['NO_CACHED_TPL_FILES']; ?></td>
</tr>
<?php
}
?>
<tr>
<td class="cat" colspan="5" align="right"><input class="btnlite" type="submit" name="update" value="<?php echo $user->lang['DELETE_MARKED']; ?>" /></td>
</tr>
</table>
<table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
<tr>
<td align="right"><b><span class="gensmall"><a href="javascript:marklist('tplcache', true);" class="gensmall"><?php echo $user->lang['MARK_ALL']; ?></a> :: <a href="javascript:marklist('tplcache', false);" class="gensmall"><?php echo $user->lang['UNMARK_ALL']; ?></a></span></b></td>
</tr>
</table></form>
<?php
adm_page_footer();
break;
case 'refresh':
if ($id)
{
$sql = 'SELECT template_path, template_storedb
FROM ' . STYLES_TPL_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
trigger_error($user->lang['NO_TEMPLATE']);
}
$db->sql_freeresult($result);
if ($template_storedb && file_exists("{$phpbb_root_path}styles/$template_path/template/"))
{
$filelist = array('/' => array());
$sql = 'SELECT template_filename, template_mtime
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
if (@filemtime("{$phpbb_root_path}styles/$template_path/template/" . $row['template_filename']) > $row['template_mtime'])
{
$filelist['/'][] = $row['template_filename'];
}
}
$db->sql_freeresult($result);
store_templates('update', $id, $template_path, $filelist);
unset($filelist);
}
}
break;
}
// Front page
frontend('template', array('cache', 'details', 'refresh', 'export', 'delete'));
break;
// THEMES
case 'theme':
switch ($action)
{
case 'edit':
// General parameters
$class = (isset($_POST['classname'])) ? htmlspecialchars($_POST['classname']) : '';
$customclass = (!empty($_POST['customclass'])) ? htmlspecialchars($_POST['customclass']) : '';
$txtcols = (isset($_POST['txtcols'])) ? max(20, intval($_POST['txtcols'])) : 76;
$txtrows = (isset($_POST['txtrows'])) ? max(5, intval($_POST['txtrows'])) : 10;
$showcss = (!empty($_POST['showcss'])) ? true : ((!empty($_POST['hidecss'])) ? false : ((!empty($_GET['showcss'])) ? true : false));
// List of default classes, categorised
$base_classes = array(
'text' => array(
'body', 'p', 'h1', 'h2', 'h3', '.tabletitle', '.cattitle', '.topictitle', '.topicauthor', '.topicdetails', '.postdetails', '.postbody', '.posthilit', '.postauthor', '.mainmenu', '.nav', '.genmed', '.gensmall', '.copyright',
),
'tables' => array(
'table', 'th', '.cat', '.catdiv', 'td', '.row1', '.row2', '.row3', '.spacer', 'hr',
),
'forms' => array(
'form', 'input', 'select', 'textarea', '.post', '.btnlite', '.btnmain', '.btnbbcode',
),
'bbcode' => array(
'.b', '.u', '.i', '.color', '.size', '.code', '.quote', '.flash', '.syntaxbg', '.syntaxcomment', '.syntaxdefault', '.syntaxhtml', '.syntaxkeyword', '.syntaxstring',
),
'custom' => array(),
);
// We categorise the elements which comprise the css class so that we set
// any appropriate additional data, e.g. sizes require the scale type to be set,
// images require the relevant image be pulled and selected in the dropdown, etc.
$match_elements = array(
'colors' => array('background-color', 'color',),
'sizes' => array('font-size', 'line-height',),
'images' => array('background-image',),
'repeat' => array('background-repeat',),
'other' => array('font-weight', 'font-family', 'font-style', 'text-decoration',),
);
// Used in an sprintf statement to generate appropriate output for rawcss mode
$map_elements = array(
'colors' => '%s',
'sizes' => '%d%s',
'images' => 'url(\'./%s\')',
'repeat' => '%s',
'other' => '%s',
);
$s_hidden_fields = '';
// Do we want to edit an existing theme?
if ($id)
{
$sql = 'SELECT *
FROM ' . STYLES_CSS_TABLE . "
WHERE theme_id = $id";
$result = $db->sql_query($sql);
if (!(extract($db->sql_fetchrow($result))))
{
trigger_error($user->lang['NO_THEME']);
}
$db->sql_freeresult($result);
// Where is the CSS stored?
if (!$theme_storedb)
{
if (!($fp = fopen("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css", 'rb')))
{
trigger_error($user->lang['NO_THEME']);
}
$stylesheet = fread($fp, filesize("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"));
fclose($fp);
}
else
{
$stylesheet = &$theme_data;
}
// Pull out list of "custom" tags
$class_used = $test_ary = array();
if (preg_match_all('/^([a-z0-9\.:#>]+?)[ \t]*?\{.*?\}/msi', $stylesheet, $matches))
{
foreach ($base_classes as $category => $class_ary)
{
$test_ary = array_merge($test_ary, $class_ary);
}
foreach ($matches[1] as $value)
{
if (!in_array($value, $test_ary))
{
$base_classes['custom'][] = $value;
}
else
{
$class_used[] = $value;
}
}
unset($matches);
unset($test_ary);
}
}
// Do we have a class set? If so, we need to extract and set the relevant data
if (!empty($class))
{
// We must generate the relevant data ... what we need depends on whether
// we are looking @ the rawcss or the simplified settings and whether we
// have just selected a class. We must also cope with switching between
// simple and rawcss mode
$css_element = array();
if (!empty($_POST['rawcss']) && (!empty($_POST['hidecss']) || !empty($_POST['preview']) || $update))
{
$css_element = trim(stripslashes(htmlspecialchars(preg_replace("#;[\r\n]*#s", "\n", $_POST['rawcss']))));
$css_element = explode("\n", $css_element);
}
else if (($showcss && !empty($_POST['showcss'])) || !empty($_POST['preview']) || $update)
{
if (!empty($_POST['cssother']))
{
$css_element = explode(';', stripslashes(htmlspecialchars(trim($_POST['cssother']))));
}
foreach ($match_elements as $type => $match_ary)
{
foreach ($match_ary as $match)
{
$var = str_replace('-', '_', $match);
if (!empty($_POST[$var]))
{
$css_element[] = str_replace('_', '-', $var) . ': ' . (($type == 'sizes') ? sprintf($map_elements[$type], stripslashes($_POST[$var]), $_POST[$var . '_units']) : sprintf($map_elements[$type], stripslashes($_POST[$var])));
}
}
}
}
else if (preg_match('#^' . $class . '[ \t]*?\{(.*?)\}#ms', $stylesheet, $matches))
{
$css_element = explode(';', substr(trim($matches[1]), 0, -1));
}
$css_element = preg_replace('#^\s*(.*?)\s*$#', '\1', $css_element);
// User wants to submit data ...
if ($update || $customclass)
{
if ($update)
{
$updated_element = trim(implode('; ', $css_element)) . ';';
if (preg_match('#^' . $class . '[ \t]*?\{(.*?)\}#ms', $stylesheet))
{
$stylesheet = preg_replace('#^(' . $class . '[ \t]*?\{).*?(\})#m', '\1 ' . $updated_element . ' \2', $stylesheet);
}
$error[] = $user->lang['THEME_UPDATED'];
}
else
{
// Check custom class name is valid
if (!preg_match('/^[a-z0-9#:\.]+$/i', $customclass))
{
$error[] = $user->lang['THEME_ERR_CLASS_CHARS'];
}
else
{
$stylesheet .= "\n$customclass { }";
$base_classes['custom'][] = $customclass;
$error[] = $user->lang['THEME_CLASS_ADDED'];
}
}
// Where is the CSS stored?
if (!$storedb && is_writeable("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"))
{
// Grab template data
if (!($fp = fopen("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css", 'wb')))
{
trigger_error($user->lang['NO_THEME']);
}
$stylesheet = fwrite($fp, $stylesheet);
fclose($fp);
}
else
{
// We change the path to one relative to the root rather than the theme folder
$sql_ary = array(
'theme_storedb' => 1,
'theme_data' => str_replace('./', "styles/$theme_path/theme/", $stylesheet),
);
$sql = 'UPDATE ' . STYLES_CSS_TABLE . '
SET ' . $db->sql_build_array('UPDATE', $sql_ary) . '
WHERE theme_id = ' . $id;
$db->sql_query($sql);
}
$cache->destroy('sql', STYLES_CSS_TABLE);
add_log('admin', 'LOG_EDIT_THEME', $theme_name);
}
// I guess really this needs some basic examples, pulled from subSilver
// to demonstrate the default classes. Other, custom classes can just use
// the div/span and some text? This is gonna get nasty :(
if (!empty($_POST['preview']))
{
// Temp, just to get this out of the way
theme_preview($theme_path, $stylesheet, $class, $css_element);
exit;
}
// Here we pull out the appropriate class entry then proceed to pull it apart,
// setting appropriate variables to their respective values. We only match
// certain css elements, the rest are "hidden" and can be accessed by exposing
// the raw css
if (!$showcss)
{
foreach ($match_elements as $type => $match_ary)
{
foreach ($match_ary as $match)
{
$var = str_replace('-', '_', $match);
$$var = '';
if (sizeof($css_element))
{
foreach ($css_element as $key => $element)
{
if (preg_match('#^' . preg_quote($match, '#') . ':[ \t]*?(.*?)$#', $element, $matches))
{
switch ($type)
{
case 'sizes':
if (preg_match('#(.*?)(px|%|em|pt)#', $matches[1], $matches))
{
${$var . '_units'} = trim($matches[2]);
}
$$var = trim($matches[1]);
break;
case 'images':
if (preg_match('#url\(\'(.*?)\'\)#', $matches[1], $matches))
{
$$var = trim($matches[1]);
$$var = str_replace('./', $theme_name . '/', $$var);
}
break;
default:
$$var = trim($matches[1]);
}
// Remove this element from array
unset($css_element[$key]);
break;
}
}
}
}
}
// Any remaining elements must be custom data so we save that
// in a hidden field
if (sizeof($css_element))
{
$s_hidden_fields .= '<input type="hidden" name="cssother" value="' . addslashes(implode('; ', $css_element)) . '" />';
}
}
}
// End of class element variable setting
// Generate list of class options
$class_options = '';
foreach ($base_classes as $category => $class_ary)
{
$class_options .= '<option class="sep">' . $user->lang['CSS_CAT_' . strtoupper($category)] . '</option>';
foreach ($class_ary as $class_name)
{
$used = (in_array($class_name, $class_used) || $category == 'custom') ? ' style="color:red"' : '';
$selected = ($class_name == $class) ? ' selected="selected"' : '';
$class_options .= '<option' . $used . ' value="' . $class_name . '"' . $selected . '>' . (($category == 'custom') ? $class_name : $user->lang['CSS_' . str_replace('.', '', strtoupper($class_name))]) . '</option>';
}
}
unset($class_used);
// Grab list of potential images for class backgrounds
$imglist = filelist("{$phpbb_root_path}styles/$theme_path/theme");
$bg_imglist = '';
foreach ($imglist as $path => $img_ary)
{
foreach ($img_ary as $img)
{
$img = ((substr($path, 0, 1) == '/') ? substr($path, 1) : $path) . $img;
$selected = (preg_match('#' . preg_quote($img) . '$#', $background_image)) ? ' selected="selected"' : '';
$bg_imglist .= '<option value="' . htmlspecialchars($img) . '"' . $selected . '>' . $img . '</option>';
}
}
$bg_imglist = '<option value=""' . (($edit_img == '') ? ' selected="selected"' : '') . '>' . $user->lang['NONE'] . '</option>' . $bg_imglist;
unset($imglist);
// Output the page
adm_page_header($user->lang['EDIT_THEME']);
?>
<script language="javascript" type="text/javascript">
<!--
function swatch(field)
{
window.open('./swatch.<?php echo "$phpEx?form=style&name="; ?>' + field, '_swatch', 'HEIGHT=115,resizable=yes,scrollbars=no,WIDTH=636');
return false;
}
function csspreview()
{
if (document.myvar == 'preview')
{
window.open('', '_preview', 'HEIGHT=400,resizable=yes,scrollbars=yes,WIDTH=500');
document.forms['style'].target = '_preview';
}
else
{
document.forms['style'].target = '_self';
}
document.myvar='';
return true;
}
//-->
</script>
<h1><?php echo $user->lang['EDIT_THEME']; ?></h1>
<p><?php echo $user->lang['EDIT_THEME_EXPLAIN']; ?></p>
<p><?php echo $user->lang['SELECTED_THEME'] . ": <b>$theme_name</b>"; ?></p>
<?php
if ($showcss)
{
?>
<h3><?php echo $user->lang['SHOW_RAW_CSS_NOTE']; ?></h3>
<p><?php echo $user->lang['SHOW_RAW_CSS_EXPLAIN']; ?></p>
<?php
}
?>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$action&amp;id=$id&amp;showcss=$showcss"; ?>" onsubmit="return csspreview()"><table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
<tr>
<td align="right"><?php echo $user->lang['SELECT_CLASS']; ?>: <select name="classname" onchange="if (this.options[this.selectedIndex].value != ''){ csspreview(); this.form.submit(); }"><?php echo $class_options; ?></select>&nbsp; <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
</tr>
<tr>
<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
<?php
if ($showcss)
{
?>
<tr>
<th colspan="2"><?php echo $user->lang['RAW_CSS']; ?></th>
</tr>
<?php
if (sizeof($error) && ($update || $customclass))
{
echo '<tr><td class="row1" colspan="2" align="center"><span class="gen" style="color:green" align="center">' . implode('<br />', $error) . '</span></td></tr>';
}
?>
<tr>
<td class="row2" colspan="2" align="center"><textarea class="post" style="font-family:'Courier New', monospace;font-size:10pt;line-height:125%;" name="rawcss" rows="<?php echo $txtrows; ?>" cols="<?php echo $txtcols; ?>"><?php echo (sizeof($css_element)) ? implode(";\n", $css_element) . ';' : ''; ?></textarea></td>
</tr>
<?php
}
else
{
?>
<tr>
<th><?php echo $user->lang['CSS_PARAMETER']; ?></th>
<th><?php echo $user->lang['CSS_VALUE']; ?></th>
</tr>
<?php
if (sizeof($error) && ($update || $customclass))
{
echo '<tr><td class="row1" colspan="2" align="center"><span class="gen" style="color:green" align="center">' . implode('<br />', $error) . '</span></td></tr>';
}
?>
<tr>
<td class="row3" colspan="2"><b><?php echo $user->lang['BACKGROUND']; ?></b></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['BACKGROUND_COLOUR']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['COLOUR_EXPLAIN']; ?></span></td>
<td class="row2"><table cellspacing="0" cellpadding="0" border="0"><tr><td><input class="post" type="text" name="background_color" value="<?php echo $background_color; ?>" size="8" maxlength="14" onchange="document.all.stylebgcolor.bgColor=this.form.background_color.value" /></td><td>&nbsp;</td><td bgcolor="<?php echo $background_color; ?>" id="stylebgcolor" style="border:solid 1px black;"><img src="../images/spacer.gif" width="45" height="15" alt="" /></td><td class="gensmall"> &nbsp; [ <a href="swatch.<?php echo $phpEx; ?>" onclick="swatch('background_color');return false" target="_swatch"><?php echo $user->lang['COLOUR_SWATCH']; ?></a> ]</td></tr></table></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['BACKGROUND_IMAGE']; ?>:</b></td>
<td class="row2"><select name="background_image"><?php echo $bg_imglist ?></select></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['BACKGROUND_REPEAT']; ?>:</b></td>
<td class="row2"><select name="background_repeat"><?php
foreach (array('' => '------', 'none' => $user->lang['REPEAT_NO'], 'repeat-x' => $user->lang['REPEAT_X'], 'repeat-y' => $user->lang['REPEAT_Y'], 'both' => $user->lang['REPEAT_ALL']) as $cssvalue => $cssrepeat)
{
echo '<option value="' . $cssvalue . '"' . (($background_repeat == $cssvalue) ? ' selected="selected"' : '') . '>' . $cssrepeat . '</option>';
}
?></select></td>
</tr>
<tr>
<td class="row3" colspan="2"><b><?php echo $user->lang['FOREGROUND']; ?></b></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['FONT_COLOUR']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['COLOUR_EXPLAIN']; ?></span></td>
<td class="row2"><table cellspacing="0" cellpadding="0" border="0"><tr><td><input class="post" type="text" name="color" value="<?php echo $color; ?>" size="8" maxlength="14" onchange="document.all.stylecolor.bgColor=this.form.color.value" /></td><td>&nbsp;</td><td bgcolor="<?php echo $color; ?>" id="stylecolor" style="border:solid 1px black;"><img src="../images/spacer.gif" width="45" height="15" alt="" /></td><td class="gensmall"> &nbsp; [ <a href="swatch.<?php echo $phpEx; ?>" onclick="swatch('color');return false" target="_swatch"><?php echo $user->lang['COLOUR_SWATCH']; ?></a> ]</td></tr></table></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['FONT_FACE']; ?>:</b> <br /><span class="gensmall"><?php echo $user->lang['FONT_FACE_EXPLAIN']; ?></span></td>
<td class="row2"><input class="post" type="text" name="font_family" value="<?php echo $font_family; ?>" size="40" maxlength="255" /></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['FONT_SIZE']; ?>:</b></td>
<td class="row2"><input class="post" type="text" name="font_size" value="<?php echo $font_size; ?>" size="3" maxlength="3" /> <select name="font_size_units"><?php
foreach (array('pt', 'px', 'em', '%') as $units)
{
echo '<option value="' . $units . '"' . (($font_size_units == $units) ? ' selected="selected"' : '') . '>' . $units . '</option>';
}
?></select></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['BOLD']; ?>:</b></td>
<td class="row2"><input type="radio" name="font_weight" value="bold"<?php echo (!empty($font_weight) && $font_weight == 'bold') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?> &nbsp; <input type="radio" name="font_weight" value="normal"<?php echo (!empty($font_weight) && $font_weight == 'normal') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['NO']; ?> &nbsp; <input type="radio" name="font_weight" value=""<?php echo (empty($font_weight)) ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['UNSET']; ?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['ITALIC']; ?>:</b></td>
<td class="row2"><input type="radio" name="font_style" value="italic"<?php echo (!empty($font_style) && $font_style == 'italic') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?> &nbsp; <input type="radio" name="font_style" value="normal"<?php echo (!empty($font_style) && $font_style == 'normal') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['NO']; ?> &nbsp; <input type="radio" name="font_style" value=""<?php echo (empty($font_style)) ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['UNSET']; ?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['UNDERLINE']; ?>:</b></td>
<td class="row2"><input type="radio" name="text_decoration" value="underline"<?php echo (!empty($text_decoration) && $text_decoration == 'underline') ? ' checked="checked"' : ''; ?> /> <?php echo $user->lang['YES']; ?> &nbsp; <input type="radio" name="text_decoration" value="none"<?php echo (!empty($text_decoration) && $text_decoration == 'none') ? ' checked="checked"' : ''; ?>/> <?php echo $user->lang['NO']; ?> &nbsp; <input type="radio" name="text_decoration" value=""<?php echo (empty($text_decoration)) ? ' checked="checked"' : ''; ?>/> <?php echo $user->lang['UNSET']; ?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['LINE_SPACING']; ?>:</b></td>
<td class="row2"><input class="post" type="text" name="line_height" value="<?php echo $line_height; ?>" size="3" maxlength="3" /> <select name="line_height_units"><?php
foreach (array('pt', 'px', 'em', '%') as $units)
{
echo '<option value="' . $units . '"' . (($line_height_units == $units) ? ' selected="selected"' : '') . '>' . $units . '</option>';
}
?></select></td>
</tr>
<?php
}
?>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>"; />&nbsp;&nbsp;<input class="btnlite" type="submit" name="preview" value="<?php echo $user->lang['PREVIEW']; ?>" onclick="document.myvar='preview';" />&nbsp;&nbsp;<input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" />&nbsp;&nbsp;<?php
echo ($showcss) ? '<input class="btnlite" type="submit" name="hidecss" value="' . $user->lang['HIDE_RAW_CSS'] . '" />' : '<input class="btnlite" type="submit" name="showcss" value="' . $user->lang['SHOW_RAW_CSS'] . '" />';
echo $s_hidden_fields;
?></td>
</tr>
</table></td>
</tr>
</table>
<h1><?php echo $user->lang['CUSTOM_CLASS']; ?></h1>
<p><?php echo $user->lang['CUSTOM_CLASS_EXPLAIN']; ?></p>
<table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
<tr>
<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="2"><?php echo $user->lang['CUSTOM_CLASS']; ?></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['CSS_CLASS_NAME']; ?>:</b></td>
<td class="row2"><input class="post" type="text" name="customclass" value="" maxlength="15" size="15" /></td>
</tr>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="addclass" value="<?php echo $user->lang['SUBMIT']; ?>" />&nbsp;&nbsp;<input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
</tr>
</table>
</td>
</tr>
</table></form>
<?php
adm_page_footer();
break;
}
// Front page
frontend('theme', array('details', 'refresh', 'export', 'delete'));
break;
// IMAGESETS
case 'imageset':
$imglist = array(
'buttons' => array(
'btn_post', 'btn_reply', 'btn_locked', 'btn_quote', 'btn_edit', 'btn_delete', 'btn_report', 'btn_post_pm', 'btn_reply_pm', 'btn_profile', 'btn_pm', 'btn_ip', 'btn_search', 'btn_email', 'btn_www', 'btn_icq', 'btn_aim', 'btn_yim', 'btn_msnm', 'btn_jabber', 'btn_online', 'btn_offline',
),
'icons' => array(
'icon_unapproved', 'icon_reported', 'icon_attach', 'icon_post', 'icon_post_new', 'icon_post_latest', 'icon_post_newest',),
'forums' => array(
'forum', 'forum_new', 'forum_locked', 'forum_link', 'sub_forum', 'sub_forum_new',),
'folders' => array(
'folder', 'folder_posted', 'folder_new', 'folder_new_posted', 'folder_hot', 'folder_hot_posted', 'folder_hot_new', 'folder_hot_new_posted', 'folder_locked', 'folder_locked_posted', 'folder_locked_new', 'folder_locked_new_posted', 'folder_sticky', 'folder_sticky_posted', 'folder_sticky_new', 'folder_sticky_new_posted', 'folder_announce', 'folder_announce_posted', 'folder_announce_new', 'folder_announce_new_posted',),
'polls' => array(
'poll_left', 'poll_center', 'poll_right',),
);
switch ($action)
{
case 'edit':
$imgname = (!empty($_POST['imgname'])) ? htmlspecialchars($_POST['imgname']) : '';
$imgpath = (isset($_POST['imgpath'])) ? htmlspecialchars($_POST['imgpath']) : '';
$imgsize = (!empty($_POST['imgsize'])) ? true : false;
$imgwidth = (isset($_POST['imgwidth'])) ? intval($_POST['imgwidth']) : '';
if ($id)
{
$sql_select = ($imgname) ? ", $imgname" : '';
$sql = "SELECT imageset_path, imageset_name, imageset_copyright$sql_select
FROM " . STYLES_IMAGE_TABLE . "
WHERE imageset_id = $id";
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
trigger_error($user->lang['NO_IMAGESET']);
}
$db->sql_freeresult($result);
// Check to see whether the selected image exists in the table
$valid_name = false;
foreach ($imglist as $category => $img_ary)
{
if (in_array($imgname, $img_ary))
{
$valid_name = true;
break;
}
}
if (!$valid_name)
{
$error[] = $user->lang['NO_IMAGE'];
}
if ($update && $imgpath)
{
if (!sizeof($error))
{
// If imgwidth and imgheight are non-zero grab the actual size
// from the image itself ... we ignore width settings for the poll center
// image
$imgwidth = $imgheight = '';
if ($imgsize)
{
list($imgwidth, $imgheight) = getimagesize("{$phpbb_root_path}styles/$imageset_path/imageset/$imgpath");
$imgwidth = ($imgname != 'poll_center') ? " width=\"$imgwidth\"" : '';
$imgheight = " height=\"$imgheight\"";
}
$imgpath = '"styles/' . $imageset_path . '/imageset/' . preg_replace('#^(.*?)/(.*?)$#', '{LANG}/\2', $imgpath) . '" border="0"' . $imgwidth . $imgheight;
$sql = 'UPDATE ' . STYLES_IMAGE_TABLE . "
SET $imgname = '$imgpath'
WHERE imageset_id = $id";
$db->sql_query($sql);
$cache->destroy('sql', STYLES_IMAGE_TABLE);
add_log('admin', 'LOG_EDIT_IMAGESET', $imageset_name);
$error[] = $user->lang['IMAGESET_UPDATED'];
$$imgname = $imgpath;
}
}
$test_ary = array();
foreach ($imglist as $category => $img_ary)
{
foreach ($img_ary as $img)
{
if (!empty($$img))
{
$test_ary[] = preg_replace('#^"styles/' . $imageset_path . '/imageset/(\{LANG\}/)?(.*?)".*$#', '\2', $$img);
}
}
}
unset($test_ary);
}
// Generate list of image options
$img_options = '';
foreach ($imglist as $category => $img_ary)
{
$img_options .= (sizeof($img_ary)) ? '<option class="sep" value="">' . $user->lang['IMG_CAT_' . strtoupper($category)] . '</option>' : '';
foreach ($img_ary as $img)
{
$selected = ($img == $imgname) ? ' selected="selected"' : '';
$img_options .= '<option value="' . $img . '"' . $selected . '>' . (($category == 'custom') ? $img : $user->lang['IMG_' . strtoupper($img)]) . '</option>';
}
}
// TODO
// Check whether localised buttons exist in admins language first
// Clean up this code
$imglang = '';
$imagesetlist = array('nolang' => array(), 'lang' => array());
$dp = opendir("{$phpbb_root_path}styles/$imageset_path/imageset");
while ($file = readdir($dp))
{
if (!is_file($file) && !is_link($file) && $file{0} != '.' && strtoupper($file) != 'CVS' && !sizeof($imagesetlist['lang']))
{
$dp2 = opendir("{$phpbb_root_path}styles/$imageset_path/imageset/$file");
while ($file2 = readdir($dp2))
{
$imglang = $file;
if (preg_match('#\.(gif|jpg|png)$#', $file2))
{
$imagesetlist['lang'][] = "$file/$file2";
}
}
closedir($dp2);
}
else if (preg_match('#\.(gif|jpg|png)$#', $file))
{
$imagesetlist['nolang'][] = $file;
}
}
closedir($dp);
$imagesetlist_options = '';
foreach ($imagesetlist as $type => $img_ary)
{
$imagesetlist_options .= ($type == 'lang') ? '<option class="sep" value="">' . $user->lang['LOCALISED_IMAGES'] . '</option>' : '<option class="sep" value="">' . $user->lang['GLOBAL_IMAGES'] . '</option>';
foreach ($img_ary as $img)
{
$imgvalue = preg_replace('#^.*?/(.*?)$#', '\1', $img);
$selected = (strstr($$imgname, $imgvalue)) ? ' selected="selected"' : '';
$imagesetlist_options .= '<option value="' . htmlspecialchars($img) . '"' . $selected . '>' . $imgvalue . '</option>';
}
}
$imagesetlist_options = '<option value=""' . (($edit_img == '') ? ' selected="selected"' : '') . '>' . $user->lang['NONE'] . '</option>' . $imagesetlist_options;
unset($imagesetlist);
$imgsize_no = $imgsize_yes = '';
if ($imgsize || preg_match('# height="[0-9]+?#', $$imgname))
{
$imgsize_yes = ' checked="checked"';
}
else
{
$imgsize_no = ' checked="checked"';
}
adm_page_header($user->lang['EDIT_IMAGESET']);
?>
<script language="javascript" type="text/javascript" defer="defer">
<!--
function update_image(newimage)
{
document.newimg.src = (newimage) ? "<?php echo "{$phpbb_root_path}styles/$imageset_path/imageset/"; ?>" + newimage : "images/no_image.png";
}
//-->
</script>
<h1><?php echo $user->lang['EDIT_IMAGESET']; ?></h1>
<p><?php echo $user->lang['EDIT_IMAGESET_EXPLAIN']; ?></p>
<p><?php echo $user->lang['SELECTED_IMAGESET'] . ": <b>$imageset_name</b>"; ?></p>
<form method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;id=$id&amp;action=$action"; ?>"><table width="95%" cellspacing="1" cellpadding="1" border="0" align="center">
<tr>
<td align="right"><?php echo $user->lang['SELECT_IMAGE']; ?>: <select name="imgname" onchange="this.form.submit(); "><?php echo $img_options; ?></select>&nbsp; <input class="btnlite" type="submit" value="<?php echo $user->lang['SELECT']; ?>" tabindex="100" /></td>
</tr>
<tr>
<td><table class="bg" width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="2"><?php echo $user->lang['EDIT_IMAGESET']; ?></th>
</tr>
<?php
if (sizeof($error))
{
?>
<tr>
<td class="row1" colspan="2" align="center"><?php echo ($update) ? '<span style="color:green">' . implode('<br />', $error) . '</span>' : implode('<br />', $error); ?></td>
</tr>
<?php
}
?>
<tr>
<td class="row1" colspan="2" align="center"><table width="100%" cellspacing="2" cellpadding="2" border="0">
<tr>
<td width="50%" align="center"><img src="<?php
echo (!empty($$imgname)) ? str_replace('"styles/', '../styles/', str_replace('{LANG}', $imglang, $$imgname)) : 'images/no_image.png';
?>" /></td>
<td width="50%" align="center"><img src="<?php
echo (!empty($$imgname)) ? preg_replace('#(width|height)="[0-9]+?"#', '', str_replace('"styles/', '../styles/', str_replace('{LANG}', $imglang, $$imgname))) : 'images/no_image.png';
?>" name="newimg" /></td>
</tr>
<tr>
<td class="gensmall" align="center"><?php echo $user->lang['CURRENT_IMAGE']; ?></td>
<td class="gensmall" align="center"><?php echo $user->lang['SELECTED_IMAGE']; ?></td>
</tr>
</table></td>
</tr>
<tr>
<th width="40%"><?php echo $user->lang['IMAGE_PARAMETER']; ?></th>
<th><?php echo $user->lang['IMAGE_VALUE']; ?></th>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['IMAGE']; ?>: </b></td>
<td class="row2"><select name="imgpath" onchange="update_image(this.options[selectedIndex].value);"><?php echo $imagesetlist_options; ?></select></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['DIMENSIONS']; ?>: </b><br /><span class="gensmall"><?php echo $user->lang['DIMENSIONS_EXPLAIN']; ?></span></td>
<td class="row2"><input type="radio" name="imgsize" value="1"<?php echo $imgsize_yes; ?> /> <?php echo $user->lang['YES']; ?>&nbsp;&nbsp;<input type="radio" name="imgsize" value="0"<?php echo $imgsize_no; ?> /> <?php echo $user->lang['NO']; ?></td>
</tr>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />&nbsp;&nbsp;<input class="btnmain" type="reset" value="<?php echo $user->lang['RESET']; ?>" /></td>
</tr>
</table></td>
</tr>
</table></form>
<?php
adm_page_footer();
break;
}
// Front page
frontend('imageset', array('details', 'delete', 'export'));
break;
}
exit;
// ---------
// FUNCTIONS
//
function frontend($type, $options)
{
global $phpbb_root_path, $phpEx, $SID, $config, $db, $user, $mode;
switch ($type)
{
case 'style':
$sql_from = STYLES_TABLE;
break;
case 'template':
$sql_from = STYLES_TPL_TABLE;
break;
case 'theme':
$sql_from = STYLES_CSS_TABLE;
break;
case 'imageset':
$sql_from = STYLES_IMAGE_TABLE;
break;
}
$l_prefix = strtoupper($type);
$thspan = ($type != 'style') ? sizeof($options) + 1: sizeof($options) + 2;
$tdspan = ($type != 'style') ? $thspan + 2 : $thspan + 3;
// Output list of themes
adm_page_header($user->lang[$l_prefix . 'S']);
?>
<h1><?php echo $user->lang[$l_prefix . 'S']; ?></h1>
<p><?php echo $user->lang[$l_prefix . 'S_EXPLAIN']; ?></p>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th nowrap="nowrap"><?php echo $user->lang[$l_prefix . '_NAME']; ?></th>
<?php
if ($type == 'style')
{
?>
<th nowrap="nowrap"><?php echo $user->lang['STYLE_USED_BY']; ?></th>
<?php
}
?>
<th colspan="<?php echo $thspan; ?>" nowrap="nowrap"><?php echo $user->lang['OPTIONS']; ?></th>
</tr>
<tr>
<td class="row3" colspan="<?php echo $tdspan; ?>"><b><?php echo $user->lang['INSTALLED_' . $l_prefix]; ?></b></td>
</tr>
<?php
if ($type == 'style')
{
$sql = 'SELECT user_style, COUNT(user_style) AS style_count
FROM ' . USERS_TABLE . '
GROUP BY user_style';
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
$style_count[$row['user_style']] = $row['style_count'];
}
$db->sql_freeresult($result);
}
$sql = "SELECT *
FROM $sql_from";
$result = $db->sql_query($sql);
$installed = array();
$basis_options = '<option class="sep" value="">' . $user->lang['OPTIONAL_BASIS'] . '</option>';
while ($row = $db->sql_fetchrow($result))
{
$installed[] = $row[$type . '_name'];
$basis_options .= '<option value="' . $row[$type . '_id'] . '">' . $row[$type . '_name'] . '</option>';
$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
$tagstyle = ($type == 'style' && $row['style_id'] == $config['default_style']) ? '*' : '';
?>
<tr>
<td class="<?php echo $row_class; ?>" width="100%"><a href="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=" . (($type == 'style') ? 'details' : 'edit') . "&amp;id=" . $row[$type . '_id']; ?>"><?php echo $row[$type . '_name']; ?></a> <?php echo $tagstyle; ?></td>
<?php
if ($type == 'style')
{
$stylevis = (!$row['style_active']) ? 'activate' : 'deactivate';
?>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap"><?php echo (!empty($style_count[$row['style_id']])) ? $style_count[$row['style_id']] : '0'; ?></td>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap">&nbsp;<a href="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$stylevis&amp;id=" . $row['style_id']; ?>"><?php echo $user->lang['STYLE_' . strtoupper($stylevis)]; ?></a>&nbsp;</td>
<?php
}
foreach ($options as $option)
{
?>
<td class="<?php echo $row_class; ?>" nowrap="nowrap">&nbsp;<a href="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=$option&amp;id=" . $row[$type . '_id']; ?>"><?php echo $user->lang[strtoupper($option)]; ?></a>&nbsp;</td>
<?php
}
?>
<td class="<?php echo $row_class; ?>" align="center" nowrap="nowrap">&nbsp;<a href="<?php echo "{$phpbb_root_path}index.$phpEx$SID&amp;$type=" . $row[$type . '_id']; ?>" target="_preview"><?php echo $user->lang['PREVIEW']; ?></a>&nbsp;</td>
</tr>
<?php
}
$db->sql_freeresult($result);
?>
<tr>
<td class="row3" colspan="<?php echo $tdspan; ?>"><b><?php echo $user->lang['UNINSTALLED_' . $l_prefix]; ?></b></td>
</tr>
<?php
$new_ary = $cfg = array();
$dp = opendir("{$phpbb_root_path}styles");
while ($file = readdir($dp))
{
$subpath = ($type != 'style') ? "$type/" : '';
if ($file{0} != '.' && file_exists("{$phpbb_root_path}styles/$file/$subpath$type.cfg"))
{
if ($cfg = file("{$phpbb_root_path}styles/$file/$subpath$type.cfg"))
{
$name = trim($cfg[0]);
if (!in_array($name, $installed))
{
$new_ary[$i]['path'] = $file;
$new_ary[$i]['name'] = $name;
$i++;
}
}
}
}
unset($installed);
@closedir($dp);
if (sizeof($new_ary))
{
foreach ($new_ary as $key => $cfg)
{
$row_class = ($row_class != 'row1') ? 'row1' : 'row2';
?>
<tr>
<td class="<?php echo $row_class; ?>"><?php echo $cfg['name']; ?></td>
<td class="<?php echo $row_class; ?>" colspan="<?php echo ($type != 'style') ? $thspan : $thspan + 1 ?>" align="center"><a href="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=install&amp;path=" . urlencode($cfg['path']); ?>"><?php echo $user->lang['INSTALL']; ?></a></td>
</tr>
<?php
}
}
else
{
?>
<tr>
<td class="row1" colspan="<?php echo $tdspan; ?>" align="center"><?php echo $user->lang['NO_UNINSTALLED_' . $l_prefix]; ?></td>
</tr>
<?php
}
unset($new_ary);
?>
<tr>
<td class="cat" colspan="<?php echo $tdspan; ?>" align="right"><?php echo $user->lang['CREATE_' . $l_prefix]; ?>: <input class="post" type="text" name="name" value="" maxlength="30" size="25" /> <?php echo $user->lang['FROM']; ?> <select name="basis"><?php echo $basis_options; ?></select> <input class="btnmain" type="submit" name="add" value="<?php echo $user->lang['SUBMIT']; ?>" /></td>
</tr>
</table></form>
<?php
adm_page_footer();
}
function remove($type, $id)
{
global $phpbb_root_path, $phpEx, $SID, $config, $db, $cache, $user, $mode, $action;
$new_id = (!empty($_POST['newid'])) ? intval($_POST['newid']) : false;
$deletefs = (!empty($_POST['deletefs'])) ? true : false;
$update = (isset($_POST['update'])) ? true : false;
switch ($type)
{
case 'style':
$sql_from = STYLES_TABLE;
$sql_select = 'style_name';
break;
case 'template':
$sql_from = STYLES_TPL_TABLE;
$sql_select = 'template_name, template_path, template_storedb';
break;
case 'theme':
$sql_from = STYLES_CSS_TABLE;
$sql_select = 'theme_name, theme_path, theme_storedb';
break;
case 'imageset':
$sql_from = STYLES_IMAGE_TABLE;
$sql_select = 'imageset_name, imageset_path';
break;
}
$l_prefix = strtoupper($type);
$sql = "SELECT $sql_select
FROM $sql_from
WHERE {$type}_id = $id";
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
trigger_error($user->lang['NO_' . $l_prefix]);
}
$path = ($type != 'style') ? ${$type . '_path'} : '';
$storedb = (isset(${$type . '_storedb'})) ? ${$type . '_storedb'} : false;
$sql = "SELECT {$type}_id, {$type}_name
FROM $sql_from
WHERE {$type}_id <> $id
ORDER BY {$type}_id";
$result = $db->sql_query($sql);
$options = '';
if (!($row = $db->sql_fetchrow($result)))
{
trigger_error($user->lang['ONLY_' . $l_prefix]);
}
do
{
$options .= '<option value="' . $row[$type . '_id'] . '">' . $row[$type . '_name'] . '</option>';
}
while ($row = $db->sql_fetchrow($result));
if ($update)
{
$sql = "DELETE FROM $sql_from
WHERE {$type}_id = $id";
$db->sql_query($sql);
$onfs = 0;
if ($type == 'style')
{
$sql = 'UPDATE ' . USERS_TABLE . "
SET user_style = $new_id
WHERE user_style = $id";
$db->sql_query($sql);
}
else
{
$sql = 'UPDATE ' . STYLES_TABLE . "
SET {$type}_id = $new_id
WHERE {$type}_id = $id";
$db->sql_query($sql);
if ($deletefs && is_writeable("{$phpbb_root_path}styles/$path/{$type}"))
{
$filelist = filelist("{$phpbb_root_path}styles/$path/{$type}", '', '*');
krsort($filelist);
foreach ($filelist as $subpath => $file_ary)
{
$subpath = "{$phpbb_root_path}styles/$path/{$type}$subpath";
foreach ($file_ary as $file)
{
/* if (!@unlink("$subpath$file"))
{
$onfs = 1;
}
*/ }
/* if (!@rmdir($subpath))
{
$onfs = 1;
}
*/ }
}
else
{
$onfs = (file_exists("{$phpbb_root_path}styles/$path/{$type}")) ? 1 : 0;
}
}
$cache->destroy('sql', STYLES_TABLE);
add_log('admin', 'LOG_DELETE_' . $l_prefix, ${$type . '_name'});
$message = ($onfs) ? $l_prefix . '_DELETED_FS' : $l_prefix . '_DELETED';
trigger_error($user->lang[$message]);
}
// Output list of themes
adm_page_header($user->lang['DELETE_' . $l_prefix]);
?>
<h1><?php echo $user->lang['DELETE_' . $l_prefix]; ?></h1>
<p><?php echo $user->lang['DELETE_' . $l_prefix . '_EXPLAIN']; ?></p>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$type&amp;action=delete&amp;id=$id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="2"><?php echo $user->lang['DELETE_' . $l_prefix]; ?></td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_prefix . '_NAME']; ?>:</b></td>
<td class="row2"><b><?php echo ${$type . '_name'}; ?></b></td>
</tr>
<?php
if ($type != 'style' && !$storedb && is_writeable("{$phpbb_root_path}styles/$path/$type"))
{
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['DELETE_FROM_FS']; ?>: </b></td>
<td class="row2"><input type="radio" name="deletefs" value="1" /> <?php echo $user->lang['YES']; ?>&nbsp;&nbsp;<input type="radio" name="deletefs" value="0" checked="checked" /> <?php echo $user->lang['NO']; ?></td>
</tr>
<?php
}
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['REPLACE_' . $l_prefix]; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['REPLACE_' . $l_prefix . '_EXPLAIN']; ?></span></td>
<td class="row2"><select name="newid"><?php echo $options; ?></select></td>
</tr>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['DELETE']; ?>"; />&nbsp;&nbsp;<input class="btnlite" type="submit" name="cancel" value="<?php echo $user->lang['CANCEL']; ?>"; /></td>
</tr>
</table></form>
<?php
adm_page_footer();
}
// Export style or style elements
function export($mode, $id)
{
global $phpbb_root_path, $phpEx, $SID, $config, $db, $user;
$update = (isset($_POST['update'])) ? true : false;
$inc_template = (!empty($_POST['inc_template'])) ? true : false;
$inc_theme = (!empty($_POST['inc_theme'])) ? true : false;
$inc_imageset = (!empty($_POST['inc_imageset'])) ? true : false;
$format = (isset($_POST['format'])) ? htmlspecialchars($_POST['format']) : '';
$store = (!empty($_POST['store'])) ? true : false;
switch ($mode)
{
case 'style':
if ($update && $inc_template + $inc_theme + $inc_imageset < 1)
{
$error[] = $user->lang['STYLE_ERR_MORE_ELEMENTS'];
}
$style_id = &$id;
$name = 'style_name';
$sql_select = 's.style_id, s.style_name, s.style_copyright';
$sql_select .= ($inc_template) ? ', t.*' : ', t.template_name';
$sql_select .= ($inc_theme) ? ', c.*' : ', c.theme_name';
$sql_select .= ($inc_imageset) ? ', i.*' : ', i.imageset_name';
$sql_from = STYLES_TABLE . ' s, ' . STYLES_TPL_TABLE . ' t, ' . STYLES_CSS_TABLE . ' c, ' . STYLES_IMAGE_TABLE . ' i';
$sql_where = "s.style_id = $id AND t.template_id = s.template_id AND c.theme_id = s.theme_id AND i.imageset_id = s.imageset_id";
$l_prefix = 'STYLE';
break;
case 'template':
$template_id = &$id;
$name = 'template_name';
$sql_select = '*';
$sql_from = STYLES_TPL_TABLE;
$sql_where = "template_id = $id";
$l_prefix = 'TEMPLATE';
break;
case 'theme':
$theme_id = &$id;
$name = 'theme_name';
$sql_select = '*';
$sql_from = STYLES_CSS_TABLE;
$sql_where = "theme_id = $id";
$l_prefix = 'THEME';
break;
case 'imageset':
$imageset_id = &$id;
$name = 'imageset_name';
$sql_select = '*';
$sql_from = STYLES_IMAGE_TABLE;
$sql_where = "imageset_id = $id";
$l_prefix = 'IMAGESET';
break;
}
// Lets do a merry dance ... either that or generate the archive
if ($update && !sizeof($error))
{
$sql = "SELECT $sql_select
FROM $sql_from
WHERE $sql_where";
$result = $db->sql_query($sql);
if (!($style_row = ($db->sql_fetchrow($result))))
{
trigger_error($user->lang['NO_' . $l_prefix]);
}
$db->sql_freeresult($result);
$var_ary = array('style_id', 'style_name', 'style_copyright', 'template_id', 'template_name', 'template_path', 'template_copyright', 'template_storedb', 'bbcode_bitfield', 'theme_id', 'theme_name', 'theme_path', 'theme_copyright', 'theme_storedb', 'theme_mtime', 'theme_data', 'imageset_id', 'imageset_name', 'imageset_path', 'imageset_copyright');
foreach ($var_ary as $var)
{
$$var = (!empty($style_row[$var])) ? $style_row[$var] : '';
unset($style_row[$var]);
}
$files = $data = array();
if ($mode == 'style')
{
$style_cfg = addslashes($style_name) . "\n";
$style_cfg .= addslashes($style_copyright) . "\n";
$style_cfg .= addslashes($config['version']) . "\n";
$style_cfg .= ((!$inc_template) ? addslashes($template_name) : '') . "\n";
$style_cfg .= ((!$inc_theme) ? addslashes($theme_name) : '') . "\n";
$style_cfg .= ((!$inc_imageset) ? addslashes($imageset_name) : '');
$data[] = array(
'src' => $style_cfg,
'prefix' => 'style.cfg'
);
unset($style_cfg);
}
// Export template core code
if ($mode == 'template' || $inc_template)
{
$template_cfg = addslashes($template_name) . "\n";
$template_cfg .= addslashes($template_copyright) . "\n";
$template_cfg .= addslashes($config['version']) . "\n";
$template_cfg .= addslashes($bbcode_bitfield);
$data[] = array(
'src' => $template_cfg,
'prefix' => 'template/template.cfg'
);
// This is potentially nasty memory-wise ...
if (!$template_storedb)
{
$files[] = array(
'src' => "styles/$template_path/template/",
'prefix-' => "styles/$template_path/",
'prefix+' => false,
'exclude' => 'template.cfg'
);
}
else
{
$sql = 'SELECT template_filename, template_data
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $template_id";
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
$data[] = array(
'src' => $row['template_data'],
'prefix' => 'template/' . $row['template_filename']
);
}
$db->sql_freeresult($result);
}
unset($template_cfg);
}
// Export theme core code
if ($mode == 'theme' || $inc_theme)
{
$theme_cfg = addslashes($theme_name) . "\n";
$theme_cfg .= addslashes($theme_copyright) . "\n";
$theme_cfg .= addslashes($config['version']);
$files[] = array(
'src' => "styles/$theme_path/theme/",
'prefix-' => "styles/$theme_path/",
'prefix+' => false,
'exclude' => ($theme_storedb) ? 'stylesheet.css,theme.cfg' : 'theme.cfg'
);
$data[] = array(
'src' => $theme_cfg,
'prefix' => 'theme/theme.cfg'
);
if ($theme_storedb)
{
$data[] = array(
'src' => $theme_data,
'prefix' => 'theme/stylesheet.css'
);
}
unset($theme_data);
unset($theme_cfg);
}
// Export imageset core code
if ($mode == 'imageset' || $inc_imageset)
{
$imageset_cfg = addslashes($imageset_name) . "\n";
$imageset_cfg .= addslashes($imageset_copyright) . "\n";
$imageset_cfg .= addslashes($config['version']) . "\n";
foreach (array_keys($style_row) as $key)
{
$imageset_cfg .= $key . '||' . str_replace("styles/$imageset_path/imageset/", '{PATH}', $style_row[$key]) . "\n";
unset($style_row[$key]);
}
$imageset_cfg = rtrim($imageset_cfg);
$files[] = array(
'src' => "styles/$imageset_path/imageset/",
'prefix-' => "styles/$imageset_path/",
'prefix+' => false,
'exclude' => 'imageset.cfg'
);
$data[] = array(
'src' => trim($imageset_cfg),
'prefix' => 'imageset/imageset.cfg'
);
unset($imageset_cfg);
}
switch ($format)
{
case 'tar':
$ext = 'tar';
$mimetype = 'x-tar';
$compress = 'compress_tar';
break;
case 'zip':
if (!extension_loaded('zlib'))
{
trigger_error($user->lang['NO_SUPPORT_ZIP']);
}
$ext = 'zip';
$mimetype = 'zip';
$compress = 'compress_zip';
break;
case 'tar.gz':
if (!extension_loaded('zlib'))
{
trigger_error($user->lang['NO_SUPPORT_GZ']);
}
$ext = 'tar.gz';
$mimetype = 'x-gzip';
$compress = 'compress_tar';
break;
case 'tar.bz2':
if (!extension_loaded('bz2'))
{
trigger_error($user->lang['NO_SUPPORT_BZ2']);
}
$ext = 'tar.bz2';
$mimetype = 'x-bzip2';
$compress = 'compress_tar';
break;
default:
$error[] = $user->lang[$l_prefix . '_ERR_ARCHIVE'];
}
if (!sizeof($error))
{
include($phpbb_root_path . 'includes/functions_compress.'.$phpEx);
$path = str_replace(' ', '_', $$name);
if (!($zip = new $compress('w', "{$phpbb_root_path}store/$path.$ext")))
{
trigger_error($user->lang['STORE_UNWRITEABLE']);
}
if ($files)
{
foreach ($files as $file_ary)
{
$zip->add_file($file_ary['src'], $file_ary['prefix-'], $file_ary['prefix+'], $file_ary['exclude']);
}
}
if ($data)
{
foreach ($data as $data_ary)
{
$zip->add_data($data_ary['src'], $data_ary['prefix']);
}
}
$zip->close();
add_log('admin', 'LOG_EXPORT_' . $l_prefix, $$name);
if (!$store)
{
header('Pragma: no-cache');
header("Content-Type: application/$mimetype; name=\"$path.$ext\"");
header("Content-disposition: attachment; filename=$path.$ext");
$fp = fopen("{$phpbb_root_path}store/$path.$ext", 'rb');
while ($buffer = fread($fp, 1024))
{
echo $buffer;
}
fclose($fp);
@unlink("{$phpbb_root_path}store/$path.$ext");
exit;
}
trigger_error(sprintf($user->lang[$l_prefix . '_EXPORTED'], "store/$path.$ext"));
}
}
else
{
$sql = "SELECT {$mode}_id, {$mode}_name
FROM " . (($mode == 'style') ? STYLES_TABLE : $sql_from) . "
WHERE {$mode}_id = $id";
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
trigger_error($user->lang['NO_' . $l_prefix]);
}
$db->sql_freeresult($result);
}
// Output list
adm_page_header($user->lang[$l_prefix . '_EXPORT']);
?>
<h1><?php echo $user->lang[$l_prefix . '_EXPORT']; ?></h1>
<p><?php echo $user->lang[$l_prefix . '_EXPORT_EXPLAIN']; ?></p>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$mode&amp;action=export&amp;id=$id"; ?>"><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="2"><?php echo $user->lang[$l_prefix . '_EXPORT']; ?></td>
</tr>
<?php
if (sizeof($error))
{
?>
<tr>
<td colspan="2" class="row3" align="center"><span style="color:red"><?php echo implode('<br />', $error); ?></span></td>
</tr>
<?php
}
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_prefix . '_NAME']; ?>:</b></td>
<td class="row2"><b><?php echo ${$mode . '_name'}; ?></b></td>
</tr>
<?php
if ($mode == 'style')
{
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_TEMPLATE']; ?>:</b></td>
<td class="row2"><input type="radio" name="inc_template" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?> &nbsp;&nbsp;<input type="radio" name="inc_template" value="0" /> <?php echo $user->lang['NO']; ?> </td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_THEME']; ?>:</b></td>
<td class="row2"><input type="radio" name="inc_theme" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?> &nbsp;&nbsp;<input type="radio" name="inc_theme" value="0" /> <?php echo $user->lang['NO']; ?> </td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['INCLUDE_IMAGESET']; ?>:</b></td>
<td class="row2"><input type="radio" name="inc_imageset" value="1" checked="checked" /> <?php echo $user->lang['YES']; ?> &nbsp;&nbsp;<input type="radio" name="inc_imageset" value="0" /> <?php echo $user->lang['NO']; ?> </td>
</tr>
<?php
}
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['DOWNLOAD_STORE']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['DOWNLOAD_STORE_EXPLAIN']; ?></span></td>
<td class="row2"><input type="radio" name="store" value="1" checked="checked" /> <?php echo $user->lang['EXPORT_STORE']; ?> &nbsp;&nbsp;<input type="radio" name="store" value="0" /> <?php echo $user->lang['EXPORT_DOWNLOAD']; ?> </td>
</tr>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang['ARCHIVE_FORMAT']; ?>:</b></td>
<td class="row2"><input type="radio" name="format" value="tar" /> .tar&nbsp;&nbsp;<?php
$compress_types = array('tar.gz' => 'zlib', 'tar.bz2' => 'bz2', 'zip' => 'zlib');
foreach ($compress_types as $type => $module)
{
if (!extension_loaded($module))
{
continue;
}
echo '<input type="radio" name="format" value="' . $type . '" /> .' . $type . '&nbsp;&nbsp;';
}
?></td>
</tr>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>"; />&nbsp;&nbsp;<input class="btnlite" type="submit" name="cancel" value="<?php echo $user->lang['CANCEL']; ?>"; /></td>
</tr>
</table></form>
<?php
adm_page_footer();
}
function store_templates($mode, $id, $path, $filelist)
{
global $phpbb_root_path, $phpEx, $db;
$includes = array();
foreach ($filelist as $pathfile => $file_ary)
{
foreach ($file_ary as $file)
{
if (!($fp = fopen("{$phpbb_root_path}styles/$path$pathfile/$file", 'r')))
{
trigger_error("Could not open {$phpbb_root_path}styles/$path/$pathfile/$file");
}
$template_data = fread($fp, filesize("{$phpbb_root_path}styles/$path$pathfile/$file"));
fclose($fp);
if (preg_match_all('#<!-- INCLUDE (.*?\.html) -->#is', $template_data, $matches))
{
foreach ($matches[1] as $match)
{
$includes[trim($match)][] = $file;
}
}
}
}
foreach ($filelist as $pathfile => $file_ary)
{
foreach ($file_ary as $file)
{
// Skip index.
if (strpos($file, 'index.') === 0)
{
continue;
}
// We could do this using extended inserts ... but that could be one
// heck of a lot of data ...
$sql_ary = array(
'template_id' => $id,
'template_filename' => $file,
'template_included' => (!empty($includes[$file])) ? implode(':', $includes[$file]) . ':' : '',
'template_mtime' => filemtime("{$phpbb_root_path}styles/$path$pathfile/$file"),
'template_data' => implode('', file("{$phpbb_root_path}styles/$path$pathfile/$file")),
);
$sql = ($mode == 'insert') ? 'INSERT INTO ' . STYLES_TPLDATA_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary) : 'UPDATE ' . STYLES_TPLDATA_TABLE . ' ' . $db->sql_build_array('INSERT', $sql_ary) . " WHERE template_id = $id AND template_filename = '" . $db->sql_escape($file) . "'";
$db->sql_query($sql);
}
}
}
// Does what it says in the function title ... give it a src location, array of files
// and destination
function copy_files($src, $filelist, $dst)
{
global $phpbb_root_path;
if (!(is_writable("{$phpbb_root_path}styles")))
{
return false;
}
umask(0);
if (!file_exists("{$phpbb_root_path}styles/$dst"))
{
@mkdir("{$phpbb_root_path}styles/$dst", 0777);
chmod("{$phpbb_root_path}styles/$dst", 0777);
}
@ksort($filelist);
foreach ($filelist as $filepath => $file_ary)
{
$filepath = (substr($filepath, 0, 1) != '/') ? "/$filepath" : $filepath;
if ($filepath && !file_exists("{$phpbb_root_path}styles/$dst$filepath"))
{
@mkdir("{$phpbb_root_path}styles/$dst$filepath", 0777);
chmod("{$phpbb_root_path}styles/$dst$filepath", 0777);
}
foreach ($file_ary as $file)
{
if (!file_exists("{$phpbb_root_path}styles/$dst$filepath$file"))
{
@copy("$src$filepath$file", "{$phpbb_root_path}styles/$dst$filepath$file");
@chmod("{$phpbb_root_path}styles/$dst$filepath$file", 0777);
}
}
}
}
// You can guess what this does ... just give it a path
function cleanup_folder($path)
{
$filelist = filelist($path, '', '*');
krsort($filelist);
foreach ($filelist as $filepath => $file_ary)
{
foreach ($file_ary as $file)
{
@unlink("$path$filepath$file");
}
if (file_exists("$path$filepath"))
{
@rmdir("$path$filepath");
}
}
@rmdir("$path");
}
// Is this element installed? If not, grab its cfg details
function test_installed($element, &$error, $root_path, $reqd_name, &$id, &$name, &$copyright)
{
global $db, $user;
switch ($element)
{
case 'template':
$sql_from = STYLES_TPL_TABLE;
break;
case 'theme':
$sql_from = STYLES_CSS_TABLE;
break;
case 'imageset':
$sql_from = STYLES_IMAGE_TABLE;
break;
}
$l_element = strtoupper($element);
$chk_name = ($reqd_name) ? $reqd_name : $name;
$sql = "SELECT {$element}_id, {$element}_name
FROM $sql_from
WHERE {$element}_name = '" . $db->sql_escape($chk_name) . "'";
$result = $db->sql_query($sql);
if ($row = $db->sql_fetchrow($result))
{
$name = $row[$element . '_name'];
$id = $row[$element . '_id'];
}
else
{
if (!($cfg = @file("$root_path$element/$element.cfg")))
{
$error[] = sprintf($user->lang['REQUIRES_' . $l_element], $reqd_name);
return false;
}
$name = trim($cfg[0]);
$copyright = trim($cfg[1]);
$id = 0;
unset($cfg);
}
$db->sql_freeresult($result);
}
// Install an element, doing various checks as we go
function install_element($type, &$error, $action, $root_path, &$id, $name, $copyright, $storedb = 0)
{
global $phpbb_root_path, $db, $user;
switch ($type)
{
case 'template':
$sql_from = STYLES_TPL_TABLE;
break;
case 'theme':
$sql_from = STYLES_CSS_TABLE;
break;
case 'imageset':
$sql_from = STYLES_IMAGE_TABLE;
break;
}
$l_type = strtoupper($type);
$path = str_replace(' ', '_', $name);
if (empty($name))
{
$error[] = $user->lang[$l_type . '_ERR_STYLE_NAME'];
}
if (strlen($name) > 30)
{
$error[] = $user->lang[$l_type . '_ERR_NAME_LONG'];
}
if (!preg_match('#^[a-z0-9_\-\+\. ]+$#i', $name))
{
$error[] = $user->lang[$l_type . '_ERR_NAME_CHARS'];
}
if (strlen($copyright) > 60)
{
$error[] = $user->lang[$l_type . '_ERR_COPY_LONG'];
}
$sql = "SELECT {$type}_name
FROM $sql_from
WHERE {$type}_name = '" . $db->sql_escape($name) . "'";
$result = $db->sql_query($sql);
if (extract($db->sql_fetchrow($result)))
{
$error[] = $user->lang[$l_type . '_ERR_NAME_EXIST'];
}
$db->sql_freeresult($result);
if (sizeof($error))
{
return false;
}
if ($action != 'install')
{
@mkdir("{$phpbb_root_path}styles/$path", 0777);
@chmod("{$phpbb_root_path}styles/$path", 0777);
if ($root_path)
{
copy_files("$root_path$type", filelist("$root_path$type", '', '*'), "$path/$type");
}
}
$sql_ary = array(
$type . '_name' => $name,
$type . '_copyright'=> $copyright,
$type . '_path' => $path,
);
if ($type != 'imageset')
{
switch ($type)
{
case 'template':
$sql_ary += array(
$type . '_storedb' => (!is_writeable("{$phpbb_root_path}styles/$path/$type")) ? 1 : 0
);
break;
case 'theme':
$sql_ary += array(
'theme_storedb' => (!is_writeable("{$phpbb_root_path}styles/$path/theme/stylesheet.css")) ? 1 : $storedb,
'theme_data' => ($storedb) ? (($root_path) ? str_replace('./', "styles/$path/theme/", implode('', file("$root_path/$type/stylesheet.css"))) : '') : '',
'theme_mtime' => ($storedb) ? filemtime("{$phpbb_root_path}styles/$path/theme/stylesheet.css") : 0
);
break;
}
}
else
{
$cfg = file("$root_path$type/imageset.cfg");
for ($i = 3; $i < sizeof($cfg); $i++)
{
$tmp = explode('||', $cfg[$i]);
$sql_ary[$tmp[0]] = str_replace('{PATH}', "styles/$path/imageset/", trim($tmp[1]));
}
unset($cfg);
}
$db->sql_transaction('begin');
$sql = "INSERT INTO $sql_from
" . $db->sql_build_array('INSERT', $sql_ary);
$db->sql_query($sql);
$id = $db->sql_nextid();
if ($type == 'template' && $storedb)
{
$filelist = filelist("{$root_path}template", '', 'html');
store_templates('insert', $id, $path, $filelist);
}
$db->sql_transaction('commit');
$log = ($storedb) ? 'LOG_ADD_' . $l_type . '_FS' : 'LOG_ADD_' . $l_type . '_DB';
add_log('admin', $log, $name);
}
function install_style($action, &$error, $name, $copyright, $active, $default, $root_path, &$template_id, &$template_name, &$template_copyright, &$theme_id, &$theme_name, &$theme_copyright, &$imageset_id, &$imageset_name, &$imageset_copyright)
{
global $config, $db, $user;
$element_ary = array('template', 'theme', 'imageset');
if (empty($name))
{
$error[] = $user->lang['STYLE_ERR_STYLE_NAME'];
}
if (strlen($name) > 30)
{
$error[] = $user->lang['STYLE_ERR_NAME_LONG'];
}
if (!preg_match('#^[a-z0-9_\-\+\. ]+$#i', $name))
{
$error[] = $user->lang['STYLE_ERR_NAME_CHARS'];
}
if (strlen($copyright) > 60)
{
$error[] = $user->lang['STYLE_ERR_COPY_LONG'];
}
$sql = 'SELECT style_name
FROM ' . STYLES_TABLE . "
WHERE style_name = '" . $db->sql_escape($name) . "'";
$result = $db->sql_query($sql);
if (extract($db->sql_fetchrow($result)))
{
$error[] = $user->lang['STYLE_ERR_NAME_EXIST'];
}
$db->sql_freeresult($result);
foreach ($element_ary as $element)
{
// Zero id value ... need to install element ... run usual checks
// and do the install if necessary
if (!${$element . '_id'})
{
$error = install_element($element, $action, $root_path, ${$element . '_id'}, ${$element . '_name'}, ${$element . '_copyright'});
}
}
if (!$template_id || !$theme_id || !$imageset_id)
{
$error[] = $user->lang['STYLE_ERR_NO_IDS'];
}
if (sizeof($error))
{
return false;
}
$db->sql_transaction('begin');
$sql_ary = array(
'style_name' => $name,
'style_copyright' => $copyright,
'style_active' => $active,
'template_id' => $template_id,
'theme_id' => $theme_id,
'imageset_id' => $imageset_id,
);
$sql = 'INSERT INTO ' . STYLES_TABLE . '
' . $db->sql_build_array('INSERT', $sql_ary);
$db->sql_query($sql);
$id = $db->sql_nextid();
if ($default)
{
$sql = 'UPDATE ' . USERS_TABLE . "
SET user_style = $id
WHERE user_style = " . $config['default_style'];
$db->sql_query($sql);
set_config('default_style', $id);
}
$db->sql_transaction('commit');
add_log('admin', 'LOG_ADD_STYLE', $name);
}
// Commented inline
function install($type, $action, $id)
{
global $phpbb_root_path, $phpEx, $SID, $config, $db, $cache, $user;
global $safe_mode, $file_uploads, $archive_preg;
$install_path = (isset($_REQUEST['path'])) ? htmlspecialchars($_REQUEST['path']) : '';
$update = (isset($_POST['update'])) ? true : false;
$installcfg = $error = array();
$template_storedb = $theme_storedb = $basis = false;
$root_path = $tmp_path = $theme_data = $s_hidden_fields = '';
$template_id = $template_name = $template_copyright =$theme_id = $theme_name = $theme_copyright = $imageset_id = $imageset_name = $imageset_copyright = '';
$l_type = strtoupper($type);
$l_prefix = ($action == 'add') ? 'ADD' : (($action == 'details') ? 'EDIT_DETAILS' : 'INSTALL');
$element_ary = array('template' => STYLES_TPL_TABLE, 'theme' => STYLES_CSS_TABLE, 'imageset' => STYLES_IMAGE_TABLE);
$phpbbversion = preg_replace('#^2\.([0-9]+?)\.([0-9]+?).*?$#', '\1.\2', $config['version']);
switch ($type)
{
case 'style':
$sql_from = STYLES_TABLE;
break;
case 'template':
$sql_from = STYLES_TPL_TABLE;
break;
case 'theme':
$sql_from = STYLES_CSS_TABLE;
break;
case 'imageset':
$sql_from = STYLES_IMAGE_TABLE;
break;
}
// Importing/uploading then check data and extract archive
if (!empty($_FILES['upload_file']['name']) || !empty($_POST['import_file']))
{
if (!empty($_FILES['upload_file']['name']))
{
$realname = htmlspecialchars($_FILES['upload_file']['name']);
$filename = htmlspecialchars($_FILES['upload_file']['tmp_name']);
if (!is_uploaded_file($filename))
{
trigger_error("$filename was not uploaded");
}
}
else
{
$realname = htmlspecialchars($_POST['import_file']);
$filename = "{$phpbb_root_path}store/$realname";
}
if (!preg_match('#(' . $archive_preg . ')$#i', $realname, $match))
{
$error[] = sprintf($user->lang['UPLOAD_WRONG_TYPE'], $archive_types);
}
$path = preg_replace('#^(.*?)' . preg_quote($match[0]) . '$#', '\1', $realname);
// Attempt to extract the files to a temporary directory in store
$tmp_path = $phpbb_root_path . 'store/tmp_' . substr(uniqid(''), 0, 10) . '/';
if (!@mkdir($tmp_path))
{
trigger_error("Cannot create $tmp_path", E_USER_ERROR);
}
include($phpbb_root_path . 'includes/functions_compress.'.$phpEx);
switch ($match[0])
{
case '.zip':
$zip = new compress_zip('r', $filename);
break;
default:
$zip = new compress_tar('r', $filename, $match[0]);
}
$zip->extract($tmp_path);
$zip->close();
unset($cfg);
}
// Installing, importing/uploading then obtain the style cfg information
if (($action == 'install' && $install_path) || (!empty($_FILES['upload_file']['name']) || !empty($_POST['import_file'])))
{
$root_path = ($action == 'install') ? "{$phpbb_root_path}styles/$install_path/" : "$tmp_path";
$cfg_path = ($type == 'style') ? "$root_path$type.cfg" : "$root_path$type/$type.cfg";
if (!($fp = @fopen($cfg_path, 'rb')))
{
$error[] = $user->lang[$l_type . '_ERR_NOT_' . $l_type];
}
else
{
$installcfg = explode("\n", fread($fp, filesize($cfg_path)));
}
fclose($fp);
}
// Installing, importing/uploading then grab the element info else grab the
// submitted params ... stylecfg will be set if this is true (see above)
if (sizeof($installcfg))
{
$name = trim($installcfg[0]);
$copyright = trim($installcfg[1]);
$version = preg_replace('#^2\.([0-9]+?)\.([0-9]+?).*?$#', '\1.\2', trim($installcfg[2]));
switch ($type)
{
case 'style':
$reqd_template = trim($installcfg[3]);
$reqd_theme = trim($installcfg[4]);
$reqd_imageset = trim($installcfg[5]);
// Check to see if each element is already installed, if it is grab the id
foreach ($element_ary as $element => $table)
{
${$element . '_id'} = ${$element . '_name'} = ${$element . '_copyright'} = '';
test_installed($element, $error, $root_path, ${'reqd_' . $element}, ${$element . '_id'}, ${$element . '_name'}, ${$element . '_copyright'});
}
break;
case 'template':
test_installed('template', $error, $root_path, false, $template_id, $template_name, $template_copyright);
break;
case 'theme':
test_installed('theme', $error, $root_path, false, $theme_id, $theme_name, $theme_copyright);
break;
case 'imageset':
test_installed('imageset', $error, $root_path, false, $imageset_id, $imageset_name, $imageset_copyright);
break;
}
$s_hidden_fields = '<input type="hidden" name="path" value="' . $install_path . '" />';
}
else
{
// NOTE: Data here is stripslashed! Ensure it's escaped when entering the DB
$name = (!empty($_POST['name'])) ? stripslashes(htmlspecialchars($_POST['name'])) : '';
$copyright = (!empty($_POST['copyright'])) ? stripslashes(htmlspecialchars($_POST['copyright'])) : '';
$template_id = (!empty($_POST['template_id'])) ? intval($_POST['template_id']) : 0;
$theme_id = (!empty($_POST['theme_id'])) ? intval($_POST['theme_id']) : 0;
$imageset_id = (!empty($_POST['imageset_id'])) ? intval($_POST['imageset_id']) : 0;
$basis = (isset($_POST['basis'])) ? intval($_POST['basis']) : 0;
// If we have a basis or we're editing we want some additional info ... else
// we need nothing
if ($basis || ($update && $action != 'add'))
{
switch ($type)
{
case 'style':
$sql_select = ($action != 'details') ? 'style_name, template_id, theme_id, imageset_id' : 'style_name';
break;
case 'template':
$sql_select = 'template_id, template_name, template_path, template_storedb';
break;
case 'theme':
$sql_select = 'theme_id, theme_name, theme_path, theme_data, theme_storedb';
break;
case 'imageset':
$sql_select = 'imageset_id, imageset_name, imageset_path';
break;
}
$sql = "SELECT $sql_select
FROM $sql_from
WHERE {$type}_id = " . (($basis) ? $basis : $id);
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
$error[] = $user->lang['NO_' . $l_type];
}
$db->sql_freeresult($result);
$s_hidden_fields .= '<input type="hidden" name="basis" value="' . $basis . '" />';
}
}
$storedb = (!empty($_POST['storedb'])) ? 1 : 0;
$style_active = (isset($_POST['style_active'])) ? ((!empty($_POST['style_active'])) ? 1 : 0) : 1;
$style_default = (isset($_POST['style_default'])) ? ((!empty($_POST['style_default'])) ? 1 : 0) : (($config['default_style'] == $id) ? 1 : 0);
// User has submitted form and no errors have occured
if ($update && !sizeof($error))
{
$sql_ary = array();
// We're installing/uploading/importing
if ($action == 'install')
{
switch ($type)
{
case 'style':
install_style($action, $error, $name, $copyright, $style_active, $style_default, $root_path, $template_id, $template_name, $template_copyright, $theme_id, $theme_name, $theme_copyright, $imageset_id, $imageset_name, $imageset_copyright);
break;
case 'template':
install_element('template', $error, $action, $root_path, $id, $name, $copyright);
break;
case 'theme':
install_element('theme', $error, $action, $root_path, $id, $name, $copyright);
break;
case 'imageset':
install_element('imageset', $error, $action, $root_path, $id, $name, $copyright);
break;
}
if ($tmp_path)
{
cleanup_folder($tmp_path);
}
if (!sizeof($error))
{
$cache->destroy('sql', STYLES_TABLE);
$message = ($storedb) ? '_ADDED_DB' : '_ADDED';
trigger_error($user->lang[$l_type . $message]);
}
}
else if ($action == 'add')
{
if ($type == 'style')
{
install_style($action, $error, $name, $copyright, $style_active, $style_default, $root_path, $template_id, $template_name, $template_copyright, $theme_id, $theme_name, $theme_copyright, $imageset_id, $imageset_name, $imageset_copyright);
}
else
{
// Create path if it doesn't exist
$storedb = 1;
umask(0);
if (file_exists("{$phpbb_root_path}styles/$path") || @mkdir("{$phpbb_root_path}styles/$path", 0777))
{
if (@chmod("{$phpbb_root_path}styles/$path", 0777))
{
$storedb = 0;
}
}
if ($basis && ($template_storedb || $theme_storedb))
{
$tmp_path = $phpbb_root_path . 'store/tmp_' . substr(uniqid(''), 0, 10) . '/';
if (!@mkdir($tmp_path, 0777))
{
trigger_error("Cannot create $tmp_path", E_USER_ERROR);
}
@chmod($tmp_path, 0777);
if (!@mkdir("$tmp_path$type", 0777))
{
trigger_error("Cannot create $tmp_path$type", E_USER_ERROR);
}
@chmod("$tmp_path$type", 0777);
switch ($type)
{
case 'theme':
copyfiles("{$phpbb_root_path}styles/$path/theme/", filelist("{$phpbb_root_path}styles/$path/theme/", '', '*'), "$tmp_path$type/");
$fp = fopen("$tmp_path$type/stylesheet.css", 'wb');
fwrite($fp, $theme_data);
fclose($theme_data);
break;
case 'template':
copyfiles("{$phpbb_root_path}styles/$path/$type/", filelist("{$phpbb_root_path}styles/$path/$type/", '', '*'), "$tmp_path$type/");
$sql = 'SELECT template_filename, template_mtime, template_data
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $basis";
$result = $db->sql_fetchrow($result);
while ($row = $db->sql_fetchrow($result))
{
$fp = fopen("$tmp_path$type/" . $row['template_filename'], 'wb');
fwrite($fp, $row['template_data']);
fclose($fp);
}
$db->sql_freeresult($result);
break;
}
}
$root_path = ($tmp_path) ? $tmp_path : (($basis) ? $phpbb_root_path . 'styles/' . ${$type . '_path'} . '/' : '');
install_element($type, $error, $action, $root_path, $id, $name, $copyright, $storedb);
}
if ($tmp_path)
{
cleanup_folder($tmp_path);
}
if (!sizeof($error))
{
$cache->destroy('sql', STYLES_TABLE);
$message = ($storedb) ? '_ADDED_DB' : '_ADDED';
trigger_error($user->lang["$l_type$message"]);
}
}
else if ($action == 'details')
{
if ($type == 'style')
{
$sql_ary = array(
'template_id' => $template_id,
'theme_id' => $theme_id,
'imageset_id' => $imageset_id,
'style_active' => $style_active,
);
}
else if ($type != 'imageset')
{
switch ($type)
{
case 'theme':
if ($theme_storedb != $storedb)
{
$theme_data = implode('', file("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"));
if (!$storedb && !$safe_mode && is_writeable("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css"))
{
$storedb = 1;
if ($fp = @fopen("{$phpbb_root_path}styles/$theme_path/$type/stylesheet.css", 'wb'))
{
$storedb = (@fwrite($fp, str_replace("styles/$theme_path/theme/", './', $theme_data))) ? 0 : 1;
}
fclose($fp);
}
$theme_data = str_replace('./', "styles/$theme_path/theme/", $theme_data);
$sql_ary = array(
'theme_mtime' => ($storedb) ? filemtime("{$phpbb_root_path}styles/$theme_path/theme/stylesheet.css") : 0,
'theme_storedb' => $storedb,
'theme_data' => ($storedb) ? $theme_data : '',
);
}
break;
case 'template':
if ($theme_storedb != $storedb)
{
$filelist = filelist("{$phpbb_root_path}styles/$template_path/template", '', 'html');
if (!$storedb && !$safe_mode && is_writeable("{$phpbb_root_path}styles/$template_path/template"))
{
$sql = 'SELECT *
FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
if (!($fp = @fopen("{$phpbb_root_path}styles/$template_path/template/" . $row['template_filename'], 'wb')))
{
$storedb = 1;
break;
}
fwrite($fp, $row['template_data']);
fclose($fp);
}
$db->sql_freeresult($result);
if (!$storedb)
{
$sql = 'DELETE FROM ' . STYLES_TPLDATA_TABLE . "
WHERE template_id = $id";
$db->sql_query($sql);
}
}
$sql_ary = array(
'template_storedb' => $storedb,
);
}
break;
}
}
if ($type != 'imageset' && sizeof($sql_ary))
{
$sql = "UPDATE $sql_from
SET " . $db->sql_build_array('UPDATE', $sql_ary) . "
WHERE {$type}_id = $id";
$db->sql_query($sql);
if ($type == 'style' && $style_default)
{
set_config('default_style', $id);
}
}
$cache->destroy('sql', STYLES_TABLE);
add_log('admin', 'LOG_EDIT_' . $l_type, $name);
trigger_error($user->lang[$l_type . '_EDITED']);
}
}
// Something went wrong ... so we'll clean up any decompressed uploaded/imported archives.
if ($tmp_path)
{
cleanup_folder($tmp_path);
}
// Either an error occured or the user has just entered the form
if (!sizeof($error) && !$update && $id)
{
$sql = "SELECT *
FROM $sql_from
WHERE {$type}_id = $id";
$result = $db->sql_query($sql);
if (!extract($db->sql_fetchrow($result)))
{
trigger_error($user->lang['NO_' . $l_type]);
}
$db->sql_freeresult($result);
$style_default = ($type == 'style' && $config['default_style'] == $id) ? 1 : 0;
$storedb = (!empty(${$type . '_storedb'})) ? true : false; // Fudged because we use $storedb when submitting data
}
if ($type == 'style' && $action != 'install')
{
$style_options = array();
foreach ($element_ary as $element => $table)
{
$sql = "SELECT {$element}_id, {$element}_name
FROM $table
ORDER BY {$element}_id ASC";
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
$selected = ($row[$element . '_id'] == ${$element . '_id'}) ? ' selected="selected"' : '';
${$element . '_options'} .= '<option value="' . $row[$element . '_id'] . '"' . $selected . '>' . $row[$element . '_name'] . '</option>';
}
$db->sql_freeresult($result);
}
}
// Output the page
adm_page_header($user->lang[$l_prefix . '_' . $l_type]);
?>
<h1><?php echo $user->lang[$l_prefix . '_' . $l_type]; ?></h1>
<p><?php echo $user->lang[$l_prefix . '_' . $l_type . '_EXPLAIN']; ?></p>
<form name="style" method="post" action="<?php echo "admin_styles.$phpEx$SID&amp;mode=$type&amp;action=$action&amp;id=$id"; ?>"<?php echo (!$safe_mode && $file_uploads && is_writeable("{$phpbb_root_path}styles")) ? ' enctype="multipart/form-data"' : ''; ?>><table class="bg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="2"><?php echo $user->lang[$l_prefix . '_' . $l_type]; ?></th>
</tr>
<?php
if (sizeof($error))
{
?>
<tr>
<td colspan="2" class="row3" align="center"><span style="color:red"><?php echo implode('<br />', $error); ?></span></td>
</tr>
<?php
}
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_NAME']; ?>:</b></td>
<td class="row2"><?php
echo ($action == 'add') ? '<input class="post" type="text" name="name" maxlength="30" size="30" value="' . $name . '" />' : '<b>' . ${$type . '_name'} . '</b>';
?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['COPYRIGHT']; ?>:</b></td>
<td class="row2"><?php
echo ($action == 'add') ? '<input class="post" type="text" name="copyright" maxlength="60" size="30" value="' . $copyright . '" />' : '<b>' . ${$type . '_copyright'} . '</b>';
?></td>
</tr>
<?php
if ($type == 'style' && !$basis)
{
?>
<tr>
<td class="row1"><b><?php echo $user->lang['STYLE_TEMPLATE']; ?>:</b></td>
<td class="row2"><?php
echo ($action == 'install') ? "<b>$template_name</b>" : '<select name="template_id">' . $template_options . '</select>';
?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['STYLE_THEME']; ?>:</b></td>
<td class="row2"><?php
echo ($action == 'install') ? "<b>$theme_name</b>" : '<select name="theme_id">' . $theme_options . '</select>';
?></td>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['STYLE_IMAGESET']; ?>:</b></td>
<td class="row2"><?php
echo ($action == 'install') ? "<b>$imageset_name</b>" : '<select name="imageset_id">' . $imageset_options . '</select>';
?></td>
</tr>
<?php
}
if ($type == 'template' || $type == 'theme')
{
$storedb_no = (!$storedb) ? ' checked="checked"' : '';
$storedb_yes = ($storedb) ? ' checked="checked"' : '';
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_LOCATION']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang[$l_type . '_LOCATION_EXPLAIN']; ?></span></td>
<td class="row2"><input type="radio" name="storedb" value="0"<?php echo $storedb_no; ?> /> <?php echo $user->lang['STORE_FILESYSTEM']; ?>&nbsp;&nbsp;<input type="radio" name="storedb" value="1"<?php echo $storedb_yes; ?> /> <?php echo $user->lang['STORE_DATABASE']; ?></td>
</tr>
<?php
}
// Import, upload and basis options
if ($action == 'add' && !$safe_mode && is_writeable("{$phpbb_root_path}styles"))
{
?>
<tr>
<th colspan="2"><?php echo $user->lang['OPTIONS']; ?></th>
</tr>
<?php
if (!$basis)
{
$store_options = '';
$dp = @opendir("{$phpbb_root_path}store");
while ($file = readdir($dp))
{
if ($file{0} != '.' && preg_match('#(' . $archive_preg . ')$#i', $file))
{
$store_options .= "<option value=\"$file\">$file</option>";
}
}
closedir($dp);
$store_options = '<option value="">' . $user->lang['NO_IMPORT'] . '</option>' . $store_options;
if ($file_uploads)
{
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_UPLOAD_BASIS']; ?>:</b><br /><span class="gensmall"><?php echo $user->lang['ALLOWED_FILETYPES']; ?>: <?php echo $archive_types; ?></span></td>
<td class="row2"><input class="post" type="file" name="upload_file" /><input type="hidden" name="MAX_FILE_SIZE" value="1048576" /></td>
</tr>
<?php
}
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_IMPORT_BASIS']; ?>:</b></td>
<td class="row2"><select name="import_file"><?php echo $store_options; ?></select></td>
</tr>
<?php
}
else if ($basis)
{
?>
<tr>
<td class="row1" width="40%"><b><?php echo $user->lang[$l_type . '_BASIS']; ?>: </b></td>
<td class="row2"><b><?php echo ${$type . '_name'}; ?></b></td>
</tr>
<?php
}
}
if ($type == 'style')
{
$active_yes = ($style_active) ? ' checked="checked"' : '';
$active_no = (!$style_active) ? ' checked="checked"' : '';
$style_default_yes = ($style_default) ? ' checked="checked"' : '';
$style_default_no = (!$style_default) ? ' checked="checked"' : '';
?>
<tr>
<th colspan="2">&nbsp;</th>
</tr>
<tr>
<td class="row1"><b><?php echo $user->lang['STYLE_ACTIVE']; ?>:</b></td>
<td class="row2"><input type="radio" name="style_active" value="1"<?php echo $active_yes; ?> /> <?php echo $user->lang['YES']; ?> &nbsp; <input type="radio" name="style_active" value="0"<?php echo $active_no; ?> /> <?php echo $user->lang['NO']; ?></td>
</tr>
<?php
if ($id != $config['default_style'])
{
?>
<tr>
<td class="row1"><b><?php echo $user->lang['STYLE_DEFAULT']; ?>:</b></td>
<td class="row2"><input type="radio" name="style_default" value="1"<?php echo $style_default_yes; ?> /> <?php echo $user->lang['YES']; ?> &nbsp; <input type="radio" name="style_default" value="0"<?php echo $style_default_no; ?> /> <?php echo $user->lang['NO']; ?></td>
</tr>
<?php
}
}
?>
<tr>
<td class="cat" colspan="2" align="center"><input class="btnmain" type="submit" name="update" value="<?php echo $user->lang['SUBMIT']; ?>" />&nbsp;&nbsp;<input class="btnlite" type="reset" value="<?php echo $user->lang['RESET']; ?>" /><?php echo $s_hidden_fields; ?></td>
</tr>
</table></form>
<?php
adm_page_footer();
}
// Hopefully temporary
function theme_preview(&$path, &$stylesheet, &$class, &$css_element)
{
global $config, $user;
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html dir="<?php echo $user->lang['LTR']; ?>">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $user->lang['ENCODING']; ?>">
<meta http-equiv="Content-Style-Type" content="text/css">
<style type="text/css">
<!--
<?php
$updated_element = implode('; ', $css_element) . ';';
if (preg_match('#^' . $class . ' {(.*?)}#m', $stylesheet))
{
$stylesheet = preg_replace('#^(' . $class . ' {).*?(})#m', '\1 ' . $updated_element . ' \2', $stylesheet);
}
echo str_replace('styles/', '../styles/', str_replace('./', "styles/$path/theme/", $stylesheet));
?>
//-->
</style>
</head>
<body>
<table width="100%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr align="center" valign="middle">
<td height="100" width="33%"><h1>h1</h1></td>
<td height="100" width="33%"><h2>h2</h2></td>
<td height="100" width="33%"><h3>h3</h3></td>
</tr>
<tr align="center">
<td colspan="3" height="30"><a class="mainmenu" href="">mainmenu</a></td>
</tr>
<tr>
<td colspan="3" height="50">&nbsp;</td>
</tr>
</table>
<table width="95%" cellspacing="2" cellpadding="2" border="0" align="center">
<tr>
<td align="left" valign="bottom"><a class="titles" href="">titles</a>
</tr>
</table>
<table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<td class="nav" width="10" align="left" valign="middle"><a href="">navlink</a></td>
</tr>
</table>
<table class="tablebg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<th colspan="3">th</th>
</tr>
<tr>
<td class="cat" width="40%"><span class="cattitle">cattitle / cat</span></td>
<td class="catdiv" colspan="2">catdiv</td>
</tr>
<tr>
<td class="row1" width="40%"><a class="topictitle" href="">topictitle / row1</a></td>
<td class="row2"><span class="topicauthor">topicauthor / row2</span></td>
<td class="row1"><span class="topicdetails">topicdetails / row1</span></td>
</tr>
<tr>
<td class="row3" colspan="3">row3</td>
</tr>
<tr>
<td class="spacer" colspan="3">spacer</td>
</tr>
<tr>
<td class="row1"><span class="postauthor">postauthor / row1</span></td>
<td class="row2"><span class="postdetails">postdetails / row2</span></td>
<td class="row1"><span class="postbody">postbody / row1 <span class="posthilit">posthilit</span></span></td>
</tr>
</table>
<br /><hr width="95%" />
<table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr align="center">
<td><span class="gen">gen</span></td>
<td><span class="genmed">genmed</span></td>
<td><span class="gensmall">gensmall</span></td>
</tr>
<tr align="center">
<td colspan="3"><span class="copyright">copyright <a href="">phpBB</a></span></td>
</tr>
</table>
<hr width="95%" /><br />
<form><table width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr align="center">
<td><input class="btnmain" type="submit" value="input / btnmain" /></td>
<td><input class="btnlite" type="submit" value="input / btnlite" /></td>
<td><input class="btnbbcode" type="submit" value="input / btnbbcode" /></td>
</tr>
<tr align="center">
<td colspan="3"><input class="post" type="text" value="input / post" /></td>
</tr>
<tr align="center">
<td colspan="3"><select class="post"><option>select</option></select></td>
</tr>
<tr align="center">
<td colspan="3"><textarea class="post">textarea / post</textarea></td>
</tr>
</table></form>
<hr width="95%" /><br />
<table class="tablebg" width="95%" cellspacing="1" cellpadding="4" border="0" align="center">
<tr>
<td class="row2" align="center"><span class="postbody">postbody / <b>bold</b> <i>italic</i> <u>underline</u></span></td>
</tr>
<tr>
<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
<tr>
<td class="quote"><b>A_N_Other wrote:</b><hr />quote</td>
</tr>
</table></td>
</tr>
<tr>
<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
<tr>
<td><b class="genmed">Code:</b></td>
</tr>
<tr>
<td class="code">10 Print "hello"<br />20 Goto 10</td>
</tr>
</table></td>
</tr>
<tr>
<td class="row2"><table width="90%" cellspacing="1" cellpadding="3" border="0" align="center">
<tr>
<td><b class="genmed">PHP:</b></td>
</tr>
<tr>
<td class="code"><span class="syntaxbg"><span class="syntaxcomment">// syntaxcomment</span><br /><span class="syntaxdefault">?&gt;</span><br />&lt;<span class="syntaxhtml">HTML</span>&gt;<br /><span class="syntaxdefault">&lt;?php</span><br /><span class="syntaxkeyword">echo </span> <span class="syntaxdefault">$this = </span><span class="syntaxstring">"HELLO"</span><span class="syntaxdefault">;</span></span></td>
</tr>
</table></td>
</tr>
</table>
<br clear="all" />
</body>
</html>
<?php
}
//
// FUNCTIONS
// ---------
?>