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
//! Requestor state part of Activity API
use ya_client_model::activity::{
    ActivityState, ActivityUsage, ExeScriptCommandState, ACTIVITY_API_PATH,
};

use crate::{web::WebClient, web::WebInterface, Result};

/// Bindings for Requestor State part of the Activity API.
#[derive(Clone)]
pub struct ActivityRequestorStateApi {
    client: WebClient,
}

impl WebInterface for ActivityRequestorStateApi {
    const API_URL_ENV_VAR: &'static str = crate::activity::ACTIVITY_URL_ENV_VAR;
    const API_SUFFIX: &'static str = ACTIVITY_API_PATH;

    fn from_client(client: WebClient) -> Self {
        ActivityRequestorStateApi { client }
    }
}

impl ActivityRequestorStateApi {
    /// Get running command for a specified Activity.
    pub async fn get_running_command(&self, activity_id: &str) -> Result<ExeScriptCommandState> {
        let uri = url_format!("activity/{activity_id}/command");
        self.client.get(&uri).send().json().await
    }

    /// Get state of specified Activity.
    pub async fn get_state(&self, activity_id: &str) -> Result<ActivityState> {
        let uri = url_format!("activity/{activity_id}/state");
        self.client.get(&uri).send().json().await
    }

    /// Get usage of specified Activity.
    pub async fn get_usage(&self, activity_id: &str) -> Result<ActivityUsage> {
        let uri = url_format!("activity/{activity_id}/usage");
        self.client.get(&uri).send().json().await
    }
}