@@ -4,7 +4,7 @@ discard block |
||
| 4 | 4 | |
| 5 | 5 | use PhpConsole; |
| 6 | 6 | |
| 7 | -defined( 'ABSPATH' ) or exit; |
|
| 7 | +defined('ABSPATH') or exit; |
|
| 8 | 8 | |
| 9 | 9 | /** |
| 10 | 10 | * WP PHP Console main class. |
@@ -36,7 +36,7 @@ discard block |
||
| 36 | 36 | public function __construct() { |
| 37 | 37 | |
| 38 | 38 | // handle translations |
| 39 | - add_action( 'plugins_loaded', [ $this, 'set_locale' ] ); |
|
| 39 | + add_action('plugins_loaded', [$this, 'set_locale']); |
|
| 40 | 40 | |
| 41 | 41 | // set options |
| 42 | 42 | $this->options = $this->get_options(); |
@@ -45,14 +45,14 @@ discard block |
||
| 45 | 45 | $this->set_admin(); |
| 46 | 46 | |
| 47 | 47 | // bail out if PHP Console can't be found |
| 48 | - if ( ! class_exists( 'PhpConsole\Connector' ) ) { |
|
| 48 | + if ( ! class_exists('PhpConsole\Connector')) { |
|
| 49 | 49 | return; |
| 50 | 50 | } |
| 51 | 51 | |
| 52 | 52 | // connect to PHP Console |
| 53 | - add_action( 'init', [ $this, 'connect' ], -1000 ); |
|
| 53 | + add_action('init', [$this, 'connect'], -1000); |
|
| 54 | 54 | // delay further PHP Console initialisation to have more context during Remote PHP execution |
| 55 | - add_action( 'wp_loaded', [ $this, 'init' ], -1000 ); |
|
| 55 | + add_action('wp_loaded', [$this, 'init'], -1000); |
|
| 56 | 56 | } |
| 57 | 57 | |
| 58 | 58 | |
@@ -66,7 +66,7 @@ discard block |
||
| 66 | 66 | load_plugin_textdomain( |
| 67 | 67 | 'wp-php-console', |
| 68 | 68 | false, |
| 69 | - dirname( dirname( plugin_basename( __FILE__ ) ) ) . '/languages/' |
|
| 69 | + dirname(dirname(plugin_basename(__FILE__))).'/languages/' |
|
| 70 | 70 | ); |
| 71 | 71 | } |
| 72 | 72 | |
@@ -78,20 +78,20 @@ discard block |
||
| 78 | 78 | */ |
| 79 | 79 | private function set_admin() { |
| 80 | 80 | |
| 81 | - if ( ! defined( 'DOING_AJAX' ) && is_admin() ) { |
|
| 81 | + if ( ! defined('DOING_AJAX') && is_admin()) { |
|
| 82 | 82 | |
| 83 | 83 | // add a settings link to the plugins admin screen |
| 84 | - $plugin_name = str_replace( 'includes/class-', '', plugin_basename( __FILE__ ) ); |
|
| 85 | - add_filter( "plugin_action_links_{$plugin_name}", static function( $actions ) { |
|
| 86 | - return array_merge( [ |
|
| 87 | - '<a href="' . esc_url( admin_url( 'options-general.php?page=wp-php-console' ) ) . '">' . __( 'Settings', 'wp-php-console' ) . '</a>', |
|
| 88 | - ], $actions ); |
|
| 84 | + $plugin_name = str_replace('includes/class-', '', plugin_basename(__FILE__)); |
|
| 85 | + add_filter("plugin_action_links_{$plugin_name}", static function($actions) { |
|
| 86 | + return array_merge([ |
|
| 87 | + '<a href="'.esc_url(admin_url('options-general.php?page=wp-php-console')).'">'.__('Settings', 'wp-php-console').'</a>', |
|
| 88 | + ], $actions); |
|
| 89 | 89 | } ); |
| 90 | 90 | |
| 91 | 91 | // init settings |
| 92 | - require_once __DIR__ . '/class-wp-php-console-settings.php'; |
|
| 92 | + require_once __DIR__.'/class-wp-php-console-settings.php'; |
|
| 93 | 93 | |
| 94 | - new Settings( $this->options ); |
|
| 94 | + new Settings($this->options); |
|
| 95 | 95 | } |
| 96 | 96 | } |
| 97 | 97 | |
@@ -108,20 +108,20 @@ discard block |
||
| 108 | 108 | public function connect() { |
| 109 | 109 | |
| 110 | 110 | // workaround for avoiding headers already sent warnings |
| 111 | - @error_reporting( E_ALL & ~E_WARNING ); |
|
| 111 | + @error_reporting(E_ALL & ~E_WARNING); |
|
| 112 | 112 | |
| 113 | - if ( empty( @session_id() ) ) { |
|
| 113 | + if (empty(@session_id())) { |
|
| 114 | 114 | @session_start(); |
| 115 | 115 | } |
| 116 | 116 | |
| 117 | - if ( ! $this->connector instanceof PhpConsole\Connector ) { |
|
| 117 | + if ( ! $this->connector instanceof PhpConsole\Connector) { |
|
| 118 | 118 | try { |
| 119 | 119 | $this->connector = PhpConsole\Connector::getInstance(); |
| 120 | - } catch ( \Exception $e ) {} |
|
| 120 | + } catch (\Exception $e) {} |
|
| 121 | 121 | } |
| 122 | 122 | |
| 123 | 123 | // restore error reporting |
| 124 | - @error_reporting( E_ALL ); |
|
| 124 | + @error_reporting(E_ALL); |
|
| 125 | 125 | |
| 126 | 126 | // apply PHP Console options |
| 127 | 127 | $this->apply_options(); |
@@ -137,16 +137,16 @@ discard block |
||
| 137 | 137 | */ |
| 138 | 138 | protected function get_options() { |
| 139 | 139 | |
| 140 | - $options = get_option( 'wp_php_console', [] ); |
|
| 140 | + $options = get_option('wp_php_console', []); |
|
| 141 | 141 | |
| 142 | - return wp_parse_args( $options, [ |
|
| 142 | + return wp_parse_args($options, [ |
|
| 143 | 143 | 'ip' => '', |
| 144 | 144 | 'password' => '', |
| 145 | 145 | 'register' => false, |
| 146 | 146 | 'short' => false, |
| 147 | 147 | 'ssl' => false, |
| 148 | 148 | 'stack' => false, |
| 149 | - ] ); |
|
| 149 | + ]); |
|
| 150 | 150 | } |
| 151 | 151 | |
| 152 | 152 | |
@@ -158,31 +158,31 @@ discard block |
||
| 158 | 158 | private function apply_options() { |
| 159 | 159 | |
| 160 | 160 | // bail out if not connected yet to PHP Console |
| 161 | - if ( ! $this->connector instanceof PhpConsole\Connector ) { |
|
| 161 | + if ( ! $this->connector instanceof PhpConsole\Connector) { |
|
| 162 | 162 | return; |
| 163 | 163 | } |
| 164 | 164 | |
| 165 | 165 | // apply 'register' option to PHP Console... |
| 166 | - if ( true === $this->options['register'] && ! class_exists( 'PC', false ) ) { |
|
| 166 | + if (true === $this->options['register'] && ! class_exists('PC', false)) { |
|
| 167 | 167 | // ...only if PC not registered yet |
| 168 | 168 | try { |
| 169 | 169 | PhpConsole\Helper::register(); |
| 170 | - } catch( \Exception $e ) { |
|
| 171 | - $this->print_notice_exception( $e ); |
|
| 170 | + } catch (\Exception $e) { |
|
| 171 | + $this->print_notice_exception($e); |
|
| 172 | 172 | } |
| 173 | 173 | } |
| 174 | 174 | |
| 175 | 175 | // apply 'stack' option to PHP Console |
| 176 | - if ( true === $this->options['stack'] ) { |
|
| 176 | + if (true === $this->options['stack']) { |
|
| 177 | 177 | $this->connector->getDebugDispatcher()->detectTraceAndSource = true; |
| 178 | 178 | } |
| 179 | 179 | |
| 180 | 180 | // apply 'short' option to PHP Console |
| 181 | - if ( true === $this->options['short'] ) { |
|
| 181 | + if (true === $this->options['short']) { |
|
| 182 | 182 | try { |
| 183 | - $this->connector->setSourcesBasePath( $_SERVER['DOCUMENT_ROOT'] ); |
|
| 184 | - } catch ( \Exception $e ) { |
|
| 185 | - $this->print_notice_exception( $e ); |
|
| 183 | + $this->connector->setSourcesBasePath($_SERVER['DOCUMENT_ROOT']); |
|
| 184 | + } catch (\Exception $e) { |
|
| 185 | + $this->print_notice_exception($e); |
|
| 186 | 186 | } |
| 187 | 187 | } |
| 188 | 188 | } |
@@ -198,89 +198,89 @@ discard block |
||
| 198 | 198 | public function init() { |
| 199 | 199 | |
| 200 | 200 | // get PHP Console extension password |
| 201 | - $password = trim( $this->options['password'] ); |
|
| 201 | + $password = trim($this->options['password']); |
|
| 202 | 202 | |
| 203 | - if ( empty( $password ) ) { |
|
| 203 | + if (empty($password)) { |
|
| 204 | 204 | |
| 205 | 205 | // display admin notice and abort if no password has been set |
| 206 | - add_action( 'admin_notices', [ $this, 'password_notice' ] ); |
|
| 206 | + add_action('admin_notices', [$this, 'password_notice']); |
|
| 207 | 207 | return; |
| 208 | 208 | } |
| 209 | 209 | |
| 210 | 210 | // selectively remove slashes added by WordPress as expected by PHP Console |
| 211 | - if ( array_key_exists( PhpConsole\Connector::POST_VAR_NAME, $_POST ) ) { |
|
| 212 | - $_POST[ PhpConsole\Connector::POST_VAR_NAME ] = stripslashes_deep( $_POST[ PhpConsole\Connector::POST_VAR_NAME ] ); |
|
| 211 | + if (array_key_exists(PhpConsole\Connector::POST_VAR_NAME, $_POST)) { |
|
| 212 | + $_POST[PhpConsole\Connector::POST_VAR_NAME] = stripslashes_deep($_POST[PhpConsole\Connector::POST_VAR_NAME]); |
|
| 213 | 213 | } |
| 214 | 214 | |
| 215 | 215 | // get PHP Console instance if wasn't set yet |
| 216 | - if ( ! $this->connector instanceof PhpConsole\Connector ) { |
|
| 216 | + if ( ! $this->connector instanceof PhpConsole\Connector) { |
|
| 217 | 217 | |
| 218 | 218 | try { |
| 219 | 219 | $this->connector = PhpConsole\Connector::getInstance(); |
| 220 | - } catch ( \Exception $e ) { |
|
| 220 | + } catch (\Exception $e) { |
|
| 221 | 221 | return; |
| 222 | 222 | } |
| 223 | 223 | } |
| 224 | 224 | |
| 225 | 225 | // set PHP Console password |
| 226 | 226 | try { |
| 227 | - $this->connector->setPassword( $password ); |
|
| 228 | - } catch ( \Exception $e ) { |
|
| 229 | - $this->print_notice_exception( $e ); |
|
| 227 | + $this->connector->setPassword($password); |
|
| 228 | + } catch (\Exception $e) { |
|
| 229 | + $this->print_notice_exception($e); |
|
| 230 | 230 | } |
| 231 | 231 | |
| 232 | 232 | // get PHP Console handler instance |
| 233 | 233 | $handler = PhpConsole\Handler::getInstance(); |
| 234 | 234 | |
| 235 | - if ( true !== PhpConsole\Handler::getInstance()->isStarted() ) { |
|
| 235 | + if (true !== PhpConsole\Handler::getInstance()->isStarted()) { |
|
| 236 | 236 | try { |
| 237 | 237 | $handler->start(); |
| 238 | - } catch( \Exception $e ) { |
|
| 239 | - $this->print_notice_exception( $e ); |
|
| 238 | + } catch (\Exception $e) { |
|
| 239 | + $this->print_notice_exception($e); |
|
| 240 | 240 | return; |
| 241 | 241 | } |
| 242 | 242 | } |
| 243 | 243 | |
| 244 | 244 | // enable SSL-only mode |
| 245 | - if ( true === $this->options['ssl'] ) { |
|
| 245 | + if (true === $this->options['ssl']) { |
|
| 246 | 246 | $this->connector->enableSslOnlyMode(); |
| 247 | 247 | } |
| 248 | 248 | |
| 249 | 249 | // restrict IP addresses |
| 250 | - $allowedIpMasks = ! empty( $this->options['ip'] ) ? explode( ',', $this->options['ip'] ) : ''; |
|
| 250 | + $allowedIpMasks = ! empty($this->options['ip']) ? explode(',', $this->options['ip']) : ''; |
|
| 251 | 251 | |
| 252 | - if ( is_array( $allowedIpMasks ) && count( $allowedIpMasks ) > 0 ) { |
|
| 253 | - $this->connector->setAllowedIpMasks( $allowedIpMasks ); |
|
| 252 | + if (is_array($allowedIpMasks) && count($allowedIpMasks) > 0) { |
|
| 253 | + $this->connector->setAllowedIpMasks($allowedIpMasks); |
|
| 254 | 254 | } |
| 255 | 255 | |
| 256 | 256 | $evalProvider = $this->connector->getEvalDispatcher()->getEvalProvider(); |
| 257 | 257 | |
| 258 | 258 | try { |
| 259 | - $evalProvider->addSharedVar( 'uri', $_SERVER['REQUEST_URI'] ); |
|
| 260 | - } catch ( \Exception $e ) { |
|
| 261 | - $this->print_notice_exception( $e ); |
|
| 259 | + $evalProvider->addSharedVar('uri', $_SERVER['REQUEST_URI']); |
|
| 260 | + } catch (\Exception $e) { |
|
| 261 | + $this->print_notice_exception($e); |
|
| 262 | 262 | } |
| 263 | 263 | |
| 264 | 264 | try { |
| 265 | - $evalProvider->addSharedVarReference( 'post', $_POST ); |
|
| 266 | - } catch ( \Exception $e ) { |
|
| 267 | - $this->print_notice_exception( $e ); |
|
| 265 | + $evalProvider->addSharedVarReference('post', $_POST); |
|
| 266 | + } catch (\Exception $e) { |
|
| 267 | + $this->print_notice_exception($e); |
|
| 268 | 268 | } |
| 269 | 269 | |
| 270 | - $openBaseDirs = [ ABSPATH, get_template_directory() ]; |
|
| 270 | + $openBaseDirs = [ABSPATH, get_template_directory()]; |
|
| 271 | 271 | |
| 272 | 272 | try { |
| 273 | - $evalProvider->addSharedVarReference( 'dirs', $openBaseDirs ); |
|
| 274 | - } catch ( \Exception $e ) { |
|
| 275 | - $this->print_notice_exception( $e ); |
|
| 273 | + $evalProvider->addSharedVarReference('dirs', $openBaseDirs); |
|
| 274 | + } catch (\Exception $e) { |
|
| 275 | + $this->print_notice_exception($e); |
|
| 276 | 276 | } |
| 277 | 277 | |
| 278 | - $evalProvider->setOpenBaseDirs( $openBaseDirs ); |
|
| 278 | + $evalProvider->setOpenBaseDirs($openBaseDirs); |
|
| 279 | 279 | |
| 280 | 280 | try { |
| 281 | 281 | $this->connector->startEvalRequestsListener(); |
| 282 | - } catch ( \Exception $e ) { |
|
| 283 | - $this->print_notice_exception( $e ); |
|
| 282 | + } catch (\Exception $e) { |
|
| 283 | + $this->print_notice_exception($e); |
|
| 284 | 284 | } |
| 285 | 285 | } |
| 286 | 286 | |
@@ -292,13 +292,13 @@ discard block |
||
| 292 | 292 | * |
| 293 | 293 | * @param \Exception $e Exception object |
| 294 | 294 | */ |
| 295 | - public function print_notice_exception( \Exception $e ) { |
|
| 295 | + public function print_notice_exception(\Exception $e) { |
|
| 296 | 296 | |
| 297 | - add_action( 'admin_notices', static function() use ( $e ) { |
|
| 297 | + add_action('admin_notices', static function() use ($e) { |
|
| 298 | 298 | |
| 299 | 299 | ?> |
| 300 | 300 | <div class="error"> |
| 301 | - <p><?php printf( '%1$s: %2$s', self::NAME, $e->getMessage() ); ?></p> |
|
| 301 | + <p><?php printf('%1$s: %2$s', self::NAME, $e->getMessage()); ?></p> |
|
| 302 | 302 | </div> |
| 303 | 303 | <?php |
| 304 | 304 | |
@@ -322,9 +322,9 @@ discard block |
||
| 322 | 322 | <div class="update-nag"> |
| 323 | 323 | <p><?php printf( |
| 324 | 324 | /* translators: Placeholders: %1$s - WP Php Console name, %2$s - opening HTML <a> link tag; %3$s closing HTML </a> link tag */ |
| 325 | - __( '%1$s: Please remember to %2$sset a password%3$s if you want to enable the terminal.', 'wp-php-console' ), |
|
| 326 | - '<strong>' . self::NAME . '</strong>', |
|
| 327 | - '<a href="' . esc_url( admin_url( 'options-general.php?page=wp-php-console' ) ) .'">', |
|
| 325 | + __('%1$s: Please remember to %2$sset a password%3$s if you want to enable the terminal.', 'wp-php-console'), |
|
| 326 | + '<strong>'.self::NAME.'</strong>', |
|
| 327 | + '<a href="'.esc_url(admin_url('options-general.php?page=wp-php-console')).'">', |
|
| 328 | 328 | '</a>' |
| 329 | 329 | ); ?></p> |
| 330 | 330 | </div> |