You've already forked AstralRinth
forked from didirus/AstralRinth
* typos :help_me: * (part 1/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 2/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 3/?) cut down some pretty major heap allocations here - more Bytes and BytesMuts, less Vec<u8>s also I don't really understand why you need to `to_vec` when you don't really use it again afterwards * (part 4/?) deduplicate error handling in backblaze logic * (part 5/?) fixes, cleanups, refactors, and reformatting * (part 6/?) cleanups and refactors * remove loads of `as_str` in types that already are `Display` * Revert "remove loads of `as_str` in types that already are `Display`" This reverts commit 4f974310cfb167ceba03001d81388db4f0fbb509. * reformat and move routes util to the util module * use streams * Run prepare + formatting issues Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com>
46 lines
1.3 KiB
Rust
46 lines
1.3 KiB
Rust
use super::authorization::UploadUrlData;
|
|
use crate::file_hosting::FileHostingError;
|
|
use bytes::Bytes;
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
#[derive(Serialize, Deserialize, Debug, Clone)]
|
|
#[serde(rename_all = "camelCase")]
|
|
pub struct UploadFileData {
|
|
pub file_id: String,
|
|
pub file_name: String,
|
|
pub account_id: String,
|
|
pub bucket_id: String,
|
|
pub content_length: u32,
|
|
pub content_sha1: String,
|
|
pub content_md5: Option<String>,
|
|
pub content_type: String,
|
|
pub upload_timestamp: u64,
|
|
}
|
|
|
|
//Content Types found here: https://www.backblaze.com/b2/docs/content-types.html
|
|
pub async fn upload_file(
|
|
url_data: &UploadUrlData,
|
|
content_type: &str,
|
|
file_name: &str,
|
|
file_bytes: Bytes,
|
|
) -> Result<UploadFileData, FileHostingError> {
|
|
let response = reqwest::Client::new()
|
|
.post(&url_data.upload_url)
|
|
.header(
|
|
reqwest::header::AUTHORIZATION,
|
|
&url_data.authorization_token,
|
|
)
|
|
.header("X-Bz-File-Name", file_name)
|
|
.header(reqwest::header::CONTENT_TYPE, content_type)
|
|
.header(reqwest::header::CONTENT_LENGTH, file_bytes.len())
|
|
.header(
|
|
"X-Bz-Content-Sha1",
|
|
sha1::Sha1::from(&file_bytes).hexdigest(),
|
|
)
|
|
.body(file_bytes)
|
|
.send()
|
|
.await?;
|
|
|
|
super::process_response(response).await
|
|
}
|