Make WordPress Core

Ticket #39730: 39730.6.patch

File 39730.6.patch, 3.7 KB (added by ryotsun, 7 years ago)

Fix codes according to the review comments.

  • src/wp-admin/includes/ajax-actions.php

     
    11001100        }
    11011101
    11021102        $comment_id = wp_new_comment( $commentdata );
     1103
     1104        if ( is_wp_error( $comment_id ) ) {
     1105                wp_send_json_error ( $comment_id->get_error_message() );
     1106        }
     1107
    11031108        $comment = get_comment($comment_id);
    11041109        if ( ! $comment ) wp_die( 1 );
    11051110
  • src/wp-includes/class-wp-xmlrpc-server.php

     
    64856485
    64866486                $comment_ID = wp_new_comment($commentdata);
    64876487
     6488                if ( is_wp_error( $comment_ID ) ) {
     6489                        return $this->pingback_error( 0, $comment_ID->get_error_message() );
     6490                }
     6491
    64886492                /**
    64896493                 * Fires after a post pingback has been sent.
    64906494                 *
  • src/wp-includes/comment.php

     
    769769         * Filters a comment's approval status before it is set.
    770770         *
    771771         * @since 2.1.0
     772         * @since 4.9.0 Returning a WP_Error value from the filter will shortcircuit comment insertion and
     773         *              allow skipping further processing.
    772774         *
    773          * @param bool|string $approved    The approval status. Accepts 1, 0, or 'spam'.
    774          * @param array       $commentdata Comment data.
     775         * @param bool|string|WP_Error $approved    The approval status. Accepts 1, 0, 'spam' or WP_Error.
     776         * @param array                $commentdata Comment data.
    775777         */
    776778        $approved = apply_filters( 'pre_comment_approved', $approved, $commentdata );
    777779        return $approved;
  • src/wp-trackback.php

     
    126126
    127127        $commentdata = compact('comment_post_ID', 'comment_author', 'comment_author_email', 'comment_author_url', 'comment_content', 'comment_type');
    128128
    129         wp_new_comment($commentdata);
     129        $result = wp_new_comment( $commentdata );
     130
     131        if ( is_wp_error( $result ) ) {
     132                trackback_response( 1, $result->get_error_message() );
     133        }
     134
    130135        $trackback_id = $wpdb->insert_id;
    131136
    132137        /**
  • tests/phpunit/tests/ajax/ReplytoComment.php

     
    222222                }
    223223                return $sql;
    224224        }
     225
     226        /**
     227         * Raises WP_Error after Posted a new pre comment
     228         * @ticket 39730
     229         * @return void
     230         */
     231        public function test_pre_comments_approved () {
     232
     233                // Become an administrator
     234                $this->_setRole( 'administrator' );
     235
     236                // Set up a default request
     237                $_POST['_ajax_nonce-replyto-comment'] = wp_create_nonce( 'replyto-comment' );
     238                $_POST['content']                     = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.';
     239                $_POST['comment_post_ID']             = self::$comment_post->ID;
     240
     241                // Simulate filter check error
     242                add_filter( 'pre_comment_approved', array( $this, '_pre_comment_approved_filter' ), 10, 2 );
     243
     244                // Make the request
     245                $this->setExpectedException( 'WPAjaxDieStopException', 'pre_comment_approved filter fails for new comment' );
     246                $this->_handleAjax( 'replyto-comment' );
     247        }
     248
     249        /**
     250         *  Block comments from being saved 'pre_comment_approved', by returning WP_Error
     251         */
     252        function _pre_comment_approved_filter ( $approved, $commentdata ) {
     253                return new WP_Error( 'comment_wrong', __( 'pre_comment_approved filter fails for new comment' ), 403 );
     254        }
    225255}