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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
use std::borrow::Cow;
#[derive(Debug)]
pub enum OpenProtocolError<'a> {
EmptyField(Cow<'a, str>),
InvalidField { field: Cow<'a, str>, value: Cow<'a, str>, description: Cow<'a, str> },
InconsistentState(Cow<'a, str>),
InconsistentField(Cow<'a, str>),
ConstraintViolated(Cow<'a, str>),
JsonError(serde_json::Error),
}
impl std::error::Error for OpenProtocolError<'_> {
fn description(&self) -> &str {
match self {
OpenProtocolError::JsonError(err) => err.description(),
OpenProtocolError::InvalidField { description, .. } if description.is_empty() => {
"invalid field value"
}
OpenProtocolError::InvalidField { description, .. } => description,
OpenProtocolError::ConstraintViolated(err) => err,
OpenProtocolError::InconsistentField(_) => {
"value of field is not the same as matching field in the Controller"
}
OpenProtocolError::InconsistentState(_) => {
"value of field is not the same as matching field in the state"
}
OpenProtocolError::EmptyField(_) => "field cannot be empty or all whitespace",
}
}
fn cause(&self) -> Option<&dyn std::error::Error> {
match self {
OpenProtocolError::JsonError(err) => Some(err),
_ => None,
}
}
}
impl std::fmt::Display for OpenProtocolError<'_> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::result::Result<(), std::fmt::Error> {
match self {
OpenProtocolError::JsonError(err) => err.fmt(f),
OpenProtocolError::InvalidField { field, value, description }
if description.is_empty() =>
{
write!(f, "value [{}] is invalid for the field {}", value, field)
}
OpenProtocolError::InvalidField { field, value, description } => {
write!(f, "value [{}] is invalid for the field {}: {}", value, field, description)
}
OpenProtocolError::ConstraintViolated(err) => err.fmt(f),
OpenProtocolError::InconsistentField(field) => write!(
f,
"value of field {} is not the same as the matching field in the Controller",
field
),
OpenProtocolError::InconsistentState(field) => write!(
f,
"value of field {} is not the same as the matching field in the state",
field
),
OpenProtocolError::EmptyField(field) => {
write!(f, "field {} cannot be empty or all whitespace", field)
}
}
}
}
impl PartialEq for OpenProtocolError<'_> {
fn eq(&self, other: &Self) -> bool {
match self {
OpenProtocolError::JsonError(err1) => match other {
OpenProtocolError::JsonError(err2) => {
format!("{:?}", err1) == format!("{:?}", err2)
}
_ => false,
},
_ => *self == *other,
}
}
}
impl Eq for OpenProtocolError<'_> {}