From 350d2ead4a8038a34648db5e4229d2d6a3d7da2c Mon Sep 17 00:00:00 2001 From: Daniel Bachhuber Date: Wed, 15 Aug 2018 17:12:07 -0700 Subject: [PATCH 1/2] Permit database credentials to be exported when finding installations --- README.md | 5 +++- src/Find_Command.php | 61 ++++++++++++++++++++++++++++++++++++++++---- 2 files changed, 60 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 57807a9..261228b 100644 --- a/README.md +++ b/README.md @@ -44,6 +44,9 @@ These fields will be displayed by default for each installation: These fields are optionally available: * wp_path - Path that can be passed to `--path=` global parameter. +* db_host - Host name for the database. +* db_user - User name for the database. +* db_name - Database name for the database. **OPTIONS** @@ -82,7 +85,7 @@ These fields are optionally available: ## Installing -Installing this package requires WP-CLI's latest stable release. Update to the latest stable release with `wp cli update`. +Installing this package requires WP-CLI 2 or greater. Update to the latest stable release with `wp cli update`. Once you've done so, you can install this package with: diff --git a/src/Find_Command.php b/src/Find_Command.php index 65d7862..bfb9521 100644 --- a/src/Find_Command.php +++ b/src/Find_Command.php @@ -145,6 +145,9 @@ class Find_Command { * These fields are optionally available: * * * wp_path - Path that can be passed to `--path=` global parameter. + * * db_host - Host name for the database. + * * db_user - User name for the database. + * * db_name - Database name for the database. * * ## OPTIONS * @@ -204,11 +207,16 @@ public function __invoke( $args, $assoc_args ) { $this->resolved_aliases[ rtrim( $target['path'], '/' ) ] = $alias; } + $fields = array( 'version_path', 'version', 'depth', 'alias' ); + if ( ! empty( $assoc_args['fields'] ) ) { + $fields = explode( ',', $assoc_args['fields'] ); + } + $this->start_time = microtime( true ); $this->log( "Searching for WordPress installations in '{$path}'" ); $this->recurse_directory( $this->base_path ); $this->log( "Finished search for WordPress installations in '{$path}'" ); - $formatter = new \WP_CLI\Formatter( $assoc_args, array( 'version_path', 'version', 'depth', 'alias' ) ); + $formatter = new \WP_CLI\Formatter( $assoc_args, $fields ); $formatter->display_items( $this->found_wp ); } @@ -245,16 +253,40 @@ private function recurse_directory( $path ) { // version.php file. if ( '/wp-includes/' === substr( $path, -13 ) && file_exists( $path . 'version.php' ) ) { - $version_path = $path . 'version.php'; - $wp_path = substr( $path, 0, -13 ); - $alias = isset( $this->resolved_aliases[ $wp_path ] ) ? $this->resolved_aliases[ $wp_path ] : ''; + $version_path = $path . 'version.php'; + $wp_path = substr( $path, 0, -13 ); + $alias = isset( $this->resolved_aliases[ $wp_path ] ) ? $this->resolved_aliases[ $wp_path ] : ''; + $wp_path = rtrim( $wp_path, '/' ) . '/'; + $this->found_wp[ $version_path ] = array( 'version_path' => $version_path, 'version' => self::get_wp_version( $version_path ), - 'wp_path' => str_replace( 'wp-includes/version.php', '', $version_path ), + 'wp_path' => rtrim( $wp_path, '/' ) . '/', 'depth' => $this->current_depth - 1, 'alias' => $alias, + 'db_host' => '', + 'db_name' => '', + 'db_user' => '', ); + $config_path = self::get_wp_config_path( $wp_path ); + if ( $config_path ) { + try { + $transformer = new WPConfigTransformer( $config_path ); + foreach ( array( 'db_host', 'db_name', 'db_user' ) as $constant ) { + $value = $transformer->get_value( 'constant', strtoupper( $constant ) ); + // Clean up strings. + $first = substr( $value, 0, 1 ); + $last = substr( $value, -1 ); + $both = array_unique( array( $first, $last ) ); + if ( in_array( $both, array( array( '"' ), array( "'" ) ), true ) ) { + $value = substr( $value, 1, -1 ); + } + $this->found_wp[ $version_path ][ $constant ] = $value; + } + } catch ( \Exception $e ) { + $this->log( "Could not process the 'wp-config.php' transformation: " . $exception->getMessage() ); + } + } $this->log( "Found WordPress installation at '{$version_path}'" ); return; } @@ -292,6 +324,25 @@ private static function get_wp_version( $path ) { return ! empty( $matches[1] ) ? $matches[1] : ''; } + /** + * Get the wp-config.php path for the installation. + * + * Adapted from WP_CLI\Utils\locate_wp_config() + */ + private static function get_wp_config_path( $installation_dir ) { + $path = false; + if ( file_exists( $installation_dir . 'wp-config.php' ) ) { + $path = $installation_dir . 'wp-config.php'; + } elseif ( file_exists( $installation_dir . '../wp-config.php' ) && ! file_exists( $installation_dir . '/../wp-settings.php' ) ) { + $path = $installation_dir . '../wp-config.php'; + } + + if ( $path ) { + $path = realpath( $path ); + } + return $path; + } + /** * Log informational message to STDOUT depending on verbosity. */ From 604b0396005953faa14ef4505bafba1bd04c7ab0 Mon Sep 17 00:00:00 2001 From: Daniel Bachhuber Date: Wed, 15 Aug 2018 17:14:40 -0700 Subject: [PATCH 2/2] Fix PHPCS issue --- src/Find_Command.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Find_Command.php b/src/Find_Command.php index bfb9521..dcd14f8 100644 --- a/src/Find_Command.php +++ b/src/Find_Command.php @@ -268,6 +268,7 @@ private function recurse_directory( $path ) { 'db_name' => '', 'db_user' => '', ); + $config_path = self::get_wp_config_path( $wp_path ); if ( $config_path ) { try {