alhp_api packages should be working

This commit is contained in:
2025-03-24 21:39:02 +01:00
parent c6f08d3365
commit 681b3a96b7
4 changed files with 90 additions and 30 deletions

View File

@@ -5,4 +5,4 @@ edition = "2024"
[dependencies] [dependencies]
alhp_api = {path = "crates/alhp_api"} alhp_api = {path = "crates/alhp_api"}
alpm = "4.0.2"

View File

@@ -8,3 +8,4 @@ authors = ["mpuchstein"]
serde = { version = "1.0.219", features = ["derive"] } serde = { version = "1.0.219", features = ["derive"] }
serde_json = "1.0.140" serde_json = "1.0.140"
reqwest = { version = "0.12.15" , features = ["blocking"] } reqwest = { version = "0.12.15" , features = ["blocking"] }
log = "0.4.27"

View File

@@ -1,6 +1,13 @@
use std::fmt; use log::{error, info};
use serde::{Serialize, Deserialize}; use reqwest::StatusCode;
use reqwest::blocking::Client; use reqwest::blocking::Client;
use serde::{Deserialize, Serialize};
use std::error::Error;
use std::fmt;
const API_BASE_URL: &str = "https://api.alhp.dev";
const API_PACKAGES_EXT: &str = "/packages?";
const API_GENERAL_EXT: &str = "/stats?";
#[derive(Debug, Clone, Copy, Serialize, Deserialize, Eq, PartialEq)] #[derive(Debug, Clone, Copy, Serialize, Deserialize, Eq, PartialEq)]
#[serde(rename_all = "lowercase")] #[serde(rename_all = "lowercase")]
@@ -18,7 +25,21 @@ pub enum PackageStatus{
impl fmt::Display for PackageStatus { impl fmt::Display for PackageStatus {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{}", serde_json::to_string(self).unwrap().trim_matches('"')) write!(
f,
"{}",
match self {
PackageStatus::Latest => "latest",
PackageStatus::Failed => "failed",
PackageStatus::Built => "build",
PackageStatus::Skipped => "skipped",
PackageStatus::Delayed => "delayed",
PackageStatus::Building => "building",
PackageStatus::Signing => "signing",
PackageStatus::Unknown => "unknown",
PackageStatus::Queued => "queued",
}
)
} }
} }
@@ -28,11 +49,13 @@ pub struct Package {
repo: String, repo: String,
split_packages: Vec<String>, split_packages: Vec<String>,
status: PackageStatus, status: PackageStatus,
skip_reason: Option<String>,
lto: String, lto: String,
debug_symbols: String, debug_symbols: String,
arch_version: String, arch_version: String,
repo_version: String, repo_version: String,
build_date: String, build_date: Option<String>,
peak_mem: Option<String>,
} }
#[derive(Debug, Clone, Serialize, Deserialize)] #[derive(Debug, Clone, Serialize, Deserialize)]
@@ -40,7 +63,7 @@ pub struct PackageResponse {
pub total: usize, pub total: usize,
pub offset: usize, pub offset: usize,
pub limit: usize, pub limit: usize,
pub packages: Vec<Package> pub packages: Vec<Package>,
} }
#[derive(Debug, Serialize, Default)] #[derive(Debug, Serialize, Default)]
pub struct PackageRequest { pub struct PackageRequest {
@@ -71,13 +94,51 @@ impl PackageRequest {
params.push(format!("limit={}", self.limit)); params.push(format!("limit={}", self.limit));
params.join("&") params.join("&")
} }
pub fn response(&self) -> Result<PackageResponse, reqwest::Error> { pub fn response(&self) -> Result<PackageResponse, Box<dyn Error>> {
let query_url = format!(
"{}{}{}",
API_BASE_URL,
API_PACKAGES_EXT,
self.query_string()
);
println!("{}", query_url);
let client = Client::new(); let client = Client::new();
let query_string = self.query_string(); info!("Fetching URL: {}", query_url);
let url = format!("https://api.alhp.dev/packages?{}", query_string); let response = client.get(query_url).send()?;
println!("{}", url); match response.status() {
let response = client.get(url).send()?.text()?; StatusCode::OK => {
let response: PackageResponse = serde_json::from_str(&response).unwrap(); let response = response.text()?;
Ok(response) println!("{}", response);
match serde_json::from_str(&response) {
Ok(json) => Ok(json),
Err(e) => {
error!("Failed to deserialize JSON: {}", e);
error!("Response body: {}", response);
Err(Box::new(e))
}
}
}
StatusCode::NOT_FOUND => {
info!("No packages found");
Ok(PackageResponse{
total: 0,
offset: 0,
limit: 0,
packages: vec![],
})
}
StatusCode::INTERNAL_SERVER_ERROR => {
panic!("Internal Server Error");
}
_ => {
let query_url = format!(
"{}{}{}",
API_BASE_URL,
API_PACKAGES_EXT,
self.query_string()
);
panic!("Unexpected server response: {:?} for query url: {}", response, query_url);
}
}
} }
} }

View File

@@ -1,31 +1,29 @@
use alhp_api; use alhp_api;
use std::process::Command; use alpm::{Alpm};
use alhp_api::{PackageRequest, PackageStatus}; use alhp_api::{PackageRequest, PackageStatus};
fn pacman_query_installed_packages() -> Vec<String> { fn query_installed_packages() {
match Command::new("pacman").arg("-Qqn").output() { let alpm = match Alpm::new("/", "/var/lib/pacman"){
Ok(packages) => String::from_utf8_lossy(&packages.stdout) Ok(alpm) => alpm,
.lines() Err(_) => panic!("Error establishing ALPM handle."),
.map(|s| s.to_string()) };
.collect(), let local_db= alpm.localdb();
_ => { let server = local_db.servers();
panic!("pacman query failed"); for s in server {
} println!("{}", s);
} }
} }
fn main() { fn main() {
let installed_packages = pacman_query_installed_packages();
println!("installed packages: {:?}", installed_packages);
let status = vec!();
let pkg = PackageRequest{ let pkg = PackageRequest{
status, status: vec![PackageStatus::Building, PackageStatus::Queued],
pkgbase: Some("go".to_string()), pkgbase: None,
exact: true, exact: true,
repo: Some("extra-x86-64-v3".to_string()), repo: Some("extra-x86-64-v3".to_string()),
offset: 0, offset: 0,
limit: 0, limit: 0,
}; };
let pkg = pkg.response().unwrap(); let pkg = pkg.response().unwrap();
println!("pkg: {:?}", pkg); println!("{:#?}", pkg);
query_installed_packages();
} }