• Austin

    (@austyfrosty)


    Following up on this previous thread: https://www.ads-software.com/support/topic/error-500-if-_embed1-parameter-is-provided/

    I too just saw the same 500 Error. Here is my stack trace:

    PHP Fatal error:  Uncaught Error: Call to undefined method WP_Error::get_matched_route() in /wordpress-versions/6.1.3/wp-includes/rest-api.php:805
    Stack trace:
    #0 /wordpress-versions/6.1.3/wp-includes/class-wp-hook.php(308): rest_send_allow_header(Object(WP_Error), Object(WP_REST_Server), Object(WP_REST_Request))
    #1 /wordpress-versions/6.1.3/wp-includes/plugin.php(205): WP_Hook->apply_filters(Object(WP_Error), Array)
    #2 /wordpress-versions/6.1.3/wp-includes/rest-api/class-wp-rest-server.php(731): apply_filters('rest_post_dispa...', Object(WP_Error), Object(WP_REST_Server), Object(WP_REST_Request))
    #3 /wordpress-versions/6.1.3/wp-includes/rest-api/class-wp-rest-server.php(581): WP_REST_Server->embed_links(Array, true)
    #4 /wordpress-versions/6.1.3/wp-includes/rest-api/class-wp-rest-server.php(503): WP_REST_Server->response_to_data(Object(WP_REST_Response), true)
    #5 /wordpress-versions/6.1.3/wp-includes/rest-api.php(410): WP_REST_Server->serve_request('/wp/v2/posts')
    #6 /wordpress-versions/6.1.3/wp-includes/class-wp-hook.php(308): rest_api_loaded(Object(WP))
    #7 /wordpress-versions/6.1.3/wp-includes/class-wp-hook.php(332): WP_Hook->apply_filters('', Array)
    #8 /wordpress-versions/6.1.3/wp-includes/plugin.php(565): WP_Hook->do_action(Array)
    #9 /wordpress-versions/6.1.3/wp-includes/class-wp.php(399): do_action_ref_array('parse_request', Array)
    #10 /wordpress-versions/6.1.3/wp-includes/class-wp.php(780): WP->parse_request('')
    #11 /wordpress-versions/6.1.3/wp-includes/functions.php(1332): WP->main('')
    #12 /wordpress-versions/6.1.3/wp-blog-header.php(16): wp()
    #13 /wordpress-versions/6.1.3/index.php(17): require('/wordpress-vers...')
    #14 {main}
      thrown in /wordpress-versions/6.1.3/wp-includes/rest-api.php on line 805

    I will try to replicate this locally, to see if I can come up with a fix. Looks like at some point the replacement of WP_REST_Response with WP_Error is causing the error.

Viewing 4 replies - 1 through 4 (of 4 total)
  • Thread Starter Austin

    (@austyfrosty)

    I haven’t been able to replicate it locally on my local box, but I am able to in my stage and prod servers.

    So far the only setting I have enabled is “Require Authentication for Users”. As soon as that box is checked any REST response fails with he error mentioned above.

    Right now the only difference between my local box and host apps free/pro Redis plugin; I am using Redis Cache on local, and Object Cache Pro in stage/prod (if this makes a difference). I will try to get the pro plugin installed to verify Still works locally with the PRO version.

    • This reply was modified 1 year, 4 months ago by Austin.
    Plugin Author Pete Nelson

    (@gungeekatx)

    Thanks for the details, looking into this.

    Plugin Author Pete Nelson

    (@gungeekatx)

    I haven’t been able to replicate this locally either, both with WP 6.2.2 and WP 6.1.3 (based on your stack trace). Also on my live site, trying to access the users REST endpoint when it requires auth does not have any fatal errors, just the expected response. https://petenelson.io/wp-json/wp/v2/users

    Thread Starter Austin

    (@austyfrosty)

    Yeah, it’s for sure strange. I am unsure how to replicate it as well.

    Not sure why the code is allowing WP_Error to continue as the new response object…

Viewing 4 replies - 1 through 4 (of 4 total)
  • The topic ‘PHP Fatal error: Uncaught Error: Call to undefined method’ is closed to new replies.