| 1 | <?php
 | 
  
    | 2 | 
 | 
  
    | 3 | // $Id: edit_module_files.php 810 2008-04-06 07:13:33Z doc $
 | 
  
    | 4 | 
 | 
  
    | 5 | /*
 | 
  
    | 6 | 
 | 
  
    | 7 |  Website Baker Project <http://www.websitebaker.org/>
 | 
  
    | 8 |  Copyright (C) 2004-2008, Ryan Djurovich
 | 
  
    | 9 | 
 | 
  
    | 10 |  Website Baker is free software; you can redistribute it and/or modify
 | 
  
    | 11 |  it under the terms of the GNU General Public License as published by
 | 
  
    | 12 |  the Free Software Foundation; either version 2 of the License, or
 | 
  
    | 13 |  (at your option) any later version.
 | 
  
    | 14 | 
 | 
  
    | 15 |  Website Baker is distributed in the hope that it will be useful,
 | 
  
    | 16 |  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
  
    | 17 |  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
  
    | 18 |  GNU General Public License for more details.
 | 
  
    | 19 | 
 | 
  
    | 20 |  You should have received a copy of the GNU General Public License
 | 
  
    | 21 |  along with Website Baker; if not, write to the Free Software
 | 
  
    | 22 |  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | 
  
    | 23 | 
 | 
  
    | 24 | */
 | 
  
    | 25 | 
 | 
  
    | 26 | /**
 | 
  
    | 27 | 	This file contains the routines to edit the optional module files: frontend.css and backend.css
 | 
  
    | 28 | 	Mechanism was introduced with WB 2.7 to provide a global solution for all modules
 | 
  
    | 29 | */
 | 
  
    | 30 | 
 | 
  
    | 31 | // prevent this file from being accessed directly
 | 
  
    | 32 | if(!(isset($_POST['page_id']) && isset($_POST['section_id']) && isset($_POST['action']) 
 | 
  
    | 33 | 	&& isset($_POST['mod_dir'])  && isset($_POST['edit_file']))) die(header('Location: index.php')); 
 | 
  
    | 34 | 
 | 
  
    | 35 | // include configuration file and admin wrapper script
 | 
  
    | 36 | require('../config.php');
 | 
  
    | 37 | 
 | 
  
    | 38 | // include the and admin wrapper script
 | 
  
    | 39 | require(WB_PATH.'/modules/admin.php');
 | 
  
    | 40 | 
 | 
  
    | 41 | // leave if the required module.functions.php file does not exist
 | 
  
    | 42 | if(!file_exists(WB_PATH .'/framework/module.functions.php')) {
 | 
  
    | 43 | 	echo 'The required file: /framework/module.functions.php is missing - script stopped.';
 | 
  
    | 44 | 	die;
 | 
  
    | 45 | }
 | 
  
    | 46 | 
 | 
  
    | 47 | // set default text output if varibles are not defined in the global WB language files
 | 
  
    | 48 | $HEADING_CSS_FILE = (isset($GLOBALS['TEXT']['HEADING_CSS_FILE'])) ?$GLOBALS['TEXT']['HEADING_CSS_FILE'] :'Actual module file: ';
 | 
  
    | 49 | $TXT_EDIT_CSS_FILE = (isset($GLOBALS['TEXT']['TXT_EDIT_CSS_FILE'])) ?$GLOBALS['TEXT']['TXT_EDIT_CSS_FILE'] :'Edit the CSS definitions in the textarea below.';
 | 
  
    | 50 | 
 | 
  
    | 51 | // include functions to edit the optional module CSS files (frontend.css, backend.css)
 | 
  
    | 52 | require_once(WB_PATH .'/framework/module.functions.php');
 | 
  
    | 53 | 
 | 
  
    | 54 | // check if the module directory is valid
 | 
  
    | 55 | $mod_dir = check_module_dir($_POST['mod_dir']);
 | 
  
    | 56 | if($mod_dir == '') {
 | 
  
    | 57 | 	echo 'The specified module directory is invalid - script stopped.';
 | 
  
    | 58 | 	die;
 | 
  
    | 59 | };
 | 
  
    | 60 | 
 | 
  
    | 61 | // check if action is: save or edit
 | 
  
    | 62 | if($_POST['action'] == 'save' && mod_file_exists($mod_dir, $_POST['edit_file'])) {
 | 
  
    | 63 | 	/** 
 | 
  
    | 64 | 		SAVE THE UPDATED CONTENTS TO THE CSS FILE
 | 
  
    | 65 | 	*/
 | 
  
    | 66 | 
 | 
  
    | 67 | 	$css_content = '';
 | 
  
    | 68 | 	if(isset($_POST['css_codepress']) && strlen($_POST['css_codepress']) > 0) {
 | 
  
    | 69 | 		// Javascript is enabled so take contents from hidden field: css_codepress
 | 
  
    | 70 | 		$css_content = stripslashes($_POST['css_codepress']);
 | 
  
    | 71 | 	} elseif(isset($_POST['css_data']) && strlen($_POST['css_data']) > 0) {
 | 
  
    | 72 | 		// Javascript disabled, take contens from textarea: css_data
 | 
  
    | 73 | 		$css_content = stripslashes($_POST['css_data']);
 | 
  
    | 74 | 	}
 | 
  
    | 75 | 
 | 
  
    | 76 | 	$bytes = 0;
 | 
  
    | 77 | 	if ($css_content != '') {
 | 
  
    | 78 | 		// open the module CSS file for writting
 | 
  
    | 79 | 		$mod_file = @fopen(WB_PATH .'/modules/' .$mod_dir .'/' .$_POST['edit_file'], "wb");
 | 
  
    | 80 | 		// write new content to the module CSS file
 | 
  
    | 81 | 		$bytes = @fwrite($mod_file, $css_content);
 | 
  
    | 82 | 		// close the file
 | 
  
    | 83 | 		@fclose($mod_file);
 | 
  
    | 84 | 	}
 | 
  
    | 85 | 
 | 
  
    | 86 | 	// write out status message
 | 
  
    | 87 | 	if($bytes == 0 ) {
 | 
  
    | 88 | 		$admin->print_error($TEXT['ERROR'], ADMIN_URL.'/pages/modify.php?page_id='.$page_id);
 | 
  
    | 89 | 	} else {
 | 
  
    | 90 | 		$admin->print_success($TEXT['SUCCESS'], ADMIN_URL.'/pages/modify.php?page_id='.$page_id);
 | 
  
    | 91 | 	}
 | 
  
    | 92 | 
 | 
  
    | 93 | 
 | 
  
    | 94 | } else {
 | 
  
    | 95 | 	/** 
 | 
  
    | 96 | 		MODIFY CONTENTS OF THE CSS FILE VIA TEXT AREA 
 | 
  
    | 97 | 	*/
 | 
  
    | 98 | 	// check if module backend.css file needs to be included into the <body>
 | 
  
    | 99 | 	if((!method_exists($admin, 'register_backend_modfiles') || !isset($_GET['page_id']))
 | 
  
    | 100 | 			&& file_exists(WB_PATH .'/modules/'.$mod_dir.'/backend.css')) {
 | 
  
    | 101 | 		echo '<style type="text/css">';
 | 
  
    | 102 | 		include(WB_PATH .'/modules/' .$mod_dir .'/backend.css');
 | 
  
    | 103 | 		echo "\n</style>\n";
 | 
  
    | 104 | 	}
 | 
  
    | 105 | 
 | 
  
    | 106 | 	// check which module file to edit (frontend.css, backend.css or '')
 | 
  
    | 107 | 	$css_file = (in_array($_POST['edit_file'], array('frontend.css', 'backend.css'))) ? $_POST['edit_file'] : '';
 | 
  
    | 108 | 
 | 
  
    | 109 | 	// display output
 | 
  
    | 110 | 	if($css_file == '') {
 | 
  
    | 111 | 		// no valid module file to edit; display error message and backlink to modify.php
 | 
  
    | 112 | 		echo "<h2>Nothing to edit</h2>";
 | 
  
    | 113 | 		echo "<p>No valid module file exists for this module.</p>";
 | 
  
    | 114 | 		$output  = "<a href=\"#\" onclick=\"javascript: window.location = '";
 | 
  
    | 115 | 		$output .= ADMIN_URL ."/pages/modify.php?page_id=" .$page_id ."'\">back</a>";
 | 
  
    | 116 | 		echo $output;
 | 
  
    | 117 | 	
 | 
  
    | 118 | 	} else {
 | 
  
    | 119 | 		// store content of the module file in variable
 | 
  
    | 120 | 		$css_content = @file_get_contents(WB_PATH .'/modules/' .$mod_dir .'/' .$css_file);
 | 
  
    | 121 | 
 | 
  
    | 122 | 		// make sure that codepress stuff is only used if the framework is available
 | 
  
    | 123 | 		$CODEPRESS['CLASS'] = '';
 | 
  
    | 124 | 		$CODEPRESS['JS'] = '';
 | 
  
    | 125 | 		if(file_exists(WB_PATH .'/include/codepress/codepress.js')) {
 | 
  
    | 126 | 			$CODEPRESS['CLASS'] = 'class="codepress css" ';
 | 
  
    | 127 | 			$CODEPRESS['JS'] = 'onclick="javascript: css_codepress.value = area_codepress.getCode();"';
 | 
  
    | 128 | 		}
 | 
  
    | 129 | 
 | 
  
    | 130 | 		// write out heading
 | 
  
    | 131 | 		echo '<h2>' .$HEADING_CSS_FILE .'"' .$css_file .'"</h2>';
 | 
  
    | 132 | 		// include button to switch between frontend.css and backend.css (only shown if both files exists)
 | 
  
    | 133 | 		toggle_css_file($mod_dir, $css_file); 
 | 
  
    | 134 | 	  echo '<p>' .$TXT_EDIT_CSS_FILE .'</p>';
 | 
  
    | 135 | 
 | 
  
    | 136 | 		// output content of module file to textareas
 | 
  
    | 137 | 	?>
 | 
  
    | 138 | 		<form name="edit_module_file" action="<?php echo $_SERVER['PHP_SELF'];?>" method="post" style="margin: 0;">
 | 
  
    | 139 | 			<input type="hidden" name="css_codepress" value="" />
 | 
  
    | 140 | 	  	<input type="hidden" name="page_id" value="<?php echo $page_id; ?>">
 | 
  
    | 141 | 	  	<input type="hidden" name="section_id" value="<?php echo $section_id; ?>">
 | 
  
    | 142 | 	  	<input type="hidden" name="mod_dir" value="<?php echo $mod_dir; ?>">
 | 
  
    | 143 | 			<input type="hidden" name="edit_file" value="<?php echo $css_file; ?>" />
 | 
  
    | 144 | 	  	<input type="hidden" name="action" value="save">
 | 
  
    | 145 | 
 | 
  
    | 146 | 			<textarea id="area_codepress" name="css_data" <?php echo $CODEPRESS['CLASS'];?>cols="115" rows="25" wrap="VIRTUAL" style="margin:2px;"><?php echo $css_content; ?></textarea>
 | 
  
    | 147 | 
 | 
  
    | 148 |   			<table cellpadding="0" cellspacing="0" border="0" width="100%">
 | 
  
    | 149 |   			<tr>
 | 
  
    | 150 |     			<td align="left">
 | 
  
    | 151 |  				<input name="save" type="submit" value="<?php echo $TEXT['SAVE'];?>"
 | 
  
    | 152 | 				  <?php echo $CODEPRESS['JS'];?> style="width: 100px; margin-top: 5px;" />
 | 
  
    | 153 |     			</td>
 | 
  
    | 154 |   				<td align="right">
 | 
  
    | 155 |       			<input type="button" value="<?php echo $TEXT['CANCEL']; ?>"
 | 
  
    | 156 | 						onclick="javascript: window.location = '<?php echo ADMIN_URL;?>/pages/modify.php?page_id=<?php echo $page_id; ?>';"
 | 
  
    | 157 | 						style="width: 100px; margin-top: 5px;" />
 | 
  
    | 158 |   				</td>
 | 
  
    | 159 |   			</tr>
 | 
  
    | 160 |   			</table>
 | 
  
    | 161 | 		</form>
 | 
  
    | 162 | 		<?php 
 | 
  
    | 163 | 	}
 | 
  
    | 164 | }
 | 
  
    | 165 | 
 | 
  
    | 166 | // Print admin footer
 | 
  
    | 167 | $admin->print_footer();
 | 
  
    | 168 | 
 | 
  
    | 169 | ?>
 |