first working version with ghcr
This commit is contained in:
parent
fe3f0579ad
commit
cefe57b980
75
src/repository/ghcr.rs
Normal file
75
src/repository/ghcr.rs
Normal file
@ -0,0 +1,75 @@
|
||||
use serde::Deserialize;
|
||||
|
||||
use crate::repo;
|
||||
use crate::repository::Error;
|
||||
|
||||
#[derive(Deserialize)]
|
||||
struct Token {
|
||||
token: String,
|
||||
}
|
||||
|
||||
#[derive(Deserialize)]
|
||||
pub struct Ghcr {
|
||||
name: String,
|
||||
tags: Vec<String>,
|
||||
}
|
||||
|
||||
impl Ghcr {
|
||||
/// fetches tag information with a repository name in the form of organization/repository or library/repository in the case of official images from docker
|
||||
pub fn create_repo(repo: &str) -> Result<super::Repo, Error> {
|
||||
let request_token = format!("https://ghcr.io/token?scope=repository:{}:pull", repo);
|
||||
let response = match reqwest::blocking::get(request_token) {
|
||||
Err(e) => return Err(Error::Fetching(format!("reqwest error: {}", e))),
|
||||
Ok(response) => response,
|
||||
};
|
||||
|
||||
let token = match response.json::<Token>() {
|
||||
Err(e) => return Err(Error::Converting(format!("invalid token json: {}", e))),
|
||||
Ok(token) => token.token,
|
||||
};
|
||||
|
||||
let request = format!("https://ghcr.io/v2/{}/tags/list?n=100", repo);
|
||||
let client = reqwest::blocking::Client::new();
|
||||
let response = match client
|
||||
.get(request)
|
||||
.header(reqwest::header::AUTHORIZATION, format!("Bearer {}", token))
|
||||
.send()
|
||||
{
|
||||
// let response = match reqwest::blocking::get(url) {
|
||||
Ok(result) => result,
|
||||
Err(e) => return Err(Error::Fetching(format!("reqwest error: {}", e))),
|
||||
};
|
||||
|
||||
//convert it to json
|
||||
let tags = match response.json::<Self>() {
|
||||
Ok(result) => result,
|
||||
Err(e) => return Err(Error::Converting(format!("invalid json: {}", e))),
|
||||
};
|
||||
|
||||
if tags.tags.is_empty() {
|
||||
return Err(Error::NoTagsFound);
|
||||
}
|
||||
|
||||
Ok(super::Repo {
|
||||
tags: tags
|
||||
.tags
|
||||
.iter()
|
||||
.map(|t| super::Tag {
|
||||
name: t.clone(),
|
||||
details: vec![],
|
||||
last_updated: None,
|
||||
})
|
||||
.collect(),
|
||||
next_page: None,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::Ghcr;
|
||||
#[test]
|
||||
fn test_ghcr() {
|
||||
Ghcr::create_repo("ghcr.io/linuxserver/beets").unwrap();
|
||||
}
|
||||
}
|
@ -1,4 +1,5 @@
|
||||
mod dockerhub;
|
||||
mod ghcr;
|
||||
|
||||
use std::fmt;
|
||||
|
||||
@ -99,13 +100,13 @@ impl Repo {
|
||||
};
|
||||
|
||||
//TODO change according to registry
|
||||
// if ®istry == "ghcr.io" {
|
||||
// //
|
||||
// } else {
|
||||
// dockerhub::DockerHub::new(repo)
|
||||
// }
|
||||
if registry.unwrap_or(String::new()) == "ghcr.io" {
|
||||
ghcr::Ghcr::create_repo(&repo)
|
||||
} else {
|
||||
dockerhub::DockerHub::create_repo(&repo)
|
||||
}
|
||||
|
||||
dockerhub::DockerHub::create_repo(&repo)
|
||||
// dockerhub::DockerHub::create_repo(&repo)
|
||||
}
|
||||
|
||||
pub fn with_url(url: &str) -> Result<Self, Error> {
|
||||
|
Loading…
Reference in New Issue
Block a user