WC_API_Orders::delete_order_refund()publicWC 2.2

Delete order refund

Метод класса: WC_API_Orders{}

Хуки из метода

Возвращает

WP_Error|Массив. error or deleted message

Использование

$WC_API_Orders = new WC_API_Orders();
$WC_API_Orders->delete_order_refund( $order_id, $id );
$order_id(строка) (обязательный)
order ID
$id(строка) (обязательный)
refund ID

Список изменений

С версии 2.2 Введена.

Код WC_API_Orders::delete_order_refund() WC 8.7.0

public function delete_order_refund( $order_id, $id ) {
	try {
		$order_id = $this->validate_request( $order_id, $this->post_type, 'delete' );

		if ( is_wp_error( $order_id ) ) {
			return $order_id;
		}

		// Validate refund ID
		$id = absint( $id );

		if ( empty( $id ) ) {
			throw new WC_API_Exception( 'woocommerce_api_invalid_order_refund_id', __( 'Invalid order refund ID.', 'woocommerce' ), 400 );
		}

		// Ensure refund ID is valid
		$refund = get_post( $id );

		if ( ! $refund ) {
			throw new WC_API_Exception( 'woocommerce_api_invalid_order_refund_id', __( 'An order refund with the provided ID could not be found.', 'woocommerce' ), 404 );
		}

		// Ensure refund ID is associated with given order
		if ( $refund->post_parent != $order_id ) {
			throw new WC_API_Exception( 'woocommerce_api_invalid_order_refund_id', __( 'The order refund ID provided is not associated with the order.', 'woocommerce' ), 400 );
		}

		wc_delete_shop_order_transients( $order_id );

		do_action( 'woocommerce_api_delete_order_refund', $refund->ID, $order_id, $this );

		return $this->delete( $refund->ID, 'refund', true );
	} catch ( WC_API_Exception $e ) {
		return new WP_Error( $e->getErrorCode(), $e->getMessage(), array( 'status' => $e->getCode() ) );
	}
}