2004-11-16 22:15:44 -05:00
< ? php
2008-08-16 03:27:34 -04:00
/**
* Edit plugin editor administration panel .
*
* @ package WordPress
* @ subpackage Administration
*/
/** WordPress Administration Bootstrap */
2004-11-16 22:15:44 -05:00
require_once ( 'admin.php' );
2006-11-18 02:31:29 -05:00
$title = __ ( " Edit Plugins " );
$parent_file = 'plugins.php' ;
2006-07-03 15:03:37 -04:00
wp_reset_vars ( array ( 'action' , 'redirect' , 'profile' , 'error' , 'warning' , 'a' , 'file' ));
2004-11-16 22:15:44 -05:00
2008-05-21 20:06:41 -04:00
wp_admin_css ( 'theme-editor' );
2008-02-21 22:06:35 -05:00
2004-11-27 19:33:04 -05:00
$plugins = get_plugins ();
$plugin_files = array_keys ( $plugins );
2004-11-16 22:15:44 -05:00
2008-03-26 12:14:29 -04:00
if ( empty ( $file ))
2004-11-16 22:15:44 -05:00
$file = $plugin_files [ 0 ];
$file = validate_file_to_edit ( $file , $plugin_files );
2008-05-27 13:55:24 -04:00
$real_file = WP_PLUGIN_DIR . '/' . $file ;
2004-11-16 22:15:44 -05:00
switch ( $action ) {
case 'update' :
2006-05-26 19:08:05 -04:00
check_admin_referer ( 'edit-plugin_' . $file );
2006-03-30 18:12:54 -05:00
2005-07-14 22:16:45 -04:00
if ( ! current_user_can ( 'edit_plugins' ) )
2006-07-05 18:00:03 -04:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit templates for this blog.' ) . '</p>' );
2004-11-16 22:15:44 -05:00
$newcontent = stripslashes ( $_POST [ 'newcontent' ]);
2008-03-26 12:14:29 -04:00
if ( is_writeable ( $real_file ) ) {
2004-11-16 22:15:44 -05:00
$f = fopen ( $real_file , 'w+' );
fwrite ( $f , $newcontent );
fclose ( $f );
2007-02-14 01:15:05 -05:00
// Deactivate so we can test it.
2008-03-26 12:14:29 -04:00
if ( is_plugin_active ( $file ) || isset ( $_POST [ 'phperror' ]) ) {
if ( is_plugin_active ( $file ) )
deactivate_plugins ( $file , true );
2007-02-14 01:15:05 -05:00
wp_redirect ( add_query_arg ( '_wpnonce' , wp_create_nonce ( 'edit-plugin-test_' . $file ), " plugin-editor.php?file= $file &liveupdate=1 " ));
2008-03-26 12:14:29 -04:00
exit ;
2007-02-14 01:15:05 -05:00
}
2006-06-27 01:38:56 -04:00
wp_redirect ( " plugin-editor.php?file= $file &a=te " );
2004-11-16 22:15:44 -05:00
} else {
2006-06-27 01:38:56 -04:00
wp_redirect ( " plugin-editor.php?file= $file " );
2004-11-16 22:15:44 -05:00
}
2008-03-26 12:14:29 -04:00
exit ;
2004-11-16 22:15:44 -05:00
break ;
default :
2006-02-12 02:53:23 -05:00
2005-07-14 22:16:45 -04:00
if ( ! current_user_can ( 'edit_plugins' ) )
2006-07-05 18:00:03 -04:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit plugins for this blog.' ) . '</p>' );
2004-11-16 22:15:44 -05:00
2008-03-26 12:14:29 -04:00
if ( isset ( $_GET [ 'liveupdate' ]) ) {
2007-02-14 01:15:05 -05:00
check_admin_referer ( 'edit-plugin-test_' . $file );
2008-03-26 12:14:29 -04:00
$error = validate_plugin ( $file );
if ( is_wp_error ( $error ) )
wp_die ( $error );
if ( ! is_plugin_active ( $file ) )
activate_plugin ( $file , " plugin-editor.php?file= $file &phperror=1 " ); // we'll override this later if the plugin can be included without fatal error
2007-02-14 01:15:05 -05:00
wp_redirect ( " plugin-editor.php?file= $file &a=te " );
2008-03-26 12:14:29 -04:00
exit ;
2007-02-14 01:15:05 -05:00
}
2006-08-22 14:20:00 -04:00
require_once ( 'admin-header.php' );
2008-05-27 13:55:24 -04:00
update_recently_edited ( WP_PLUGIN_DIR . '/' . $file );
2006-02-12 02:53:23 -05:00
2008-03-26 12:14:29 -04:00
if ( ! is_file ( $real_file ) )
2004-11-16 22:15:44 -05:00
$error = 1 ;
2006-02-12 02:53:23 -05:00
2008-03-26 12:14:29 -04:00
if ( ! $error )
$content = htmlspecialchars ( file_get_contents ( $real_file ));
2004-11-16 22:15:44 -05:00
?>
< ? php if ( isset ( $_GET [ 'a' ])) : ?>
2005-08-07 21:13:22 -04:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'File edited successfully.' ) ?> </p></div>
2007-02-14 01:15:05 -05:00
< ? php elseif ( isset ( $_GET [ 'phperror' ])) : ?>
2008-03-26 12:14:29 -04:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'This plugin has been deactivated because your changes resulted in a <strong>fatal error</strong>.' ) ?> </p>
< ? php
if ( wp_verify_nonce ( $_GET [ '_error_nonce' ], 'plugin-activation-error_' . $file ) ) { ?>
< iframe style = " border:0 " width = " 100% " height = " 70px " src = " <?php bloginfo('wpurl'); ?>/wp-admin/plugins.php?action=error_scrape&plugin=<?php echo attribute_escape( $file ); ?>&_wpnonce=<?php echo attribute_escape( $_GET['_error_nonce'] ); ?> " ></ iframe >
< ? php } ?>
</ div >
2004-11-16 22:15:44 -05:00
< ? php endif ; ?>
2006-11-19 02:56:05 -05:00
< div class = " wrap " >
2008-02-21 22:06:35 -05:00
< div class = " bordertitle " >
2008-03-14 19:58:31 -04:00
< h2 >< ? php _e ( 'Plugin Editor' ); ?> </h2>
2008-02-21 22:06:35 -05:00
</ div >
2008-03-14 19:58:31 -04:00
< div class = " tablenav " >
< div class = " alignleft " >
2008-02-21 22:06:35 -05:00
< big >< strong >< ? php
2008-03-26 12:14:29 -04:00
if ( is_plugin_active ( $file ) ) {
if ( is_writeable ( $real_file ) )
2008-02-21 22:06:35 -05:00
echo sprintf ( __ ( 'Editing <strong>%s</strong> (active)' ), $file );
2008-03-26 12:14:29 -04:00
else
echo sprintf ( __ ( 'Browsing <strong>%s</strong> (active)' ), $file );
2004-11-16 22:15:44 -05:00
} else {
2008-03-26 12:14:29 -04:00
if ( is_writeable ( $real_file ) )
2008-02-21 22:06:35 -05:00
echo sprintf ( __ ( 'Editing <strong>%s</strong> (inactive)' ), $file );
2008-03-26 12:14:29 -04:00
else
echo sprintf ( __ ( 'Browsing <strong>%s</strong> (inactive)' ), $file );
2004-11-16 22:15:44 -05:00
}
2008-02-21 22:06:35 -05:00
?> </strong></big>
</ div >
2008-03-14 19:58:31 -04:00
< br class = " clear " />
2008-02-21 22:06:35 -05:00
</ div >
2008-03-14 19:58:31 -04:00
< br class = " clear " />
2004-11-16 22:15:44 -05:00
< div id = " templateside " >
2008-03-26 12:14:29 -04:00
< h3 id = " bordertitle " >< ? php _e ( 'Plugin Files' ); ?> </h3>
2004-11-16 22:15:44 -05:00
2008-03-14 19:58:31 -04:00
< h4 >< ? php _e ( 'Plugins' ); ?> </h4>
2006-11-19 02:56:05 -05:00
< ul >
2008-02-21 22:06:35 -05:00
< ? php foreach ( $plugin_files as $plugin_file ) : ?>
2008-03-26 12:14:29 -04:00
< li >< a href = " plugin-editor.php?file=<?php echo $plugin_file ; ?> " >< ? php echo $plugins [ $plugin_file ][ 'Name' ]; ?> </a></li>
2008-02-21 22:06:35 -05:00
< ? php endforeach ; ?>
2006-11-19 02:56:05 -05:00
</ ul >
2008-02-21 22:06:35 -05:00
</ div >
2008-03-26 12:14:29 -04:00
< ? php if ( ! $error ) { ?>
2006-11-19 02:56:05 -05:00
< form name = " template " id = " template " action = " plugin-editor.php " method = " post " >
< ? php wp_nonce_field ( 'edit-plugin_' . $file ) ?>
< div >< textarea cols = " 70 " rows = " 25 " name = " newcontent " id = " newcontent " tabindex = " 1 " >< ? php echo $content ?> </textarea>
< input type = " hidden " name = " action " value = " update " />
< input type = " hidden " name = " file " value = " <?php echo $file ?> " />
2004-11-16 22:15:44 -05:00
</ div >
< ? php if ( is_writeable ( $real_file ) ) : ?>
2007-02-14 01:15:05 -05:00
< ? php if ( in_array ( $file , ( array ) get_option ( 'active_plugins' )) ) { ?>
< p >< ? php _e ( '<strong>Warning:</strong> Making changes to active plugins is not recommended. If your changes cause a fatal error, the plugin will be automatically deactivated.' ); ?> </p>
< ? php } ?>
2006-11-19 02:56:05 -05:00
< p class = " submit " >
< ? php
2007-02-14 01:15:05 -05:00
if ( isset ( $_GET [ 'phperror' ]) )
2008-02-20 14:30:55 -05:00
echo " <input type='hidden' name='phperror' value='1' /><input type='submit' name='submit' value=' " . __ ( 'Update File and Attempt to Reactivate' ) . " ' tabindex='2' /> " ;
2007-02-14 01:15:05 -05:00
else
2008-02-19 15:33:59 -05:00
echo " <input type='submit' name='submit' value=' " . __ ( 'Update File' ) . " ' tabindex='2' /> " ;
2006-11-19 02:56:05 -05:00
?>
</ p >
2004-11-16 22:15:44 -05:00
< ? php else : ?>
2008-02-13 18:58:23 -05:00
< p >< em >< ? php _e ( 'You need to make this file writable before you can save your changes. See <a href="http://codex.wordpress.org/Changing_File_Permissions">the Codex</a> for more information.' ); ?> </em></p>
2004-11-16 22:15:44 -05:00
< ? php endif ; ?>
2006-11-19 02:56:05 -05:00
</ form >
< ? php
2004-11-16 22:15:44 -05:00
} else {
echo '<div class="error"><p>' . __ ( 'Oops, no such file exists! Double check the name and try again, merci.' ) . '</p></div>' ;
}
2006-11-19 02:56:05 -05:00
?>
2005-11-14 05:19:22 -05:00
< div class = " clear " > & nbsp ; </ div >
2006-11-19 02:56:05 -05:00
</ div >
2004-11-16 22:15:44 -05:00
< ? php
2008-03-26 12:14:29 -04:00
break ;
2004-11-16 22:15:44 -05:00
}
2008-02-21 22:06:35 -05:00
include ( " admin-footer.php " ) ?>