本文整理匯總了PHP中WC_Webhook::deliver_ping方法的典型用法代碼示例。如果您正苦於以下問題:PHP WC_Webhook::deliver_ping方法的具體用法?PHP WC_Webhook::deliver_ping怎麽用?PHP WC_Webhook::deliver_ping使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類WC_Webhook
的用法示例。
在下文中一共展示了WC_Webhook::deliver_ping方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: create_webhook
/**
* Create an webhook
*
* @since 2.2
* @param array $data parsed webhook data
* @return array
*/
public function create_webhook($data)
{
$data = isset($data['webhook']) ? $data['webhook'] : array();
try {
// permission check
if (!current_user_can('publish_shop_webhooks')) {
throw new WC_API_Exception('woocommerce_api_user_cannot_create_webhooks', __('You do not have permission to create webhooks', 'woocommerce'), 401);
}
$data = apply_filters('woocommerce_api_create_webhook_data', $data, $this);
// validate topic
if (empty($data['topic']) || !wc_is_webhook_valid_topic(strtolower($data['topic']))) {
throw new WC_API_Exception('woocommerce_api_invalid_webhook_topic', __('Webhook topic is required and must be valid', 'woocommerce'), 400);
}
// validate delivery URL
if (empty($data['delivery_url']) || !wc_is_valid_url($data['delivery_url'])) {
throw new WC_API_Exception('woocommerce_api_invalid_webhook_delivery_url', __('Webhook delivery URL must be a valid URL starting with http:// or https://', 'woocommerce'), 400);
}
$webhook_data = apply_filters('woocommerce_new_webhook_data', array('post_type' => 'shop_webhook', 'post_status' => 'publish', 'ping_status' => 'closed', 'post_author' => get_current_user_id(), 'post_password' => strlen($password = uniqid('webhook_')) > 20 ? substr($password, 0, 20) : $password, 'post_title' => !empty($data['name']) ? $data['name'] : sprintf(__('Webhook created on %s', 'woocommerce'), strftime(_x('%b %d, %Y @ %I:%M %p', 'Webhook created on date parsed by strftime', 'woocommerce')))), $data, $this);
$webhook_id = wp_insert_post($webhook_data);
if (is_wp_error($webhook_id) || !$webhook_id) {
throw new WC_API_Exception('woocommerce_api_cannot_create_webhook', sprintf(__('Cannot create webhook: %s', 'woocommerce'), is_wp_error($webhook_id) ? implode(', ', $webhook_id->get_error_messages()) : '0'), 500);
}
$webhook = new WC_Webhook($webhook_id);
// set topic, delivery URL, and optional secret
$webhook->set_topic($data['topic']);
$webhook->set_delivery_url($data['delivery_url']);
// set secret if provided, defaults to API users consumer secret
$webhook->set_secret(!empty($data['secret']) ? $data['secret'] : get_user_meta(get_current_user_id(), 'woocommerce_api_consumer_secret', true));
// send ping
$webhook->deliver_ping();
// HTTP 201 Created
$this->server->send_status(201);
do_action('woocommerce_api_create_webhook', $webhook->id, $this);
delete_transient('woocommerce_webhook_ids');
return $this->get_webhook($webhook->id);
} catch (WC_API_Exception $e) {
return new WP_Error($e->getErrorCode(), $e->getMessage(), array('status' => $e->getCode()));
}
}
示例2: create_item
/**
* Create a single webhook.
*
* @param WP_REST_Request $request Full details about the request.
* @return WP_Error|WP_REST_Response
*/
public function create_item($request)
{
if (!empty($request['id'])) {
return new WP_Error("woocommerce_rest_{$this->post_type}_exists", sprintf(__('Cannot create existing %s.', 'woocommerce'), $this->post_type), array('status' => 400));
}
// Validate topic.
if (empty($request['topic']) || !wc_is_webhook_valid_topic(strtolower($request['topic']))) {
return new WP_Error("woocommerce_rest_{$this->post_type}_invalid_topic", __('Webhook topic is required and must be valid.', 'woocommerce'), array('status' => 400));
}
// Validate delivery URL.
if (empty($request['delivery_url']) || !wc_is_valid_url($request['delivery_url'])) {
return new WP_Error("woocommerce_rest_{$this->post_type}_invalid_delivery_url", __('Webhook delivery URL must be a valid URL starting with http:// or https://.', 'woocommerce'), array('status' => 400));
}
$post = $this->prepare_item_for_database($request);
if (is_wp_error($post)) {
return $post;
}
$post->post_type = $this->post_type;
$post_id = wp_insert_post($post, true);
if (is_wp_error($post_id)) {
if (in_array($post_id->get_error_code(), array('db_insert_error'))) {
$post_id->add_data(array('status' => 500));
} else {
$post_id->add_data(array('status' => 400));
}
return $post_id;
}
$post->ID = $post_id;
$webhook = new WC_Webhook($post_id);
// Set topic.
$webhook->set_topic($request['topic']);
// Set delivery URL.
$webhook->set_delivery_url($request['delivery_url']);
// Set secret.
$webhook->set_secret(!empty($request['secret']) ? $request['secret'] : '');
// Set status.
if (!empty($request['status'])) {
$webhook->update_status($request['status']);
}
$post = get_post($post_id);
$this->update_additional_fields_for_object($post, $request);
/**
* Fires after a single item is created or updated via the REST API.
*
* @param WP_Post $post Inserted object.
* @param WP_REST_Request $request Request object.
* @param boolean $creating True when creating item, false when updating.
*/
do_action("woocommerce_rest_insert_{$this->post_type}", $post, $request, true);
$request->set_param('context', 'edit');
$response = $this->prepare_item_for_response($post, $request);
$response = rest_ensure_response($response);
$response->set_status(201);
$response->header('Location', rest_url(sprintf('/%s/%s/%d', $this->namespace, $this->rest_base, $post_id)));
// Send ping.
$webhook->deliver_ping();
// Clear cache.
delete_transient('woocommerce_webhook_ids');
return $response;
}