我正在使用 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
......?
我想我将只执行三个单独的调用,而不是等待解决方案......