You've already forked AstralRinth
forked from didirus/AstralRinth
* WIP Switch to Postgres * feat(postgres): more work on porting to postgres, now compiles * feat(docker-compose): Changed the docker-compose.yml file to use postgres. * Update docker, documentation, gh actions... * Remove bson dependency * Remove bson import * feat: move mock filehost to trait rather than cargo feature * feat(postgres): transactions for mod creation, multipart refactor * fix: Add Cargo.lock so that sqlx functions * Update sqlx offline build data * fix: Use SQLX_OFFLINE to force sqlx into offline mode for CI * Default release channels * feat(postgres): refactor database models to fit postgres models * fix: Fix sqlx prepare, fix double allocation in indexing * Add dockerfile (#40) Co-authored-by: Charalampos Fanoulis <charalampos.fanoulis@gmail.com> Co-authored-by: Aeledfyr <aeledfyr@gmail.com> Co-authored-by: redblueflame <contact@redblueflame.com> Co-authored-by: Jai A <jai.a@tuta.io> Co-authored-by: Valentin Ricard <redblueflame1@gmail.Com> Co-authored-by: Charalampos Fanoulis <charalampos.fanoulis@gmail.com>
80 lines
2.4 KiB
Rust
80 lines
2.4 KiB
Rust
use crate::file_hosting::FileHostingError;
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
#[derive(Serialize, Deserialize, Debug, Clone)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct AuthorizationPermissions {
|
|
bucket_id: Option<String>,
|
|
bucket_name: Option<String>,
|
|
capabilities: Vec<String>,
|
|
name_prefix: Option<String>,
|
|
}
|
|
|
|
#[derive(Serialize, Deserialize, Debug, Clone)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct AuthorizationData {
|
|
pub absolute_minimum_part_size: i32,
|
|
pub account_id: String,
|
|
pub allowed: AuthorizationPermissions,
|
|
pub api_url: String,
|
|
pub authorization_token: String,
|
|
pub download_url: String,
|
|
pub recommended_part_size: i32,
|
|
}
|
|
|
|
#[derive(Serialize, Deserialize, Debug, Clone)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct UploadUrlData {
|
|
pub bucket_id: String,
|
|
pub upload_url: String,
|
|
pub authorization_token: String,
|
|
}
|
|
|
|
pub async fn authorize_account(
|
|
key_id: &str,
|
|
application_key: &str,
|
|
) -> Result<AuthorizationData, FileHostingError> {
|
|
let combined_key = format!("{}:{}", key_id, application_key);
|
|
let formatted_key = format!("Basic {}", base64::encode(combined_key));
|
|
|
|
let response = reqwest::Client::new()
|
|
.get("https://api.backblazeb2.com/b2api/v2/b2_authorize_account")
|
|
.header(reqwest::header::CONTENT_TYPE, "application/json")
|
|
.header(reqwest::header::AUTHORIZATION, formatted_key)
|
|
.send()
|
|
.await?;
|
|
|
|
if response.status().is_success() {
|
|
Ok(response.json().await?)
|
|
} else {
|
|
Err(FileHostingError::BackblazeError(response.json().await?))
|
|
}
|
|
}
|
|
|
|
pub async fn get_upload_url(
|
|
authorization_data: &AuthorizationData,
|
|
bucket_id: &str,
|
|
) -> Result<UploadUrlData, FileHostingError> {
|
|
let response = reqwest::Client::new()
|
|
.post(&format!("{}/b2api/v2/b2_get_upload_url", authorization_data.api_url).to_string())
|
|
.header(reqwest::header::CONTENT_TYPE, "application/json")
|
|
.header(
|
|
reqwest::header::AUTHORIZATION,
|
|
&authorization_data.authorization_token,
|
|
)
|
|
.body(
|
|
serde_json::json!({
|
|
"bucketId": bucket_id,
|
|
})
|
|
.to_string(),
|
|
)
|
|
.send()
|
|
.await?;
|
|
|
|
if response.status().is_success() {
|
|
Ok(response.json().await?)
|
|
} else {
|
|
Err(FileHostingError::BackblazeError(response.json().await?))
|
|
}
|
|
}
|