1

我正在使用 C# 通过新的 REST API 从 WooCommerce 2.6 安装中检索订单列表。

我需要做的是获取具有三种可能状态之一的订单,但 API 似乎只允许我在每次调用时过滤一个状态。这是用于 WooCommerce 2.5x REST API 的代码的一部分:

// Create a list of parameters for filtering the result set
Dictionary<string, string> parameters = new Dictionary<string, string>();
parameters["status"] = "pending,processing,on-hold";
parameters["expand"] = "coupons,products,taxes";

// Use RestSharp to call the API
var client = new RestClient(wooHelper.ApiUrl);
...
var request = new RestRequest(url, Method.GET);
var response = client.Execute(request);

字典中的值parameters被附加到 API URL,所以最后我得到了这样的东西:

https://example.com/wp-json/wc/v1/orders?status=pending,processing,on-hold&expand=coupons,products,taxes&<other parameters for OAUTH>

2.5 API 用于返回具有其中一种状态的订单列表status。现在我收到一个错误,说这status不是值之一any,...

是否仍然可以在一次调用中检索待处理、处理或暂停订单的列表,或者我是否需要对 API 执行三个单独的调用?


编辑:实际错误 JSON 是

{
    "code" : "rest_invalid_param",
    "message" : "Ung\u00fcltige(r) Parameter: status",
    "data" : {
        "status" : 400,
        "params" : {
            "status" : "status ist kein any, pending, processing, on-hold, completed, cancelled, refunded, failed"
        }
    }
}

编辑 2:挖掘WooCommerce 源代码发现了以下代码片段:

/**
 * Query args.
 *
 * @param array $args
 * @param WP_REST_Request $request
 * @return array
 */
public function query_args( $args, $request ) {
    global $wpdb;

    // Set post_status.
    if ( 'any' !== $request['status'] ) {
        $args['post_status'] = 'wc-' . $request['status'];
    } else {
        $args['post_status'] = 'any';
    }

所以当传入多个状态时,这会$args['post_status']变成wc-pending,processing,on-hold......?

我想我将只执行三个单独的调用,而不是等待解决方案......

4

1 回答 1

1

我在 GitHub 上对此进行了调查,结果发现新的 REST API 不再支持按多个状态值进行过滤。(https://github.com/woothemes/woocommerce/issues/11676)。

于 2016-08-15T13:23:09.317 回答