phpBB

Code Changes

File: includes/acp/acp_styles.php

  Unmodified   Added   Modified   Removed
Line 37Line 37
		// Hardcoded template bitfield to add for new templates
$bitfield = new bitfield();
$bitfield->set(0);

		// Hardcoded template bitfield to add for new templates
$bitfield = new bitfield();
$bitfield->set(0);

 
		$bitfield->set(1);
$bitfield->set(2);

		$bitfield->set(3);

		$bitfield->set(3);

 
		$bitfield->set(4);

		$bitfield->set(8);
$bitfield->set(9);
$bitfield->set(11);

		$bitfield->set(8);
$bitfield->set(9);
$bitfield->set(11);

Line 91Line 94
# images within your css file.
#
parse_css_file = {PARSE_CSS_FILE}

# images within your css file.
#
parse_css_file = {PARSE_CSS_FILE}

 
';

$this->template_cfg .= '
# Some configuration options

# Template inheritance
# See http://blog.phpbb.com/2008/07/31/templating-just-got-easier/
# Set value to empty or this template name to ignore template inheritance.
inherit_from = {INHERIT_FROM}

';

$this->imageset_keys = array(

';

$this->imageset_keys = array(

Line 198Line 210
							trigger_error($user->lang['DEACTIVATE_DEFAULT'] . adm_back_link($this->u_action), E_USER_WARNING);
}


							trigger_error($user->lang['DEACTIVATE_DEFAULT'] . adm_back_link($this->u_action), E_USER_WARNING);
}


 
						if (($action == 'deactivate' && confirm_box(true)) || $action == 'activate')
{

						$sql = 'UPDATE ' . STYLES_TABLE . '
SET style_active = ' . (($action == 'activate') ? 1 : 0) . '
WHERE style_id = ' . $style_id;

						$sql = 'UPDATE ' . STYLES_TABLE . '
SET style_active = ' . (($action == 'activate') ? 1 : 0) . '
WHERE style_id = ' . $style_id;

Line 215Line 229
								SET forum_style = 0
WHERE forum_style = ' . $style_id;
$db->sql_query($sql);

								SET forum_style = 0
WHERE forum_style = ' . $style_id;
$db->sql_query($sql);

 
							}
}
else if ($action == 'deactivate')
{
$s_hidden_fields = array(
'i' => $id,
'mode' => $mode,
'action' => $action,
'style_id' => $style_id,
);
confirm_box(false, $user->lang['CONFIRM_OPERATION'], build_hidden_fields($s_hidden_fields));

						}
break;
}

						}
break;
}

Line 485Line 510
							$db->sql_transaction('commit');

$cache->destroy('sql', STYLES_IMAGESET_DATA_TABLE);

							$db->sql_transaction('commit');

$cache->destroy('sql', STYLES_IMAGESET_DATA_TABLE);

 
							$cache->destroy('imageset_site_logo_md5');


add_log('admin', 'LOG_IMAGESET_REFRESHED', $imageset_row['imageset_name']);
trigger_error($user->lang['IMAGESET_REFRESHED'] . adm_back_link($this->u_action));


add_log('admin', 'LOG_IMAGESET_REFRESHED', $imageset_row['imageset_name']);
trigger_error($user->lang['IMAGESET_REFRESHED'] . adm_back_link($this->u_action));

Line 514Line 540
		global $user, $template, $db, $config, $phpbb_root_path, $phpEx;

$sql_from = '';

		global $user, $template, $db, $config, $phpbb_root_path, $phpEx;

$sql_from = '';

 
		$sql_sort = 'LOWER(' . $mode . '_name)';

		$style_count = array();

switch ($mode)
{
case 'style':
$sql_from = STYLES_TABLE;

		$style_count = array();

switch ($mode)
{
case 'style':
$sql_from = STYLES_TABLE;

 
				$sql_sort = 'style_active DESC, ' . $sql_sort;


$sql = 'SELECT user_style, COUNT(user_style) AS style_count
FROM ' . USERS_TABLE . '


$sql = 'SELECT user_style, COUNT(user_style) AS style_count
FROM ' . USERS_TABLE . '

Line 545Line 573
			case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;
break;

			case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;
break;

 
			
default:
trigger_error($user->lang['NO_MODE'] . adm_back_link($this->u_action), E_USER_WARNING);

		}

$l_prefix = strtoupper($mode);

		}

$l_prefix = strtoupper($mode);

Line 568Line 599
		);

$sql = "SELECT *

		);

$sql = "SELECT *

			FROM $sql_from";


			FROM $sql_from
ORDER BY $sql_sort ASC";

		$result = $db->sql_query($sql);

$installed = array();

		$result = $db->sql_query($sql);

$installed = array();

Line 604Line 636

'NAME' => $row[$mode . '_name'],
'STYLE_COUNT' => ($mode == 'style' && isset($style_count[$row['style_id']])) ? $style_count[$row['style_id']] : 0,


'NAME' => $row[$mode . '_name'],
'STYLE_COUNT' => ($mode == 'style' && isset($style_count[$row['style_id']])) ? $style_count[$row['style_id']] : 0,

 

'S_INACTIVE' => ($mode == 'style' && !$row['style_active']) ? true : false,

				)
);
}

				)
);
}

Line 618Line 652
		{
while (($file = readdir($dp)) !== false)
{

		{
while (($file = readdir($dp)) !== false)
{

 
				if ($file[0] == '.' || !is_dir($phpbb_root_path . 'styles/' . $file))
{
continue;
}


				$subpath = ($mode != 'style') ? "$mode/" : '';

				$subpath = ($mode != 'style') ? "$mode/" : '';

				if ($file[0] != '.' && file_exists("{$phpbb_root_path}styles/$file/$subpath$mode.cfg"))

				if (file_exists("{$phpbb_root_path}styles/$file/$subpath$mode.cfg"))

				{
if ($cfg = file("{$phpbb_root_path}styles/$file/$subpath$mode.cfg"))
{

				{
if ($cfg = file("{$phpbb_root_path}styles/$file/$subpath$mode.cfg"))
{

Line 628Line 667

if ($name && !in_array($name, $installed))
{


if ($name && !in_array($name, $installed))
{

							$new_ary[] = array(



							// The array key is used for sorting later on.
// $file is appended because $name doesn't have to be unique.
$new_ary[$name . $file] = array(

								'path'		=> $file,
'name' => $name,
'copyright' => $items['copyright'],

								'path'		=> $file,
'name' => $name,
'copyright' => $items['copyright'],

Line 644Line 685

if (sizeof($new_ary))
{


if (sizeof($new_ary))
{

 
			ksort($new_ary);


			foreach ($new_ary as $cfg)
{
$template->assign_block_vars('uninstalled', array(

			foreach ($new_ary as $cfg)
{
$template->assign_block_vars('uninstalled', array(

Line 669Line 712
	function edit_template($template_id)
{
global $phpbb_root_path, $phpEx, $config, $db, $cache, $user, $template, $safe_mode;

	function edit_template($template_id)
{
global $phpbb_root_path, $phpEx, $config, $db, $cache, $user, $template, $safe_mode;

 

if (defined('PHPBB_DISABLE_ACP_EDITOR'))
{
trigger_error($user->lang['EDITOR_DISABLED'] . adm_back_link($this->u_action));
}


$this->page_title = 'EDIT_TEMPLATE';



$this->page_title = 'EDIT_TEMPLATE';


Line 681Line 729
		$save_changes	= (isset($_POST['save'])) ? true : false;

// make sure template_file path doesn't go upwards

		$save_changes	= (isset($_POST['save'])) ? true : false;

// make sure template_file path doesn't go upwards

		$template_file = str_replace('..', '.', $template_file);

		$template_file = preg_replace('#\.{2,}#', '.', $template_file);

		
// Retrieve some information about the template
$sql = 'SELECT template_storedb, template_path, template_name

		
// Retrieve some information about the template
$sql = 'SELECT template_storedb, template_path, template_name

Line 694Line 742
		if (!$template_info)
{
trigger_error($user->lang['NO_TEMPLATE'] . adm_back_link($this->u_action), E_USER_WARNING);

		if (!$template_info)
{
trigger_error($user->lang['NO_TEMPLATE'] . adm_back_link($this->u_action), E_USER_WARNING);

 
		}

if ($save_changes && !check_form_key('acp_styles'))
{
trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING);
}
else if (!$save_changes)
{
add_form_key('acp_styles');

		}

// save changes to the template if the user submitted any

		}

// save changes to the template if the user submitted any

Line 704Line 761
			$additional = '';

// If the template is stored on the filesystem try to write the file else store it in the database

			$additional = '';

// If the template is stored on the filesystem try to write the file else store it in the database

			if (!$safe_mode && !$template_info['template_storedb'] && file_exists($file) && @is_writable($file))

			if (!$safe_mode && !$template_info['template_storedb'] && file_exists($file) && phpbb_is_writable($file))

			{
if (!($fp = @fopen($file, 'wb')))
{

			{
if (!($fp = @fopen($file, 'wb')))
{

					trigger_error($user->lang['NO_TEMPLATE'] . adm_back_link($this->u_action), E_USER_WARNING);


					// File exists and is writeable, but still not able to be written to
trigger_error(sprintf($user->lang['TEMPLATE_FILE_NOT_WRITABLE'], htmlspecialchars($template_file)) . adm_back_link($this->u_action), E_USER_WARNING);

				}
fwrite($fp, $template_data);
fclose($fp);

				}
fwrite($fp, $template_data);
fclose($fp);

Line 720Line 778
				// If it's not stored in the db yet, then update the template setting and store all template files in the db
if (!$template_info['template_storedb'])
{

				// If it's not stored in the db yet, then update the template setting and store all template files in the db
if (!$template_info['template_storedb'])
{

					$sql = 'UPDATE ' . STYLES_TEMPLATE_TABLE . '
SET template_storedb = 1
WHERE template_id = ' . $template_id;
$db->sql_query($sql);

$filelist = filelist("{$phpbb_root_path}styles/{$template_info['template_path']}/template", '', 'html');
$this->store_templates('insert', $template_id, $template_info['template_path'], $filelist);


					if ($super = $this->get_super('template', $template_id))
{
$this->store_in_db('template', $super['template_id']);
}
else
{
$this->store_in_db('template', $template_id);
}


add_log('admin', 'LOG_TEMPLATE_EDIT_DETAILS', $template_info['template_name']);
$additional .= '<br />' . $user->lang['EDIT_TEMPLATE_STORED_DB'];


add_log('admin', 'LOG_TEMPLATE_EDIT_DETAILS', $template_info['template_name']);
$additional .= '<br />' . $user->lang['EDIT_TEMPLATE_STORED_DB'];

Line 798Line 857
			}
$db->sql_freeresult($result);
unset($file_info);

			}
$db->sql_freeresult($result);
unset($file_info);

 
		}

if (empty($filelist['']))
{
trigger_error($user->lang['NO_TEMPLATE'] . adm_back_link($this->u_action), E_USER_WARNING);

		}

// Now create the categories

		}

// Now create the categories

Line 914Line 978
			trigger_error($user->lang['TEMPLATE_CACHE_CLEARED'] . adm_back_link($this->u_action . "&amp;action=cache&amp;id=$template_id"));
}


			trigger_error($user->lang['TEMPLATE_CACHE_CLEARED'] . adm_back_link($this->u_action . "&amp;action=cache&amp;id=$template_id"));
}


		$cache_prefix = 'tpl_' . $template_row['template_path'];

		$cache_prefix = 'tpl_' . str_replace('_', '-', $template_row['template_path']);


// Someone wants to see the cached source ... so we'll highlight it,
// add line numbers and indent it appropriately. This could be nasty


// Someone wants to see the cached source ... so we'll highlight it,
// add line numbers and indent it appropriately. This could be nasty

Line 965Line 1029

$filemtime = array();
if ($template_row['template_storedb'])


$filemtime = array();
if ($template_row['template_storedb'])

 
		{
$ids = array();
if (isset($template_row['template_inherits_id']) && $template_row['template_inherits_id'])
{
$ids[] = $template_row['template_inherits_id'];
}
$ids[] = $template_row['template_id'];

$filemtime = array();
$file_template_db = array();

foreach ($ids as $id)

		{
$sql = 'SELECT template_filename, template_mtime
FROM ' . STYLES_TEMPLATE_DATA_TABLE . "

		{
$sql = 'SELECT template_filename, template_mtime
FROM ' . STYLES_TEMPLATE_DATA_TABLE . "

				WHERE template_id = $template_id";

					WHERE template_id = $id";

			$result = $db->sql_query($sql);


			$result = $db->sql_query($sql);


			$filemtime = array();

 
			while ($row = $db->sql_fetchrow($result))
{
$filemtime[$row['template_filename']] = $row['template_mtime'];

			while ($row = $db->sql_fetchrow($result))
{
$filemtime[$row['template_filename']] = $row['template_mtime'];

 
					$file_template_db[$row['template_filename']] = $id;

			}
$db->sql_freeresult($result);

			}
$db->sql_freeresult($result);

 
			}

		}

// Get a list of cached template files and then retrieve additional information about them

		}

// Get a list of cached template files and then retrieve additional information about them

Line 984Line 1061

foreach ($file_ary as $file)
{


foreach ($file_ary as $file)
{

			$file 		= str_replace('/', '.', $file);

			$file		= str_replace('/', '.', $file);

			
// perform some dirty guessing to get the path right.
// We assume that three dots in a row were '../'

			
// perform some dirty guessing to get the path right.
// We assume that three dots in a row were '../'

			$tpl_file 	= str_replace('.', '/', $file);
$tpl_file = str_replace('///', '../', $tpl_file);

			$tpl_file	= str_replace('.', '/', $file);
$tpl_file = str_replace('///', '../', $tpl_file);

			
$filename = "{$cache_prefix}_$file.html.$phpEx";

if (!file_exists("{$phpbb_root_path}cache/$filename"))
{
continue;

			
$filename = "{$cache_prefix}_$file.html.$phpEx";

if (!file_exists("{$phpbb_root_path}cache/$filename"))
{
continue;

 
			}

$file_tpl = "{$phpbb_root_path}styles/{$template_row['template_path']}/template/$tpl_file.html";
$inherited = false;

if (isset($template_row['template_inherits_id']) && $template_row['template_inherits_id'])
{
if (!$template_row['template_storedb'])
{
if (!file_exists($file_tpl))
{
$file_tpl = "{$phpbb_root_path}styles/{$template_row['template_inherit_path']}/template/$tpl_file.html";
$inherited = true;
}
}
else
{
if ($file_template_db[$file . '.html'] == $template_row['template_inherits_id'])
{
$file_tpl = "{$phpbb_root_path}styles/{$template_row['template_inherit_path']}/template/$tpl_file.html";
$inherited = true;
}
}
}

// Correct the filename if it is stored in database and the file is in a subfolder.
if ($template_row['template_storedb'])
{
$file = str_replace('.', '/', $file);

			}

$template->assign_block_vars('file', array(

			}

$template->assign_block_vars('file', array(

Line 1003Line 1109

'CACHED' => $user->format_date(filemtime("{$phpbb_root_path}cache/$filename")),
'FILENAME' => $file,


'CACHED' => $user->format_date(filemtime("{$phpbb_root_path}cache/$filename")),
'FILENAME' => $file,

				'FILESIZE'		=> sprintf('%.1f KB', filesize("{$phpbb_root_path}cache/$filename") / 1024),
'MODIFIED' => $user->format_date((!$template_row['template_storedb']) ? filemtime("{$phpbb_root_path}styles/{$template_row['template_path']}/template/$tpl_file.html") : $filemtime[$file . '.html']))


				'FILENAME_PATH'	=> $file_tpl,
'FILESIZE' => get_formatted_filesize(filesize("{$phpbb_root_path}cache/$filename")),
'MODIFIED' => $user->format_date((!$template_row['template_storedb']) ? filemtime($file_tpl) : $filemtime[$file . '.html']))

			);
}
unset($filemtime);

			);
}
unset($filemtime);

Line 1061Line 1168
			$message = $user->lang['THEME_UPDATED'];

// If the theme is stored on the filesystem try to write the file else store it in the database

			$message = $user->lang['THEME_UPDATED'];

// If the theme is stored on the filesystem try to write the file else store it in the database

			if (!$safe_mode && !$theme_info['theme_storedb'] && file_exists($file) && @is_writable($file))

			if (!$safe_mode && !$theme_info['theme_storedb'] && file_exists($file) && phpbb_is_writable($file))

			{
if (!($fp = @fopen($file, 'wb')))
{

			{
if (!($fp = @fopen($file, 'wb')))
{

Line 1200Line 1307
			'TEXT_ROWS'			=> $text_rows)
);
}

			'TEXT_ROWS'			=> $text_rows)
);
}



 

/**
* Edit imagesets


/**
* Edit imagesets

Line 1212Line 1318
		global $db, $user, $phpbb_root_path, $cache, $template;

$this->page_title = 'EDIT_IMAGESET';

		global $db, $user, $phpbb_root_path, $cache, $template;

$this->page_title = 'EDIT_IMAGESET';

 

if (!$imageset_id)
{
trigger_error($user->lang['NO_IMAGESET'] . adm_back_link($this->u_action), E_USER_WARNING);
}


$update = (isset($_POST['update'])) ? true : false;



$update = (isset($_POST['update'])) ? true : false;


		$imgname	= request_var('imgname', '');
$imgpath = request_var('imgpath', '');
$imgsize = request_var('imgsize', false);
$imgwidth = request_var('imgwidth', 0);
$imgheight = request_var('imgheight', 0);


		$imgname	= request_var('imgname', 'site_logo');






		$imgname	= preg_replace('#[^a-z0-9\-+_]#i', '', $imgname);

		$imgname	= preg_replace('#[^a-z0-9\-+_]#i', '', $imgname);

		$imgpath	= str_replace('..', '.', $imgpath);

		$sql_extra = $imgnamelang = '';





		if ($imageset_id)
{

 
			$sql = 'SELECT imageset_path, imageset_name
FROM ' . STYLES_IMAGESET_TABLE . "
WHERE imageset_id = $imageset_id";
$result = $db->sql_query($sql);
$imageset_row = $db->sql_fetchrow($result);
$db->sql_freeresult($result);

			$sql = 'SELECT imageset_path, imageset_name
FROM ' . STYLES_IMAGESET_TABLE . "
WHERE imageset_id = $imageset_id";
$result = $db->sql_query($sql);
$imageset_row = $db->sql_fetchrow($result);
$db->sql_freeresult($result);

 

if (!$imageset_row)
{
trigger_error($user->lang['NO_IMAGESET'] . adm_back_link($this->u_action), E_USER_WARNING);
}


$imageset_path = $imageset_row['imageset_path'];
$imageset_name = $imageset_row['imageset_name'];



$imageset_path = $imageset_row['imageset_path'];
$imageset_name = $imageset_row['imageset_name'];


			$sql_extra = '';

 
			if (strpos($imgname, '-') !== false)
{
list($imgname, $imgnamelang) = explode('-', $imgname);

			if (strpos($imgname, '-') !== false)
{
list($imgname, $imgnamelang) = explode('-', $imgname);

Line 1256Line 1364
			$image_height	= $imageset_data_row['image_height'];
$image_lang = $imageset_data_row['image_lang'];
$image_id = $imageset_data_row['image_id'];

			$image_height	= $imageset_data_row['image_height'];
$image_lang = $imageset_data_row['image_lang'];
$image_id = $imageset_data_row['image_id'];


if (!$imageset_row)
{
trigger_error($user->lang['NO_IMAGESET'] . adm_back_link($this->u_action), E_USER_WARNING);
}

		$imgsize		= ($imageset_data_row['image_width'] && $imageset_data_row['image_height']) ? 1 : 0;






// Check to see whether the selected image exists in the table
$valid_name = ($update) ? false : true;


// Check to see whether the selected image exists in the table
$valid_name = ($update) ? false : true;

Line 1274Line 1378
				}
}


				}
}


			if ($update && isset($_POST['imgpath']))
{
if ($valid_name)

		if ($update && isset($_POST['imgpath']) && $valid_name)



				{
// 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 = request_var('imgwidth', 0);
$imgheight = request_var('imgheight', 0);

				{
// 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 = request_var('imgwidth', 0);
$imgheight = request_var('imgheight', 0);

 
			$imgsize	= request_var('imgsize', 0);
$imgpath = request_var('imgpath', '');
$imgpath = str_replace('..', '.', $imgpath);

// If no dimensions selected, we reset width and height to 0 ;)
if (!$imgsize)
{
$imgwidth = $imgheight = 0;
}


					$imglang = '';

if ($imgpath && !file_exists("{$phpbb_root_path}styles/$imageset_path/imageset/$imgpath"))

					$imglang = '';

if ($imgpath && !file_exists("{$phpbb_root_path}styles/$imageset_path/imageset/$imgpath"))

Line 1289Line 1401
						trigger_error($user->lang['NO_IMAGE_ERROR'] . adm_back_link($this->u_action), E_USER_WARNING);
}


						trigger_error($user->lang['NO_IMAGE_ERROR'] . adm_back_link($this->u_action), E_USER_WARNING);
}


 
			// Determine width/height. If dimensions included and no width/height given, we detect them automatically...

					if ($imgsize && $imgpath)
{
if (!$imgwidth || !$imgheight)

					if ($imgsize && $imgpath)
{
if (!$imgwidth || !$imgheight)

Line 1300Line 1413
						$imgwidth	= ($imgname != 'poll_center') ? (int) $imgwidth : 0;
$imgheight = (int) $imgheight;
}

						$imgwidth	= ($imgname != 'poll_center') ? (int) $imgwidth : 0;
$imgheight = (int) $imgheight;
}



 

if (strpos($imgpath, '/') !== false)
{


if (strpos($imgpath, '/') !== false)
{

Line 1344Line 1456
					$image_width	= $imgwidth;
$image_height = $imgheight;
$image_lang = $imglang;

					$image_width	= $imgwidth;
$image_height = $imgheight;
$image_lang = $imglang;

				}
}

 
		}

$imglang = '';

		}

$imglang = '';

Line 1467Line 1577
			'U_BACK'			=> $this->u_action,
'NAME' => $imageset_name,
'A_NAME' => addslashes($imageset_name),

			'U_BACK'			=> $this->u_action,
'NAME' => $imageset_name,
'A_NAME' => addslashes($imageset_name),

 
			'PATH'				=> $imageset_path,
'A_PATH' => addslashes($imageset_path),

			'ERROR'				=> !$valid_name,
'IMG_SRC' => ($image_found) ? '../styles/' . $imageset_path . '/imageset/' . $img_val : 'images/no_image.png',
'IMAGE_SELECT' => $image_found

			'ERROR'				=> !$valid_name,
'IMG_SRC' => ($image_found) ? '../styles/' . $imageset_path . '/imageset/' . $img_val : 'images/no_image.png',
'IMAGE_SELECT' => $image_found

Line 1488Line 1600
		{
case 'style':
$sql_from = STYLES_TABLE;

		{
case 'style':
$sql_from = STYLES_TABLE;

				$sql_select = 'style_name';

				$sql_select = 'style_id, style_name, template_id, theme_id, imageset_id';

				$sql_where = 'AND style_active = 1';
break;

case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;

				$sql_where = 'AND style_active = 1';
break;

case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;

				$sql_select = 'template_name, template_path, template_storedb';

				$sql_select = 'template_id, template_name, template_path, template_storedb';

			break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;

			break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;

				$sql_select = 'theme_name, theme_path, theme_storedb';

				$sql_select = 'theme_id, theme_name, theme_path, theme_storedb';

			break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;

			break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;

				$sql_select = 'imageset_name, imageset_path';

				$sql_select = 'imageset_id, imageset_name, imageset_path';

			break;

			break;

 
		}

if ($mode === 'template' && ($conflicts = $this->check_inheritance($mode, $style_id)))
{
$l_type = strtoupper($mode);
$msg = $user->lang[$l_type . '_DELETE_DEPENDENT'];
foreach ($conflicts as $id => $values)
{
$msg .= '<br />' . $values['template_name'];
}

trigger_error($msg . adm_back_link($this->u_action), E_USER_WARNING);

		}

$l_prefix = strtoupper($mode);

		}

$l_prefix = strtoupper($mode);

Line 1522Line 1646
			trigger_error($user->lang['NO_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}


			trigger_error($user->lang['NO_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}


		$sql = "SELECT {$mode}_id, {$mode}_name
FROM $sql_from
WHERE {$mode}_id <> $style_id
$sql_where
ORDER BY {$mode}_name ASC";
$result = $db->sql_query($sql);

		$s_only_component = $this->display_component_options($mode, $style_row[$mode . '_id'], $style_row);










		$s_options = '';

if ($row = $db->sql_fetchrow($result))
{
do
{
$s_options .= '<option value="' . $row[$mode . '_id'] . '">' . $row[$mode . '_name'] . '</option>';
}
while ($row = $db->sql_fetchrow($result));
}
else

		if ($s_only_component)











		{
trigger_error($user->lang['ONLY_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}

		{
trigger_error($user->lang['ONLY_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}

		$db->sql_freeresult($result);

 

if ($update)


if ($update)

 
		{
if ($mode == 'style')

		{
$sql = "DELETE FROM $sql_from
WHERE {$mode}_id = $style_id";
$db->sql_query($sql);


		{
$sql = "DELETE FROM $sql_from
WHERE {$mode}_id = $style_id";
$db->sql_query($sql);


			if ($mode == 'style')
{

 
				$sql = 'UPDATE ' . USERS_TABLE . "
SET user_style = $new_id
WHERE user_style = $style_id";

				$sql = 'UPDATE ' . USERS_TABLE . "
SET user_style = $new_id
WHERE user_style = $style_id";

Line 1566Line 1674
				if ($style_id == $config['default_style'])
{
set_config('default_style', $new_id);

				if ($style_id == $config['default_style'])
{
set_config('default_style', $new_id);

 
				}

// Remove the components
$components = array('template', 'theme', 'imageset');
foreach ($components as $component)
{
$new_id = request_var('new_' . $component . '_id', 0);
$component_id = $style_row[$component . '_id'];
$this->remove_component($component, $component_id, $new_id, $style_id);

				}
}
else
{

				}
}
else
{

				if ($mode == 'imageset')
{
$sql = 'DELETE FROM ' . STYLES_IMAGESET_DATA_TABLE . "
WHERE imageset_id = $style_id";
$db->sql_query($sql);
}
$sql = 'UPDATE ' . STYLES_TABLE . "
SET {$mode}_id = $new_id
WHERE {$mode}_id = $style_id";
$db->sql_query($sql);

				$this->remove_component($mode, $style_id, $new_id);










			}

$cache->destroy('sql', STYLES_TABLE);

			}

$cache->destroy('sql', STYLES_TABLE);

Line 1593Line 1701

$template->assign_vars(array(
'S_DELETE' => true,


$template->assign_vars(array(
'S_DELETE' => true,

			'S_REPLACE_OPTIONS'	=> $s_options,

 

'L_TITLE' => $user->lang[$this->page_title],
'L_EXPLAIN' => $user->lang[$this->page_title . '_EXPLAIN'],


'L_TITLE' => $user->lang[$this->page_title],
'L_EXPLAIN' => $user->lang[$this->page_title . '_EXPLAIN'],

Line 1607Line 1714
			'NAME'			=> $style_row[$mode . '_name'],
)
);

			'NAME'			=> $style_row[$mode . '_name'],
)
);

 

if ($mode == 'style')
{
$template->assign_vars(array(
'S_DELETE_STYLE' => true,
));
}
}

/**
* Remove template/theme/imageset entry from the database
*/
function remove_component($component, $component_id, $new_id, $style_id = false)
{
global $db;

if (($new_id == 0) || ($component === 'template' && ($conflicts = $this->check_inheritance($component, $component_id))))
{
// We can not delete the template, as the user wants to keep the component or an other template is inheriting from this one.
return;
}

$component_in_use = array();
if ($component != 'style')
{
$component_in_use = $this->component_in_use($component, $component_id, $style_id);
}

if (($new_id == -1) && !empty($component_in_use))
{
// We can not delete the component, as it is still in use
return;
}

if ($component == 'imageset')
{
$sql = 'DELETE FROM ' . STYLES_IMAGESET_DATA_TABLE . "
WHERE imageset_id = $component_id";
$db->sql_query($sql);
}

switch ($component)
{
case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;
break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;
break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;;
break;
}

$sql = "DELETE FROM $sql_from
WHERE {$component}_id = $component_id";
$db->sql_query($sql);

$sql = 'UPDATE ' . STYLES_TABLE . "
SET {$component}_id = $new_id
WHERE {$component}_id = $component_id";
$db->sql_query($sql);
}

/**
* Display the options which can be used to replace a style/template/theme/imageset
*
* @return boolean Returns true if the component is the only component and can not be deleted.
*/
function display_component_options($component, $component_id, $style_row = false, $style_id = false)
{
global $db, $template, $user;

$is_only_component = true;
$component_in_use = array();
if ($component != 'style')
{
$component_in_use = $this->component_in_use($component, $component_id, $style_id);
}

$sql_where = '';
switch ($component)
{
case 'style':
$sql_from = STYLES_TABLE;
$sql_where = 'WHERE style_active = 1';
break;

case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;
$sql_where = 'WHERE template_inherits_id <> ' . $component_id;
break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;
break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;
break;
}

$s_options = '';
if (($component != 'style') && empty($component_in_use))
{
// If it is not in use, there must be another component
$is_only_component = false;

$sql = "SELECT {$component}_id, {$component}_name
FROM $sql_from
WHERE {$component}_id = {$component_id}";
$result = $db->sql_query($sql);
$row = $db->sql_fetchrow($result);
$db->sql_freeresult($result);

$s_options .= '<option value="-1" selected="selected">' . $user->lang['DELETE_' . strtoupper($component)] . '</option>';
$s_options .= '<option value="0">' . sprintf($user->lang['KEEP_' . strtoupper($component)], $row[$component . '_name']) . '</option>';
}
else
{
$sql = "SELECT {$component}_id, {$component}_name
FROM $sql_from
$sql_where
ORDER BY {$component}_name ASC";
$result = $db->sql_query($sql);

$s_keep_option = $s_options = '';
while ($row = $db->sql_fetchrow($result))
{
if ($row[$component . '_id'] != $component_id)
{
$is_only_component = false;
$s_options .= '<option value="' . $row[$component . '_id'] . '">' . sprintf($user->lang['REPLACE_WITH_OPTION'], $row[$component . '_name']) . '</option>';
}
else if ($component != 'style')
{
$s_keep_option = '<option value="0" selected="selected">' . sprintf($user->lang['KEEP_' . strtoupper($component)], $row[$component . '_name']) . '</option>';
}
}
$db->sql_freeresult($result);
$s_options = $s_keep_option . $s_options;
}

if (!$style_row)
{
$template->assign_var('S_REPLACE_' . strtoupper($component) . '_OPTIONS', $s_options);
}
else
{
$template->assign_var('S_REPLACE_OPTIONS', $s_options);
if ($component == 'style')
{
$components = array('template', 'theme', 'imageset');
foreach ($components as $component)
{
$this->display_component_options($component, $style_row[$component . '_id'], false, $component_id, true);
}
}
}

return $is_only_component;
}

/**
* Check whether the component is still used by another style or component
*/
function component_in_use($component, $component_id, $style_id = false)
{
global $db;

$component_in_use = array();

if ($style_id)
{
$sql = 'SELECT style_id, style_name
FROM ' . STYLES_TABLE . "
WHERE {$component}_id = {$component_id}
AND style_id <> {$style_id}
ORDER BY style_name ASC";
}
else
{
$sql = 'SELECT style_id, style_name
FROM ' . STYLES_TABLE . "
WHERE {$component}_id = {$component_id}
ORDER BY style_name ASC";
}
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
$component_in_use[] = $row['style_name'];
}
$db->sql_freeresult($result);

if ($component === 'template' && ($conflicts = $this->check_inheritance($component, $component_id)))
{
foreach ($conflicts as $temp_id => $conflict_data)
{
$component_in_use[] = $conflict_data['template_name'];
}
}

return $component_in_use;

	}

/**

	}

/**

Line 1708Line 2020
				trigger_error($user->lang['NO_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}


				trigger_error($user->lang['NO_' . $l_prefix] . adm_back_link($this->u_action), E_USER_WARNING);
}


			$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');

			$var_ary = array('style_id', 'style_name', 'style_copyright', 'template_id', 'template_name', 'template_path', 'template_copyright', 'template_storedb', 'template_inherits_id', '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)
{


foreach ($var_ary as $var)
{

Line 1739Line 2051
			// Export template core code
if ($mode == 'template' || $inc_template)
{

			// Export template core code
if ($mode == 'template' || $inc_template)
{

				$template_cfg = str_replace(array('{MODE}', '{NAME}', '{COPYRIGHT}', '{VERSION}'), array($mode, $style_row['template_name'], $style_row['template_copyright'], $config['version']), $this->template_cfg);
$template_cfg .= "\nbbcode_bitfield = {$style_row['bbcode_bitfield']}";
















				$use_template_name = $style_row['template_name'];

// Add the inherit from variable, depending on it's use...
if ($style_row['template_inherits_id'])
{
// Get the template name
$sql = 'SELECT template_name
FROM ' . STYLES_TEMPLATE_TABLE . '
WHERE template_id = ' . (int) $style_row['template_inherits_id'];
$result = $db->sql_query($sql);
$use_template_name = (string) $db->sql_fetchfield('template_name');
$db->sql_freeresult($result);
}

$template_cfg = str_replace(array('{MODE}', '{NAME}', '{COPYRIGHT}', '{VERSION}', '{INHERIT_FROM}'), array($mode, $style_row['template_name'], $style_row['template_copyright'], $config['version'], $use_template_name), $this->template_cfg);

$template_cfg .= "\n\nbbcode_bitfield = {$style_row['bbcode_bitfield']}";


$data[] = array(
'src' => $template_cfg,


$data[] = array(
'src' => $template_cfg,

Line 1913Line 2240
			{
case 'tar':
$ext = '.tar';

			{
case 'tar':
$ext = '.tar';

					$mimetype = 'x-tar';
$compress = 'compress_tar';

 
				break;

case 'zip':
$ext = '.zip';

				break;

case 'zip':
$ext = '.zip';

					$mimetype = 'zip';

 
				break;

case 'tar.gz':
$ext = '.tar.gz';

				break;

case 'tar.gz':
$ext = '.tar.gz';

					$mimetype = 'x-gzip';

 
				break;

case 'tar.bz2':
$ext = '.tar.bz2';

				break;

case 'tar.bz2':
$ext = '.tar.bz2';

					$mimetype = 'x-bzip2';

 
				break;

default:

				break;

default:

Line 2085Line 2407
			$style_active = request_var('style_active', 0);
$style_default = request_var('style_default', 0);
$store_db = request_var('store_db', 0);

			$style_active = request_var('style_active', 0);
$style_default = request_var('style_default', 0);
$store_db = request_var('store_db', 0);

 

// If the admin selected the style to be the default style, but forgot to activate it... we will do it for him
if ($style_default)
{
$style_active = 1;
}

$sql = "SELECT {$mode}_id, {$mode}_name
FROM $sql_from
WHERE {$mode}_id <> $style_id
AND LOWER({$mode}_name) = '" . $db->sql_escape(strtolower($name)) . "'";
$result = $db->sql_query($sql);
$conflict = $db->sql_fetchrow($result);
$db->sql_freeresult($result);


if ($mode == 'style' && (!$template_id || !$theme_id || !$imageset_id))
{


if ($mode == 'style' && (!$template_id || !$theme_id || !$imageset_id))
{

Line 2096Line 2432
				$error[] = $user->lang['DEACTIVATE_DEFAULT'];
}


				$error[] = $user->lang['DEACTIVATE_DEFAULT'];
}


			if (!$name)

			if (!$name || $conflict)

			{
$error[] = $user->lang[$l_type . '_ERR_STYLE_NAME'];
}

			{
$error[] = $user->lang[$l_type . '_ERR_STYLE_NAME'];
}

Line 2105Line 2441
			{
// a rather elaborate check we have to do here once to avoid trouble later
$check = "{$phpbb_root_path}styles/" . $style_row["{$mode}_path"] . (($mode === 'theme') ? '/theme/stylesheet.css' : '/template');

			{
// a rather elaborate check we have to do here once to avoid trouble later
$check = "{$phpbb_root_path}styles/" . $style_row["{$mode}_path"] . (($mode === 'theme') ? '/theme/stylesheet.css' : '/template');

				if (($style_row["{$mode}_storedb"] != $store_db) && !$store_db && ($safe_mode || !@is_writable($check)))

				if (($style_row["{$mode}_storedb"] != $store_db) && !$store_db && ($safe_mode || !phpbb_is_writable($check)))

				{
$error[] = $user->lang['EDIT_' . strtoupper($mode) . '_STORED_DB'];
$store_db = 1;

				{
$error[] = $user->lang['EDIT_' . strtoupper($mode) . '_STORED_DB'];
$store_db = 1;

Line 2185Line 2521
						{
$theme_data = $this->db_theme_data($style_row);
}

						{
$theme_data = $this->db_theme_data($style_row);
}

						else if (!$store_db && !$safe_mode && @is_writable("{$phpbb_root_path}styles/{$style_row['theme_path']}/theme/stylesheet.css"))

						else if (!$store_db && !$safe_mode && phpbb_is_writable("{$phpbb_root_path}styles/{$style_row['theme_path']}/theme/stylesheet.css"))

						{
$store_db = 1;
$theme_data = $style_row['theme_data'];

						{
$store_db = 1;
$theme_data = $style_row['theme_data'];

Line 2209Line 2545

if ($style_row['template_storedb'] != $store_db)
{


if ($style_row['template_storedb'] != $store_db)
{

						if (!$store_db && !$safe_mode && @is_writable("{$phpbb_root_path}styles/{$style_row['template_path']}/template"))

						if ($super = $this->get_super($mode, $style_row['template_id']))

						{

						{

							$sql = 'SELECT *
FROM ' . STYLES_TEMPLATE_DATA_TABLE . "
WHERE template_id = $style_id";
$result = $db->sql_query($sql);

while ($row = $db->sql_fetchrow($result))

							$error[] = (sprintf($user->lang["{$l_type}_INHERITS"], $super['template_name']));
$sql_ary = array();
}
else



							{

							{

								if (!($fp = @fopen("{$phpbb_root_path}styles/{$style_row['template_path']}/template/" . $row['template_filename'], 'wb')))

							if (!$store_db && !$safe_mode && phpbb_is_writable("{$phpbb_root_path}styles/{$style_row['template_path']}/template"))

								{

								{

									$store_db = 1;
$error[] = $user->lang['EDIT_TEMPLATE_STORED_DB'];
break;
}

fwrite($fp, $row['template_data']);
fclose($fp);
}
$db->sql_freeresult($result);

if (!$store_db)

								$err = $this->store_in_fs('template', $style_row['template_id']);
if ($err)










							{

							{

								$sql = 'DELETE FROM ' . STYLES_TEMPLATE_DATA_TABLE . "
WHERE template_id = $style_id";
$db->sql_query($sql);

									$error += $err;



							}
}
else if ($store_db)
{

							}
}
else if ($store_db)
{

							$filelist = filelist("{$phpbb_root_path}styles/{$style_row['template_path']}/template", '', 'html');
$this->store_templates('insert', $style_id, $style_row['template_path'], $filelist);

								$this->store_in_db('template', $style_row['template_id']);


						}
else
{

						}
else
{

Line 2254Line 2576
						$sql_ary += array(
'template_storedb' => $store_db,
);

						$sql_ary += array(
'template_storedb' => $store_db,
);

 
						}

					}
break;
}

					}
break;
}

Line 2301Line 2624
					${$element . '_options'} .= '<option value="' . $row[$element . '_id'] . '"' . $selected . '>' . $row[$element . '_name'] . '</option>';
}
$db->sql_freeresult($result);

					${$element . '_options'} .= '<option value="' . $row[$element . '_id'] . '"' . $selected . '>' . $row[$element . '_name'] . '</option>';
}
$db->sql_freeresult($result);

 
			}
}

if ($mode == 'template')
{
$super = array();
if (isset($style_row[$mode . '_inherits_id']) && $style_row['template_inherits_id'])
{
$super = $this->get_super($mode, $style_row['template_id']);

			}
}


			}
}


Line 2314Line 2646
			'S_THEME'				=> ($mode == 'theme') ? true : false,
'S_IMAGESET' => ($mode == 'imageset') ? true : false,
'S_STORE_DB' => (isset($style_row[$mode . '_storedb'])) ? $style_row[$mode . '_storedb'] : 0,

			'S_THEME'				=> ($mode == 'theme') ? true : false,
'S_IMAGESET' => ($mode == 'imageset') ? true : false,
'S_STORE_DB' => (isset($style_row[$mode . '_storedb'])) ? $style_row[$mode . '_storedb'] : 0,

 
			'S_STORE_DB_DISABLED'	=> (isset($style_row[$mode . '_inherits_id'])) ? $style_row[$mode . '_inherits_id'] : 0,

			'S_STYLE_ACTIVE'		=> (isset($style_row['style_active'])) ? $style_row['style_active'] : 0,
'S_STYLE_DEFAULT' => (isset($style_row['style_default'])) ? $style_row['style_default'] : 0,

			'S_STYLE_ACTIVE'		=> (isset($style_row['style_active'])) ? $style_row['style_active'] : 0,
'S_STYLE_DEFAULT' => (isset($style_row['style_default'])) ? $style_row['style_default'] : 0,

 
			'S_SUPERTEMPLATE'		=> (isset($style_row[$mode . '_inherits_id']) && $style_row[$mode . '_inherits_id']) ? $super['template_name'] : 0,


'S_TEMPLATE_OPTIONS' => ($mode == 'style') ? $template_options : '',
'S_THEME_OPTIONS' => ($mode == 'style') ? $theme_options : '',


'S_TEMPLATE_OPTIONS' => ($mode == 'style') ? $template_options : '',
'S_THEME_OPTIONS' => ($mode == 'style') ? $theme_options : '',

Line 2353Line 2687
		else
{
$content = '';

		else
{
$content = '';

 
		}
if (defined('DEBUG'))
{
$content = "/* BEGIN @include $filename */ \n $content \n /* END @include $filename */ \n";

		}

return $content;

		}

return $content;

Line 2388Line 2726

// Match CSS imports
$matches = array();


// Match CSS imports
$matches = array();

		preg_match_all('/@import url\(["\'](.*)["\']\);/i', $stylesheet, $matches);






		preg_match_all('/@import url\((["\'])(.*)\1\);/i', $stylesheet, $matches);

// remove commented stylesheets (very simple parser, allows only whitespace
// around an @import statement)
preg_match_all('#/\*\s*@import url\((["\'])(.*)\1\);\s\*/#i', $stylesheet, $commented);
$matches[2] = array_diff($matches[2], $commented[2]);


if (sizeof($matches))
{
foreach ($matches[0] as $idx => $match)
{


if (sizeof($matches))
{
foreach ($matches[0] as $idx => $match)
{

				$stylesheet = str_replace($match, acp_styles::load_css_file($theme_row['theme_path'], $matches[1][$idx]), $stylesheet);




				if (isset($matches[2][$idx]))
{
$stylesheet = str_replace($match, acp_styles::load_css_file($theme_row['theme_path'], $matches[2][$idx]), $stylesheet);
}

			}
}


			}
}


Line 2419Line 2765
				{
trigger_error("Could not open {$phpbb_root_path}styles/$template_path$pathfile$file", E_USER_ERROR);
}

				{
trigger_error("Could not open {$phpbb_root_path}styles/$template_path$pathfile$file", E_USER_ERROR);
}

				$template_data = fread($fp, filesize("{$phpbb_root_path}styles/$template_path$pathfile$file"));









$filesize = filesize("{$phpbb_root_path}styles/$template_path$pathfile$file");

if ($filesize)
{
$template_data = fread($fp, $filesize);
}


				fclose($fp);

				fclose($fp);

 

if (!$filesize)
{
// File is empty
continue;
}


if (preg_match_all('#<!-- INCLUDE (.*?\.html) -->#is', $template_data, $matches))
{


if (preg_match_all('#<!-- INCLUDE (.*?\.html) -->#is', $template_data, $matches))
{

Line 2478Line 2837
	{
global $phpbb_root_path, $phpEx, $user;


	{
global $phpbb_root_path, $phpEx, $user;


		$cache_prefix = 'tpl_' . $template_path;

		$cache_prefix = 'tpl_' . str_replace('_', '-', $template_path);


if (!($dp = @opendir("{$phpbb_root_path}cache")))
{


if (!($dp = @opendir("{$phpbb_root_path}cache")))
{

Line 2514Line 2873
	{
global $phpbb_root_path, $phpEx, $user;


	{
global $phpbb_root_path, $phpEx, $user;


		$cache_prefix = 'tpl_' . $template_row['template_path'];

		$cache_prefix = 'tpl_' . str_replace('_', '-', $template_row['template_path']);


if (!$file_ary || !is_array($file_ary))
{


if (!$file_ary || !is_array($file_ary))
{

Line 2614Line 2973
						if (!$style_row[$element . '_name'])
{
$style_row[$element . '_name'] = $reqd_template;

						if (!$style_row[$element . '_name'])
{
$style_row[$element . '_name'] = $reqd_template;

 
						}

// Merge other information to installcfg... if present
$cfg_file = $phpbb_root_path . 'styles/' . $install_path . '/' . $element . '/' . $element . '.cfg';

if (file_exists($cfg_file))
{
$cfg_contents = parse_cfg_file($cfg_file);

// Merge only specific things. We may need them later.
foreach (array('inherit_from', 'parse_css_file') as $key)
{
if (!empty($cfg_contents[$key]) && !isset($installcfg[$key]))
{
$installcfg[$key] = $cfg_contents[$key];
}
}

						}
}


						}
}


Line 2673Line 3049
			'S_DETAILS'			=> true,
'S_INSTALL' => true,
'S_ERROR_MSG' => (sizeof($error)) ? true : false,

			'S_DETAILS'			=> true,
'S_INSTALL' => true,
'S_ERROR_MSG' => (sizeof($error)) ? true : false,

 
			'S_LOCATION'		=> (isset($installcfg['inherit_from']) && $installcfg['inherit_from']) ? false : true,

			'S_STYLE'			=> ($mode == 'style') ? true : false,
'S_TEMPLATE' => ($mode == 'template') ? true : false,

			'S_STYLE'			=> ($mode == 'style') ? true : false,
'S_TEMPLATE' => ($mode == 'template') ? true : false,

 
			'S_SUPERTEMPLATE'	=> (isset($installcfg['inherit_from'])) ? $installcfg['inherit_from'] : '',

			'S_THEME'			=> ($mode == 'theme') ? true : false,

'S_STORE_DB' => (isset($style_row[$mode . '_storedb'])) ? $style_row[$mode . '_storedb'] : 0,

			'S_THEME'			=> ($mode == 'theme') ? true : false,

'S_STORE_DB' => (isset($style_row[$mode . '_storedb'])) ? $style_row[$mode . '_storedb'] : 0,

Line 3024Line 3402
	function install_element($mode, &$error, $action, $root_path, &$id, $name, $path, $copyright, $store_db = 0)
{
global $phpbb_root_path, $db, $user;

	function install_element($mode, &$error, $action, $root_path, &$id, $name, $path, $copyright, $store_db = 0)
{
global $phpbb_root_path, $db, $user;

 

// we parse the cfg here (again)
$cfg_data = parse_cfg_file("$root_path$mode/$mode.cfg");


switch ($mode)
{


switch ($mode)
{

Line 3076Line 3457
			}

$error[] = $user->lang[$l_type . '_ERR_NAME_EXIST'];

			}

$error[] = $user->lang[$l_type . '_ERR_NAME_EXIST'];

 
		}

if (isset($cfg_data['inherit_from']) && $cfg_data['inherit_from'])
{
if ($mode === 'template')
{
$select_bf = ', bbcode_bitfield';
}
else
{
$select_bf = '';
}

$sql = "SELECT {$mode}_id, {$mode}_name, {$mode}_path, {$mode}_storedb $select_bf
FROM $sql_from
WHERE {$mode}_name = '" . $db->sql_escape($cfg_data['inherit_from']) . "'
AND {$mode}_inherits_id = 0";
$result = $db->sql_query($sql);
$row = $db->sql_fetchrow($result);
$db->sql_freeresult($result);
if (!$row)
{
$error[] = sprintf($user->lang[$l_type . '_ERR_REQUIRED_OR_INCOMPLETE'], $cfg_data['inherit_from']);
}
else
{
$inherit_id = $row["{$mode}_id"];
$inherit_path = $row["{$mode}_path"];
$inherit_bf = ($mode === 'template') ? $row["bbcode_bitfield"] : false;
$cfg_data['store_db'] = $row["{$mode}_storedb"];
$store_db = $row["{$mode}_storedb"];
}
}
else
{
$inherit_id = 0;
$inherit_path = '';
$inherit_bf = false;

		}

if (sizeof($error))

		}

if (sizeof($error))

Line 3093Line 3512
		{
case 'template':
// We check if the template author defined a different bitfield

		{
case 'template':
// We check if the template author defined a different bitfield

				$cfg_data = parse_cfg_file("$root_path$mode/template.cfg");


 
				if (!empty($cfg_data['template_bitfield']))
{
$sql_ary['bbcode_bitfield'] = $cfg_data['template_bitfield'];

				if (!empty($cfg_data['template_bitfield']))
{
$sql_ary['bbcode_bitfield'] = $cfg_data['template_bitfield'];

 
				}
else if ($inherit_bf)
{
$sql_ary['bbcode_bitfield'] = $inherit_bf;

				}
else
{

				}
else
{

Line 3106Line 3527

// We set a pre-defined bitfield here which we may use further in 3.2
$sql_ary += array(


// We set a pre-defined bitfield here which we may use further in 3.2
$sql_ary += array(

					'template_storedb'	=> $store_db

					'template_storedb'		=> $store_db,

				);

				);

 
				if (isset($cfg_data['inherit_from']) && $cfg_data['inherit_from'])
{
$sql_ary += array(
'template_inherits_id' => $inherit_id,
'template_inherit_path' => $inherit_path,
);
}

			break;

case 'theme':
// We are only interested in the theme configuration for now

			break;

case 'theme':
// We are only interested in the theme configuration for now

				$theme_cfg = parse_cfg_file("{$phpbb_root_path}styles/$path/theme/theme.cfg");

 




				if (isset($theme_cfg['parse_css_file']) && $theme_cfg['parse_css_file'])

				if (isset($cfg_data['parse_css_file']) && $cfg_data['parse_css_file'])

				{
$store_db = 1;
}

				{
$store_db = 1;
}

Line 3252Line 3679

// Return store_db in case it had to be altered
return $store_db;


// Return store_db in case it had to be altered
return $store_db;

 
	}

/**
* Checks downwards dependencies
*
* @access public
* @param string $mode The element type to check - only template is supported
* @param int $id The template id
* @returns false if no component inherits, array with name, path and id for each subtemplate otherwise
*/
function check_inheritance($mode, $id)
{
global $db;

$l_type = strtoupper($mode);

switch ($mode)
{
case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;
break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;
break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;
break;
}

$sql = "SELECT {$mode}_id, {$mode}_name, {$mode}_path
FROM $sql_from
WHERE {$mode}_inherits_id = " . (int) $id;
$result = $db->sql_query($sql);

$names = array();
while ($row = $db->sql_fetchrow($result))
{

$names[$row["{$mode}_id"]] = array(
"{$mode}_id" => $row["{$mode}_id"],
"{$mode}_name" => $row["{$mode}_name"],
"{$mode}_path" => $row["{$mode}_path"],
);
}
$db->sql_freeresult($result);

if (sizeof($names))
{
return $names;
}
else
{
return false;
}
}

/**
* Checks upwards dependencies
*
* @access public
* @param string $mode The element type to check - only template is supported
* @param int $id The template id
* @returns false if the component does not inherit, array with name, path and id otherwise
*/
function get_super($mode, $id)
{
global $db;

$l_type = strtoupper($mode);

switch ($mode)
{
case 'template':
$sql_from = STYLES_TEMPLATE_TABLE;
break;

case 'theme':
$sql_from = STYLES_THEME_TABLE;
break;

case 'imageset':
$sql_from = STYLES_IMAGESET_TABLE;
break;
}

$sql = "SELECT {$mode}_inherits_id
FROM $sql_from
WHERE {$mode}_id = " . (int) $id;
$result = $db->sql_query_limit($sql, 1);

if ($row = $db->sql_fetchrow($result))
{
$db->sql_freeresult($result);
}
else
{
return false;
}

$super_id = $row["{$mode}_inherits_id"];

$sql = "SELECT {$mode}_id, {$mode}_name, {$mode}_path
FROM $sql_from
WHERE {$mode}_id = " . (int) $super_id;

$result = $db->sql_query_limit($sql, 1);
if ($row = $db->sql_fetchrow($result))
{
$db->sql_freeresult($result);
return $row;
}

return false;
}

/**
* Moves a template set and its subtemplates to the database
*
* @access public
* @param string $mode The component to move - only template is supported
* @param int $id The template id
*/
function store_in_db($mode, $id)
{
global $db, $user;

$error = array();
$l_type = strtoupper($mode);
if ($super = $this->get_super($mode, $id))
{
$error[] = (sprintf($user->lang["{$l_type}_INHERITS"], $super['template_name']));
return $error;
}

$sql = "SELECT {$mode}_id, {$mode}_name, {$mode}_path
FROM " . STYLES_TEMPLATE_TABLE . '
WHERE template_id = ' . (int) $id;

$result = $db->sql_query_limit($sql, 1);
if ($row = $db->sql_fetchrow($result))
{
$db->sql_freeresult($result);
$subs = $this->check_inheritance($mode, $id);

$this->_store_in_db($mode, $id, $row["{$mode}_path"]);
if ($subs && sizeof($subs))
{
foreach ($subs as $sub_id => $sub)
{
if ($err = $this->_store_in_db($mode, $sub["{$mode}_id"], $sub["{$mode}_path"]))
{
$error[] = $err;
}
}
}
}
if (sizeof($error))
{
return $error;
}

return false;
}

/**
* Moves a template set to the database
*
* @access private
* @param string $mode The component to move - only template is supported
* @param int $id The template id
* @param string $path TThe path to the template files
*/
function _store_in_db($mode, $id, $path)
{
global $phpbb_root_path, $db;

$filelist = filelist("{$phpbb_root_path}styles/{$path}/template", '', 'html');
$this->store_templates('insert', $id, $path, $filelist);

// Okay, we do the query here -shouldn't be triggered often.
$sql = 'UPDATE ' . STYLES_TEMPLATE_TABLE . '
SET template_storedb = 1
WHERE template_id = ' . $id;
$db->sql_query($sql);
}

/**
* Moves a template set and its subtemplates to the filesystem
*
* @access public
* @param string $mode The component to move - only template is supported
* @param int $id The template id
*/
function store_in_fs($mode, $id)
{
global $db, $user;

$error = array();
$l_type = strtoupper($mode);
if ($super = $this->get_super($mode, $id))
{
$error[] = (sprintf($user->lang["{$l_type}_INHERITS"], $super['template_name']));
return($error);
}

$sql = "SELECT {$mode}_id, {$mode}_name, {$mode}_path
FROM " . STYLES_TEMPLATE_TABLE . '
WHERE template_id = ' . (int) $id;

$result = $db->sql_query_limit($sql, 1);
if ($row = $db->sql_fetchrow($result))
{
$db->sql_freeresult($result);
if (!sizeof($error))
{
$subs = $this->check_inheritance($mode, $id);

$this->_store_in_fs($mode, $id, $row["{$mode}_path"]);

if ($subs && sizeof($subs))
{
foreach ($subs as $sub_id => $sub)
{
$this->_store_in_fs($mode, $sub["{$mode}_id"], $sub["{$mode}_path"]);
}
}
}
if (sizeof($error))
{
$this->store_in_db($id, $mode);
return $error;
}
}
return false;
}

/**
* Moves a template set to the filesystem
*
* @access private
* @param string $mode The component to move - only template is supported
* @param int $id The template id
* @param string $path The path to the template
*/
function _store_in_fs($mode, $id, $path)
{
global $phpbb_root_path, $db, $user, $safe_mode;

$store_db = 0;
$error = array();
if (!$safe_mode && phpbb_is_writable("{$phpbb_root_path}styles/{$path}/template"))
{
$sql = 'SELECT *
FROM ' . STYLES_TEMPLATE_DATA_TABLE . "
WHERE template_id = $id";
$result = $db->sql_query($sql);

while ($row = $db->sql_fetchrow($result))
{
if (!($fp = @fopen("{$phpbb_root_path}styles/{$path}/template/" . $row['template_filename'], 'wb')))
{
$store_db = 1;
$error[] = $user->lang['EDIT_TEMPLATE_STORED_DB'];
break;
}

fwrite($fp, $row['template_data']);
fclose($fp);
}
$db->sql_freeresult($result);

if (!$store_db)
{
$sql = 'DELETE FROM ' . STYLES_TEMPLATE_DATA_TABLE . "
WHERE template_id = $id";
$db->sql_query($sql);
}
}
if (sizeof($error))
{
return $error;
}
$sql = 'UPDATE ' . STYLES_TEMPLATE_TABLE . '
SET template_storedb = 0
WHERE template_id = ' . $id;
$db->sql_query($sql);

return false;

	}

}

	}

}