wp-async-task不要触发run_action方法

时间:2016-03-10 18:38:46

标签: php wordpress asynchronous wordpress-plugin background-process

我必须使用techcrunch wp-async-task在我的 wordpress插件中在后台运行同步任务。

所以要测试一下,我在主文件的底部有:

//top of the php file
require_once(dirname(__FILE__) . '/lib/WP_Async_Task.php');
require_once(dirname(__FILE__) . '/class/my_api_status.class.php');
define('API_URL', '...');

/* ... */

// At the bottom of the file
function my_api_status($api_url)
{
  sleep(5);
  $r = wp_safe_remote_get($api_url);
  if (!is_wp_error($r)) {
    $body = json_decode(wp_remote_retrieve_body($r));
    if (isset($body->success)) {
      return;
    }
  }
}
add_action('wp_async_api_status', 'my_api_status');

function my_init_api_status()
{
  new ApiStatusTask();
  do_action('api_status', constant('API_URL'));
}
add_action('plugins_loaded', 'my_init_api_status');

和api状态任务类

class ApiStatusTask extends WP_Async_Task {

  protected $action = 'api_status';

  /**
   * Prepare data for the asynchronous request
   * @throws Exception If for any reason the request should not happen
   * @param array $data An array of data sent to the hook
   * @return array
   */
  protected function prepare_data( $data ) {
    return array(
      'api_url' => $data[0]
    );
  }

  /**
   * Run the async task action
   */
  protected function run_action() {
    if(isset($_POST['api_url'])){
      do_action("wp_async_$this->action", $_POST['api_url']);
    }
  }

}

prepare_data正确调用了函数launch,之后也正确调用了launch_on_shutdown,最后在wp_remote_post结束时调用了launch_on_shutdown admin-post.php。 但函数run_action永远不会被调用...所以主文件中的my_api_status

它可能出错了什么?

1 个答案:

答案 0 :(得分:1)

我很快就会在这里提供一个完整的插件示例。但就目前而言,我发现了我的问题:

// In the `launch_on_shutdown` method of `WP_Async_Task` class

public function launch_on_shutdown() {
  GcLogger::getLogger()->debug('WP_Async_Task::launch_on_shutdown');
  if ( ! empty( $this->_body_data ) ) {
    $cookies = array();
    foreach ( $_COOKIE as $name => $value ) {
      $cookies[] = "$name=" . urlencode( is_array( $value ) ? serialize( $value ) : $value );
    }

    $request_args = array(
        'timeout'   => 0.01,
        'blocking'  => false,
        'sslverify' => false, //apply_filters( 'https_local_ssl_verify', true ),
        'body'      => $this->_body_data,
        'headers'   => array(
            'cookie' => implode( '; ', $cookies ),
        ),
    );

    $url = admin_url( 'admin-post.php' );
    GcLogger::getLogger()->debug('WP_Async_Task::launch_on_shutdown wp_remote_post');
    wp_remote_post( $url, $request_args );
  }
}

sslverify 选项在我的本地环境中失败。如果我们没有投入生产,我就不得不把它弄错了。

设置此选项后,run_action会正确触发。