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) } }