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
use crate::Client;
use crate::resources::common::object::Object;

use crate::resources::common::path::UrlPath;
use crate::resources::core::file::File;
use crate::util::List;

use serde::Serialize;

#[derive(Serialize, Deserialize, Debug, PartialEq)]
pub struct ScheduledQueryRun {
    pub id: String,
    pub object: Object,
    pub created: i64,
    pub data_load_time: i64,
    pub error: Option<SigmaError>,
    pub file: Option<File>,
    pub livemode: bool,
    pub result_available_until: i64,
    pub sql: String,
    pub status: SigmaStatus,
    pub title: String,
}

#[derive(Serialize, Deserialize, Debug, PartialEq)]
pub struct SigmaError {
    pub message: String,
}

#[derive(Serialize, Deserialize, Debug, PartialEq)]
#[serde(rename_all = "snake_case")]
pub enum SigmaStatus {
    Completed,
    Canceled,
    Failed,
    TimedOut,
}

#[derive(Debug, Serialize, PartialEq)]
pub struct ScheduleQueryRunListParam<'a> {
    #[serde(skip_serializing_if = "Option::is_none")]
    pub ending_before: Option<&'a str>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub limit: Option<i64>,
    #[serde(skip_serializing_if = "Option::is_none")]
    pub starting_after: Option<&'a str>,
}

impl ScheduledQueryRun {
    pub fn retrieve(client: &Client, id: &str) -> crate::Result<Self> {
        client.get(
            UrlPath::Sigma,
            vec![id],
            serde_json::Map::new(),
        )
    }

    pub fn list<B: Serialize>(client: &Client, param: B) -> crate::Result<List<Self>> {
        client.get(UrlPath::Sigma, vec![], param)
    }
}