mirror of
https://git.asonix.dog/asonix/pict-rs
synced 2025-01-10 19:45:50 +00:00
Add back range header support for thumbnail on generation
This commit is contained in:
parent
6436f48712
commit
c1b2c7706a
2 changed files with 50 additions and 8 deletions
31
src/main.rs
31
src/main.rs
|
@ -541,13 +541,40 @@ async fn process(
|
||||||
let (details, bytes) =
|
let (details, bytes) =
|
||||||
CancelSafeProcessor::new(thumbnail_path.clone(), Box::pin(process_fut)).await?;
|
CancelSafeProcessor::new(thumbnail_path.clone(), Box::pin(process_fut)).await?;
|
||||||
|
|
||||||
return Ok(srv_response(
|
return match range {
|
||||||
|
Some(range_header) => {
|
||||||
|
if !range_header.is_bytes() {
|
||||||
|
return Err(UploadError::Range);
|
||||||
|
}
|
||||||
|
|
||||||
|
if range_header.is_empty() {
|
||||||
|
Err(UploadError::Range)
|
||||||
|
} else if range_header.len() == 1 {
|
||||||
|
let range = range_header.ranges().next().unwrap();
|
||||||
|
let content_range = range.to_content_range(bytes.len() as u64);
|
||||||
|
let stream = range.chop_bytes(bytes);
|
||||||
|
let mut builder = HttpResponse::PartialContent();
|
||||||
|
builder.insert_header(content_range);
|
||||||
|
|
||||||
|
Ok(srv_response(
|
||||||
|
builder,
|
||||||
|
stream,
|
||||||
|
details.content_type(),
|
||||||
|
7 * DAYS,
|
||||||
|
details.system_time(),
|
||||||
|
))
|
||||||
|
} else {
|
||||||
|
Err(UploadError::Range)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
None => Ok(srv_response(
|
||||||
HttpResponse::Ok(),
|
HttpResponse::Ok(),
|
||||||
once(ready(Ok(bytes) as Result<_, UploadError>)),
|
once(ready(Ok(bytes) as Result<_, UploadError>)),
|
||||||
details.content_type(),
|
details.content_type(),
|
||||||
7 * DAYS,
|
7 * DAYS,
|
||||||
details.system_time(),
|
details.system_time(),
|
||||||
));
|
)),
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
let details = if let Some(details) = details {
|
let details = if let Some(details) = details {
|
||||||
|
|
17
src/range.rs
17
src/range.rs
|
@ -8,7 +8,7 @@ use actix_web::{
|
||||||
web::Bytes,
|
web::Bytes,
|
||||||
FromRequest, HttpRequest,
|
FromRequest, HttpRequest,
|
||||||
};
|
};
|
||||||
use futures_util::stream::LocalBoxStream;
|
use futures_util::stream::{once, LocalBoxStream, Stream};
|
||||||
use std::{future::ready, io};
|
use std::{future::ready, io};
|
||||||
use tokio::io::{AsyncReadExt, AsyncSeekExt};
|
use tokio::io::{AsyncReadExt, AsyncSeekExt};
|
||||||
|
|
||||||
|
@ -43,6 +43,21 @@ impl Range {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) fn chop_bytes(
|
||||||
|
&self,
|
||||||
|
bytes: Bytes,
|
||||||
|
) -> impl Stream<Item = Result<Bytes, UploadError>> + Unpin {
|
||||||
|
match self {
|
||||||
|
Range::RangeStart(start) => once(ready(Ok(bytes.slice(*start as usize..)))),
|
||||||
|
Range::SuffixLength(from_start) => {
|
||||||
|
once(ready(Ok(bytes.slice(..*from_start as usize))))
|
||||||
|
}
|
||||||
|
Range::Segment(start, end) => {
|
||||||
|
once(ready(Ok(bytes.slice(*start as usize..*end as usize))))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub(crate) async fn chop_file(
|
pub(crate) async fn chop_file(
|
||||||
&self,
|
&self,
|
||||||
mut file: tokio::fs::File,
|
mut file: tokio::fs::File,
|
||||||
|
|
Loading…
Reference in a new issue