nexgenomics 0.2.6

The official Rust crate for NexGenomics
Documentation

// src/images.rs

use crate::utils;
use reqwest::{Client,Error};
use reqwest::header::{AUTHORIZATION, HeaderValue};
use chrono::{DateTime,Utc};
use serde::Deserialize;

#[derive(Debug,Deserialize)]
pub struct Image {
    pub id: String,
    pub title: String,
    pub creator: String,
    pub created_at: DateTime<Utc>,
}

async fn inner_get_images() -> Result<Vec<Image>, Error> {
    let auth_token = utils::get_api_auth_token().unwrap();
    let url_stem = utils::get_api_url_stem().unwrap();

    let token = format!("Bearer {}", auth_token);
    let url = format!("{}/api/v0/images",url_stem);
    //println!("{}, {}", token, url);

    let client = Client::new();
    let response = client
        .get(url)
        .header (AUTHORIZATION, HeaderValue::from_str(&token).unwrap())
        .send()
        .await?
        .error_for_status()?;

    let p = response.json::<Vec<Image>>().await?;
    Ok(p)
    
}

#[cfg(feature = "async")]
pub async fn get_images() -> Result<Vec<Image>,Error> {
    inner_get_images().await
}


#[cfg(feature = "blocking")]
pub fn get_images() -> Result<Vec<Image>,Error> {
    let rt = tokio::runtime::Runtime::new()
        .expect("Failed to create Tokio runtime");
    rt.block_on(inner_get_images())
}