185 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
WP_CLI::add_command( 'akismet', 'Akismet_CLI' );
 | 
						|
 | 
						|
/**
 | 
						|
 * Filter spam comments.
 | 
						|
 */
 | 
						|
class Akismet_CLI extends WP_CLI_Command {
 | 
						|
	/**
 | 
						|
	 * Checks one or more comments against the Akismet API.
 | 
						|
	 *
 | 
						|
	 * ## OPTIONS
 | 
						|
	 * <comment_id>...
 | 
						|
	 * : The ID(s) of the comment(s) to check.
 | 
						|
	 *
 | 
						|
	 * [--noaction]
 | 
						|
	 * : Don't change the status of the comment. Just report what Akismet thinks it is.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *     wp akismet check 12345
 | 
						|
	 *
 | 
						|
	 * @alias comment-check
 | 
						|
	 */
 | 
						|
	public function check( $args, $assoc_args ) {
 | 
						|
		foreach ( $args as $comment_id ) {
 | 
						|
			if ( isset( $assoc_args['noaction'] ) ) {
 | 
						|
				// Check the comment, but don't reclassify it.
 | 
						|
				$api_response = Akismet::check_db_comment( $comment_id, 'wp-cli' );
 | 
						|
			}
 | 
						|
			else {
 | 
						|
				$api_response = Akismet::recheck_comment( $comment_id, 'wp-cli' );
 | 
						|
			}
 | 
						|
			
 | 
						|
			if ( 'true' === $api_response ) {
 | 
						|
				WP_CLI::line( sprintf( __( "Comment #%d is spam.", 'akismet' ), $comment_id ) );
 | 
						|
			}
 | 
						|
			else if ( 'false' === $api_response ) {
 | 
						|
				WP_CLI::line( sprintf( __( "Comment #%d is not spam.", 'akismet' ), $comment_id ) );
 | 
						|
			}
 | 
						|
			else {
 | 
						|
				if ( false === $api_response ) {
 | 
						|
					WP_CLI::error( __( "Failed to connect to Akismet.", 'akismet' ) );
 | 
						|
				}
 | 
						|
				else if ( is_wp_error( $api_response ) ) {
 | 
						|
					WP_CLI::warning( sprintf( __( "Comment #%d could not be checked.", 'akismet' ), $comment_id ) );
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	
 | 
						|
	/**
 | 
						|
	 * Recheck all comments in the Pending queue.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 *     wp akismet recheck_queue
 | 
						|
	 *
 | 
						|
	 * @alias recheck-queue
 | 
						|
	 */
 | 
						|
	public function recheck_queue() {
 | 
						|
		$batch_size = 100;
 | 
						|
		$start = 0;
 | 
						|
		
 | 
						|
		$total_counts = array();
 | 
						|
		
 | 
						|
		do {
 | 
						|
			$result_counts = Akismet_Admin::recheck_queue_portion( $start, $batch_size );
 | 
						|
			
 | 
						|
			if ( $result_counts['processed'] > 0 ) {
 | 
						|
				foreach ( $result_counts as $key => $count ) {
 | 
						|
					if ( ! isset( $total_counts[ $key ] ) ) {
 | 
						|
						$total_counts[ $key ] = $count;
 | 
						|
					}
 | 
						|
					else {
 | 
						|
						$total_counts[ $key ] += $count;
 | 
						|
					}
 | 
						|
				}
 | 
						|
				$start += $batch_size;
 | 
						|
				$start -= $result_counts['spam']; // These comments will have been removed from the queue.
 | 
						|
			}
 | 
						|
		} while ( $result_counts['processed'] > 0 );
 | 
						|
		
 | 
						|
		WP_CLI::line( sprintf( _n( "Processed %d comment.", "Processed %d comments.", $total_counts['processed'], 'akismet' ), number_format( $total_counts['processed'] ) ) );
 | 
						|
		WP_CLI::line( sprintf( _n( "%d comment moved to Spam.", "%d comments moved to Spam.", $total_counts['spam'], 'akismet' ), number_format( $total_counts['spam'] ) ) );
 | 
						|
		
 | 
						|
		if ( $total_counts['error'] ) {
 | 
						|
			WP_CLI::line( sprintf( _n( "%d comment could not be checked.", "%d comments could not be checked.", $total_counts['error'], 'akismet' ), number_format( $total_counts['error'] ) ) );
 | 
						|
		}
 | 
						|
	}
 | 
						|
	
 | 
						|
	/**
 | 
						|
	 * Fetches stats from the Akismet API.
 | 
						|
	 *
 | 
						|
	 * ## OPTIONS
 | 
						|
	 *
 | 
						|
	 * [<interval>]
 | 
						|
	 * : The time period for which to retrieve stats.
 | 
						|
	 * ---
 | 
						|
	 * default: all
 | 
						|
	 * options:
 | 
						|
	 *  - days
 | 
						|
	 *  - months
 | 
						|
	 *  - all
 | 
						|
	 * ---
 | 
						|
	 *
 | 
						|
	 * [--format=<format>]
 | 
						|
	 * : Allows overriding the output of the command when listing connections.
 | 
						|
	 * ---
 | 
						|
	 * default: table
 | 
						|
	 * options:
 | 
						|
	 *  - table
 | 
						|
	 *  - json
 | 
						|
	 *  - csv
 | 
						|
	 *  - yaml
 | 
						|
	 *  - count
 | 
						|
	 * ---
 | 
						|
	 *
 | 
						|
	 * [--summary]
 | 
						|
	 * : When set, will display a summary of the stats.
 | 
						|
	 *
 | 
						|
	 * ## EXAMPLES
 | 
						|
	 *
 | 
						|
	 * wp akismet stats
 | 
						|
	 * wp akismet stats all
 | 
						|
	 * wp akismet stats days
 | 
						|
	 * wp akismet stats months
 | 
						|
	 * wp akismet stats all --summary
 | 
						|
	 */
 | 
						|
	public function stats( $args, $assoc_args ) {
 | 
						|
		$api_key = Akismet::get_api_key();
 | 
						|
 
 | 
						|
		if ( empty( $api_key ) ) {
 | 
						|
			WP_CLI::error( __( 'API key must be set to fetch stats.', 'akismet' ) );
 | 
						|
		}
 | 
						|
 
 | 
						|
		switch ( $args[0] ) {
 | 
						|
			case 'days':
 | 
						|
				$interval = '60-days';
 | 
						|
				break;
 | 
						|
			case 'months':
 | 
						|
				$interval = '6-months';
 | 
						|
				break;
 | 
						|
			default:
 | 
						|
				$interval = 'all';
 | 
						|
				break;
 | 
						|
		}
 | 
						|
 
 | 
						|
		$response = Akismet::http_post(
 | 
						|
			Akismet::build_query( array(
 | 
						|
				'blog' => get_option( 'home' ),
 | 
						|
				'key'  => $api_key,
 | 
						|
				'from' => $interval,
 | 
						|
			) ),
 | 
						|
			'get-stats'
 | 
						|
		);
 | 
						|
 
 | 
						|
		if ( empty( $response[1] ) ) {
 | 
						|
			WP_CLI::error( __( 'Currently unable to fetch stats. Please try again.', 'akismet' ) );
 | 
						|
		}
 | 
						|
 
 | 
						|
		$response_body = json_decode( $response[1], true );
 | 
						|
		
 | 
						|
		if ( is_null( $response_body ) ) {
 | 
						|
			WP_CLI::error( __( 'Stats response could not be decoded.', 'akismet' ) );
 | 
						|
		}
 | 
						|
 
 | 
						|
		if ( isset( $assoc_args['summary'] ) ) {
 | 
						|
			$keys = array(
 | 
						|
				'spam',
 | 
						|
				'ham',
 | 
						|
				'missed_spam',
 | 
						|
				'false_positives',
 | 
						|
				'accuracy',
 | 
						|
				'time_saved',
 | 
						|
			);
 | 
						|
 
 | 
						|
			WP_CLI\Utils\format_items( $assoc_args['format'], array( $response_body ), $keys );
 | 
						|
		}
 | 
						|
		else {
 | 
						|
			$stats = $response_body['breakdown'];
 | 
						|
			WP_CLI\Utils\format_items( $assoc_args['format'], $stats, array_keys( end( $stats ) ) );
 | 
						|
		}
 | 
						|
	}
 | 
						|
} |