1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
<?php namespace Automattic\WooCommerce\StoreApi\Exceptions;
use WP_Error;
/** * InvalidCartException class. * * @internal This exception is thrown if the cart is in an erroneous state. */ class InvalidCartException extends \Exception { /** * Sanitized error code. * * @var string */ public $error_code;
/** * Additional error data. * * @var array */ public $additional_data = [];
/** * All errors to display to the user. * * @var WP_Error */ public $error;
/** * Setup exception. * * @param string $error_code Machine-readable error code, e.g `woocommerce_invalid_product_id`. * @param WP_Error $error The WP_Error object containing all errors relating to stock availability. * @param array $additional_data Extra data (key value pairs) to expose in the error response. */ public function __construct( $error_code, WP_Error $error, $additional_data = [] ) { $this->error_code = $error_code; $this->error = $error; $this->additional_data = array_filter( (array) $additional_data ); parent::__construct( '', 409 ); }
/** * Returns the error code. * * @return string */ public function getErrorCode() { return $this->error_code; }
/** * Returns the list of messages. * * @return WP_Error */ public function getError() { return $this->error; }
/** * Returns additional error data. * * @return array */ public function getAdditionalData() { return $this->additional_data; }
}
|