1use crate::CodecError;
4use gbp_core::{ErrorClass, errors::ErrorSpec};
5use serde::{Deserialize, Serialize};
6use serde_bytes::ByteBuf;
7
8#[derive(Clone, Debug, Serialize, Deserialize)]
14pub struct ErrorObject {
15 pub code: u16,
17 pub class: u8,
19 pub retryable: bool,
21 pub fatal: bool,
23 pub reason: String,
25 #[serde(rename = "det")]
27 pub details_cbor: ByteBuf,
28}
29
30impl ErrorObject {
31 pub fn from_spec(spec: ErrorSpec, reason: impl Into<String>) -> Self {
33 Self {
34 code: spec.code,
35 class: spec.class as u8,
36 retryable: spec.retryable,
37 fatal: spec.fatal,
38 reason: reason.into(),
39 details_cbor: ByteBuf::new(),
40 }
41 }
42
43 pub fn new(
46 code: u16,
47 class: ErrorClass,
48 retryable: bool,
49 fatal: bool,
50 reason: impl Into<String>,
51 ) -> Self {
52 Self {
53 code,
54 class: class as u8,
55 retryable,
56 fatal,
57 reason: reason.into(),
58 details_cbor: ByteBuf::new(),
59 }
60 }
61
62 pub fn to_cbor(&self) -> Vec<u8> {
64 let mut buf = Vec::new();
65 ciborium::into_writer(self, &mut buf).expect("cbor encode");
66 buf
67 }
68
69 pub fn from_cbor(data: &[u8]) -> Result<Self, CodecError> {
71 ciborium::from_reader(data).map_err(|e| CodecError::Decode(e.to_string()))
72 }
73}