2003-05-22 08:12:53 -04:00
< ? php
2004-10-18 23:03:06 -04:00
require_once ( 'admin.php' );
2004-09-22 02:33:54 -04:00
$title = __ ( 'Template & file editing' );
2004-11-16 22:15:44 -05:00
$parent_file = 'edit.php' ;
2004-03-29 17:43:07 -05:00
2004-10-18 23:03:06 -04:00
$wpvarstoreset = array ( 'action' , 'redirect' , 'profile' , 'error' , 'warning' , 'a' , 'file' );
2003-12-18 04:36:13 -05:00
for ( $i = 0 ; $i < count ( $wpvarstoreset ); $i += 1 ) {
$wpvar = $wpvarstoreset [ $i ];
if ( ! isset ( $$wpvar )) {
2004-04-20 18:56:47 -04:00
if ( empty ( $_POST [ " $wpvar " ])) {
if ( empty ( $_GET [ " $wpvar " ])) {
2003-12-18 04:36:13 -05:00
$$wpvar = '' ;
2003-05-22 08:12:53 -04:00
} else {
2004-04-20 18:56:47 -04:00
$$wpvar = $_GET [ " $wpvar " ];
2003-05-22 08:12:53 -04:00
}
} else {
2004-04-20 18:56:47 -04:00
$$wpvar = $_POST [ " $wpvar " ];
2003-05-22 08:12:53 -04:00
}
}
}
2004-11-16 22:15:44 -05:00
if ( empty ( $file )) {
$file = 'index.php' ;
}
$file = validate_file_to_edit ( $file );
$real_file = get_real_file_to_edit ( $file );
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
2004-04-17 14:44:10 -04:00
if ( $user_level < 5 ) {
2004-04-25 19:57:43 -04:00
die ( __ ( '<p>You have do not have sufficient permissions to edit templates for this blog.</p>' ));
2003-05-22 08:12:53 -04:00
}
2004-04-20 18:56:47 -04:00
$newcontent = stripslashes ( $_POST [ 'newcontent' ]);
2004-11-16 22:15:44 -05:00
if ( is_writeable ( $real_file )) {
$f = fopen ( $real_file , 'w+' );
fwrite ( $f , $newcontent );
fclose ( $f );
header ( " Location: templates.php?file= $file &a=te " );
} else {
header ( " Location: templates.php?file= $file " );
}
2003-05-22 08:12:53 -04:00
exit ();
break ;
default :
2004-09-22 02:33:54 -04:00
require_once ( './admin-header.php' );
2004-12-14 04:45:49 -05:00
if ( $user_level <= 5 )
2004-04-25 19:57:43 -04:00
die ( __ ( '<p>You have do not have sufficient permissions to edit templates for this blog.</p>' ));
2004-12-14 04:45:49 -05:00
if ( strstr ( $file , 'wp-config.php' ) )
die ( __ ( '<p>The config file cannot be edited or viewed through the web interface. Sorry!</p>' ) );
2003-05-22 08:12:53 -04:00
2004-11-16 22:15:44 -05:00
update_recently_edited ( $file );
2003-05-22 08:12:53 -04:00
2004-03-29 17:43:07 -05:00
if ( ! is_file ( $real_file ))
2003-05-22 08:12:53 -04:00
$error = 1 ;
2003-05-22 20:12:22 -04:00
2003-05-22 08:12:53 -04:00
if ( ! $error ) {
2004-03-29 17:43:07 -05:00
$f = fopen ( $real_file , 'r' );
$content = fread ( $f , filesize ( $real_file ));
2004-12-12 15:41:19 -05:00
$content = wp_specialchars ( $content );
2003-05-22 08:12:53 -04:00
}
?>
2004-05-07 19:56:33 -04:00
< ? php if ( isset ( $_GET [ 'a' ])) : ?>
2004-04-25 19:57:43 -04:00
< div class = " updated " >< p >< ? php _e ( 'File edited successfully.' ) ?> </p></div>
2004-04-17 14:44:10 -04:00
< ? php endif ; ?>
2003-12-07 20:55:38 -05:00
< div class = " wrap " >
2004-09-22 02:33:54 -04:00
< ? php
if ( is_writeable ( $real_file )) {
2004-12-12 15:41:19 -05:00
echo '<h2>' . sprintf ( __ ( 'Editing <strong>%s</strong>' ), wp_specialchars ( $file ) ) . '</h2>' ;
2004-09-22 02:33:54 -04:00
} else {
2004-12-12 15:41:19 -05:00
echo '<h2>' . sprintf ( __ ( 'Browsing <strong>%s</strong>' ), wp_specialchars ( $file ) ) . '</h2>' ;
2004-09-22 02:33:54 -04:00
}
?>
< div id = " templateside " >
< ? php
if ( $recents = get_option ( 'recently_edited' ) ) :
?>
< h3 >< ? php _e ( 'Recent' ); ?> </h3>
< ? php
echo '<ol>' ;
foreach ( $recents as $recent ) :
2004-12-12 01:31:01 -05:00
echo " <li><a href='templates.php?file= $recent '> " . get_file_description ( basename ( $recent )) . " </a></li> " ;
2004-09-22 02:33:54 -04:00
endforeach ;
echo '</ol>' ;
endif ;
?>
< h3 >< ? php _e ( 'Common' ); ?> </h3>
2004-11-16 22:15:44 -05:00
< ? php $common_files = array ( 'index.php' , 'wp-layout.css' , 'wp-comments.php' , 'wp-comments-popup.php' , '.htaccess' , 'my-hacks.php' ); ?>
2004-09-22 02:33:54 -04:00
< ul >
2004-11-16 22:15:44 -05:00
< ? php foreach ( $common_files as $common_file ) : ?>
< li >< a href = " templates.php?file=<?php echo $common_file ?> " >< ? php echo get_file_description ( $common_file ); ?> </a></li>
2004-11-19 16:05:26 -05:00
< ? php endforeach ; ?>
2004-11-16 22:15:44 -05:00
</ ul >
2004-09-22 02:33:54 -04:00
</ div >
< ? php if ( ! $error ) { ?>
< form name = " template " id = " template " action = " templates.php " method = " post " >
< div >< textarea cols = " 70 " rows = " 25 " name = " newcontent " id = 'newcontent' tabindex = " 1 " >< ? php echo $content ?> </textarea>
2003-12-07 20:55:38 -05:00
< input type = " hidden " name = " action " value = " update " />
< input type = " hidden " name = " file " value = " <?php echo $file ?> " />
2004-09-22 02:33:54 -04:00
</ div >
< ? php if ( is_writeable ( $real_file ) ) : ?>
2004-04-17 14:44:10 -04:00
< p class = " submit " >
2004-09-22 02:33:54 -04:00
< ? php
echo " <input type='submit' name='submit' value=' " . __ ( 'Update File' ) . " »' tabindex='2' /> " ;
?>
2004-04-17 14:44:10 -04:00
</ p >
2004-09-22 02:33:54 -04:00
< ? php else : ?>
< p >< em >< ? php _e ( 'If this file was writable you could edit it.' ); ?> </em></p>
< ? php endif ; ?>
2003-12-07 20:55:38 -05:00
</ form >
< ? php
2003-05-22 08:12:53 -04:00
} else {
2004-04-25 19:57:43 -04:00
echo '<div class="error"><p>' . __ ( 'Oops, no such file exists! Double check the name and try again, merci.' ) . '</p></div>' ;
2003-05-22 08:12:53 -04:00
}
2004-09-22 02:33:54 -04:00
?>
</ div >
2004-02-05 09:48:55 -05:00
< div class = " wrap " >
2004-09-22 02:33:54 -04:00
< h2 > Other Files </ h2 >
2004-04-25 19:57:43 -04:00
< p >< ? php _e ( 'To edit a file, type its name here. You can edit any file <a href="http://wiki.wordpress.org/index.php/MakeWritable" title="Read more about making files writable">writable by the server</a>, e.g. CHMOD 666.' ) ?> </p>
2003-12-07 20:55:38 -05:00
< form name = " file " action = " templates.php " method = " get " >
< input type = " text " name = " file " />
2004-04-25 19:57:43 -04:00
< input type = " submit " name = " submit " value = " <?php _e('Edit file »') ?> " />
2003-12-07 20:55:38 -05:00
</ form >
2004-09-22 02:33:54 -04:00
2004-04-25 19:57:43 -04:00
< p >< ? php _e ( '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>
2003-12-07 20:55:38 -05:00
</ div >
< ? php
2003-05-22 08:12:53 -04:00
break ;
}
2004-12-12 01:31:01 -05:00
include ( " admin-footer.php " );
?>