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
use serde::{Deserialize, Serialize};

use crate::{activation_intent::NandoResultSerializable, ecb_id::EcbId, epic_control::TaskStatus};

#[derive(Serialize, Deserialize)]
#[serde(remote = "TaskStatus")]
pub enum TaskStatusDef {
    Pending,
    PendingUnresolvedDependencies,
    InProgress,
    Success,
    Failure,
}

#[derive(Clone, Serialize, Deserialize)]
pub struct GetEpicStatusRequest {
    pub ecb_id: EcbId,
}

#[derive(Clone, Serialize, Deserialize, Debug)]
pub struct EpicStatus {
    #[serde(with = "TaskStatusDef")]
    pub status: TaskStatus,
    pub result: Option<NandoResultSerializable>,
    // TODO maybe we should also include the spawned ecbs that correspond to subgraphs that are yet
    // to complete?
}

#[derive(Clone, Serialize, Deserialize, Debug)]
pub enum EpicStatusResponse {
    NotFound(String),
    Status(EpicStatus),
}

#[derive(Clone, Serialize, Deserialize)]
pub struct AwaitEpicResultRequest {
    pub ecb_id: EcbId,
}