shrupl/src/sharry/file.rs

74 lines
1.8 KiB
Rust
Raw Normal View History

2025-05-24 00:48:59 +00:00
use std::{
ffi::OsStr,
fs,
path::{Path, PathBuf},
};
use log::debug;
use ureq::http::StatusCode;
use super::{
alias::{Alias, SharryAlias},
share::Share,
};
#[derive(Debug)]
pub struct File<'t> {
alias: &'t Alias,
path: PathBuf,
patch_uri: String,
}
impl<'t> File<'t> {
pub fn create(
http: &ureq::Agent,
share: &'t Share,
path: impl AsRef<OsStr> + AsRef<Path>,
) -> Result<Self, ureq::Error> {
let filepath = PathBuf::from(&path);
let endpoint = share
.alias
.get_endpoint(format!("alias/upload/{}/files/tus", share.id));
let filename = filepath
.file_name()
.and_then(OsStr::to_str)
.unwrap_or("file.bin");
let res = http
.post(endpoint)
.sharry_header(share.alias)
.header("Sharry-File-Name", filename)
.header("Upload-Length", fs::metadata(&filepath)?.len())
.send_empty()?;
if res.status() != StatusCode::CREATED {
return Err(ureq::Error::Other("unexpected response status".into()));
}
let location = res
.headers()
.get("Location")
.ok_or_else(|| ureq::Error::Other("Location header not found".into()))?
.to_str()
.map_err(|_| ureq::Error::Other("Location header invalid".into()))?;
debug!("location: {}", location);
// let start = 10;
// let count = 10;
// let mut f = File::open(path)?;
// f.seek(SeekFrom::Start(0));
// let mut buf = vec![0; count];
// f.read_exact(&mut buf)?;
Ok(Self {
alias: share.alias,
path: filepath,
patch_uri: location.into(),
})
}
}