2003-05-22 08:12:53 -04:00
< ? php
2003-10-25 17:14:06 -04:00
$title = " Template & file editing " ;
2003-05-22 08:12:53 -04:00
function add_magic_quotes ( $array ) {
foreach ( $array as $k => $v ) {
if ( is_array ( $v )) {
$array [ $k ] = add_magic_quotes ( $v );
} else {
$array [ $k ] = addslashes ( $v );
}
}
return $array ;
}
if ( ! get_magic_quotes_gpc ()) {
$HTTP_GET_VARS = add_magic_quotes ( $HTTP_GET_VARS );
$HTTP_POST_VARS = add_magic_quotes ( $HTTP_POST_VARS );
$HTTP_COOKIE_VARS = add_magic_quotes ( $HTTP_COOKIE_VARS );
}
2003-12-18 04:36:13 -05:00
$wpvarstoreset = array ( 'action' , 'standalone' , 'redirect' , 'profile' , 'error' , 'warning' , 'a' , 'file' );
for ( $i = 0 ; $i < count ( $wpvarstoreset ); $i += 1 ) {
$wpvar = $wpvarstoreset [ $i ];
if ( ! isset ( $$wpvar )) {
if ( empty ( $HTTP_POST_VARS [ " $wpvar " ])) {
if ( empty ( $HTTP_GET_VARS [ " $wpvar " ])) {
$$wpvar = '' ;
2003-05-22 08:12:53 -04:00
} else {
2003-12-18 04:36:13 -05:00
$$wpvar = $HTTP_GET_VARS [ " $wpvar " ];
2003-05-22 08:12:53 -04:00
}
} else {
2003-12-18 04:36:13 -05:00
$$wpvar = $HTTP_POST_VARS [ " $wpvar " ];
2003-05-22 08:12:53 -04:00
}
}
}
switch ( $action ) {
2003-05-22 20:12:22 -04:00
case 'update' :
2003-05-22 08:12:53 -04:00
2003-05-22 20:12:22 -04:00
$standalone = 1 ;
2003-12-10 19:22:36 -05:00
require_once ( " admin-header.php " );
2003-05-22 08:12:53 -04:00
if ( $user_level < 3 ) {
2003-05-22 20:12:22 -04:00
die ( '<p>You have no right to edit the template for this blog.<br />Ask for a promotion to your <a href="mailto:$admin_email">blog admin</a>. :)</p>' );
2003-05-22 08:12:53 -04:00
}
2003-12-07 20:55:38 -05:00
$newcontent = stripslashes ( $HTTP_POST_VARS [ 'newcontent' ]);
$file = $HTTP_POST_VARS [ 'file' ];
2003-05-22 20:12:22 -04:00
$f = fopen ( $file , 'w+' );
fwrite ( $f , $newcontent );
2003-05-22 08:12:53 -04:00
fclose ( $f );
2003-05-22 20:12:22 -04:00
$file = str_replace ( '../' , '' , $file );
2003-12-07 20:55:38 -05:00
header ( " Location: templates.php?file= $file &a=te " );
2003-05-22 08:12:53 -04:00
exit ();
break ;
default :
2003-12-10 19:22:36 -05:00
require_once ( 'admin-header.php' );
2003-05-22 08:12:53 -04:00
if ( $user_level <= 3 ) {
2003-05-22 20:12:22 -04:00
die ( '<p>You have no right to edit the template for this blog.<br>Ask for a promotion to your <a href="mailto:$admin_email">blog admin</a>. :)</p>' );
2003-05-22 08:12:53 -04:00
}
2003-05-22 20:12:22 -04:00
if ( '' == $file ) {
if ( '' != $blogfilename ) {
2003-05-22 08:12:53 -04:00
$file = $blogfilename ;
} else {
2003-05-22 20:12:22 -04:00
$file = 'index.php' ;
2003-05-22 08:12:53 -04:00
}
}
2003-05-22 20:12:22 -04:00
if ( '..' == substr ( $file , 0 , 2 ))
die ( 'Sorry, can’t edit files with ".." in the name. If you are trying to edit a file in your WordPress home directory, you can just type the name of the file in.' );
2003-05-22 08:12:53 -04:00
2003-05-22 20:12:22 -04:00
if ( ':' == substr ( $file , 1 , 1 ))
die ( 'Sorry, can’t call files with their real path.' );
2003-05-22 08:12:53 -04:00
2003-05-22 20:12:22 -04:00
if ( '/' == substr ( $file , 0 , 1 ))
$file = '.' . $file ;
$file = stripslashes ( $file );
$file = '../' . $file ;
2003-05-22 08:12:53 -04:00
if ( ! is_file ( $file ))
$error = 1 ;
2003-12-15 21:10:52 -05:00
if (( substr ( $file , 0 , 2 ) == 'wp' ) and ( substr ( $file , - 4 , 4 ) == '.php' ) and ( $file != 'wp.php' ))
2003-05-22 20:12:22 -04:00
$warning = ' — this is a WordPress file, be careful when editing it!' ;
2003-05-22 08:12:53 -04:00
if ( ! $error ) {
2003-05-22 20:12:22 -04:00
$f = fopen ( $file , 'r' );
$content = fread ( $f , filesize ( $file ));
2003-05-22 08:12:53 -04:00
$content = htmlspecialchars ( $content );
// $content = str_replace("</textarea","</textarea",$content);
}
?>
2003-12-07 20:55:38 -05:00
< div class = " wrap " >
< ? php
echo " Editing <strong> $file </strong> $warning " ;
2003-05-22 20:12:22 -04:00
if ( 'te' == $a )
echo " <em>File edited successfully.</em> " ;
2003-05-22 08:12:53 -04:00
if ( ! $error ) {
2003-12-07 20:55:38 -05:00
?>
< form name = " template " action = " templates.php " method = " post " >
< textarea cols = " 80 " rows = " 20 " style = " width:100%; font-family: 'Courier New', Courier, monopace; font-size:small; " name = " newcontent " tabindex = " 1 " >< ? php echo $content ?> </textarea>
< input type = " hidden " name = " action " value = " update " />
< input type = " hidden " name = " file " value = " <?php echo $file ?> " />
< br />
< ? php
2003-05-22 08:12:53 -04:00
if ( is_writeable ( $file )) {
echo " <input type= \" submit \" name= \" submit \" class= \" search \" value= \" update template ! \" tabindex= \" 2 \" /> " ;
} else {
echo " <input type= \" button \" name= \" oops \" class= \" search \" value= \" (you cannot update that file/template: must make it writable, e.g. CHMOD 766) \" tabindex= \" 2 \" /> " ;
}
2003-12-07 20:55:38 -05:00
?>
</ form >
< ? php
2003-05-22 08:12:53 -04:00
} else {
2003-05-22 20:12:22 -04:00
echo '<p>Oops, no such file exists! Double check the name and try again, merci.</p>' ;
2003-05-22 08:12:53 -04:00
}
2003-12-07 20:55:38 -05:00
?>
</ div >
2003-05-22 20:12:22 -04:00
< div class = " wrap " >
2003-12-10 19:22:36 -05:00
< p > You can also edit the < a href = " templates.php?file=wp-comments.php " > comments template </ a > or the < a href = " templates.php?file=wp-comments-popup.php " > popup comments template </ a > , or edit any other file ( provided it & #8217;s writable by the server, e.g. CHMOD 766).</p>
2003-12-07 20:55:38 -05:00
< p > To edit a file , type its name here :</ p >
< form name = " file " action = " templates.php " method = " get " >
< input type = " text " name = " file " />
< input type = " submit " name = " submit " class = " search " value = " go " />
</ form >
< p > Note : of course , you can also edit the files / templates in your text editor of choice and upload them . This online editor is only meant to be used when you don ' t have access to a text editor or FTP client .</ p >
</ div >
< ? php
2003-05-22 08:12:53 -04:00
break ;
}
2003-12-10 19:22:36 -05:00
include ( " admin-footer.php " ) ?>