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
use crate::task::Task;
pub enum RunTaskResult {
Finished {
result: String,
},
Failed {
result: String,
},
SerdeErr {
msg: String,
},
None,
}
impl RunTaskResult {
pub fn is_none(&self) -> bool {
if let RunTaskResult::None = self {
return true;
}
false
}
}
macro_rules! handle_serialize_err {
($payload:ident) => {
match serde_json::to_string(&$payload) {
Ok(result) => result,
Err(e) => {
return RunTaskResult::SerdeErr {
msg: format!("{}", e),
}
}
}
};
}
pub trait Job {
type R: serde::Serialize + serde::de::DeserializeOwned;
type E: serde::Serialize + serde::de::DeserializeOwned;
const UUID: &'static str;
const MAX_ATTEMPTS: usize;
fn run(&self) -> Result<Self::R, Self::E>;
fn run_task(&self, task: &Task) -> RunTaskResult {
if task.job_uuid != Self::UUID {
return RunTaskResult::None;
}
match self.run() {
Ok(result) => RunTaskResult::Finished {
result: handle_serialize_err!(result),
},
Err(error) => RunTaskResult::Failed {
result: handle_serialize_err!(error),
},
}
}
}