serve-file-fix
Some checks failed
deploy / deploy (push) Failing after 49s

This commit is contained in:
Untone 2024-10-22 11:38:28 +03:00
parent 1385f64824
commit ca97ecf128
2 changed files with 18 additions and 18 deletions

View File

@ -108,18 +108,20 @@ impl AppState {
// Формируем список файлов без дубликатов по имени файла (без расширения)
for object in objects.iter() {
if let Some(storj_objkey) = &object.key {
let filekey = storj_objkey.split('.')
.chain(std::iter::once("")) // Ensure the chain doesn't break on empty strings
.filter(|s| !s.is_empty()) // Filter out any empty strings
.map(|s| s.split('/')) // Map to Split iterator
.nth(0) // Get the first non-empty split result or default to &""
.and_then(|s| s.last()) // Call last() on the resulting iterator if it exists, otherwise None
.unwrap_or(&"");
if let Some(storj_filepath) = &object.key {
let filepath = match storj_filepath.ends_with("/webp") {
true => &storj_filepath.replace("/webp", ""),
false => storj_filepath,
};
let mut parts = filepath.split('/').collect::<Vec<&str>>(); // Explicit type annotation
let filename = parts.pop().unwrap();
let mut filename_parts = filename.split('.').collect::<Vec<&str>>();
let _ext = filename_parts.pop().unwrap();
let filekey = filename_parts.pop().unwrap();
// Сохраняем список файлов в Redis, используя HSET для каждого файла
let _: () = redis
.hset(PATH_MAPPING_KEY, filekey, storj_objkey)
.hset(PATH_MAPPING_KEY, filekey, storj_filepath)
.await
.expect("Failed to cache file in Redis");
}
@ -164,7 +166,7 @@ impl AppState {
Ok(())
}
/// Получает путь в хранилище из ключа (имени файла) в Redis.
/// Получает путь в Storj из ключа (имени файла) в Redis.
pub async fn get_path(&self, file_key: &str) -> Result<Option<String>, actix_web::Error> {
let mut redis = self.redis.clone();
let new_path: Option<String> = redis

View File

@ -1,6 +1,5 @@
use actix_web::{error::ErrorInternalServerError, HttpResponse, Result};
use mime_guess::MimeGuess;
use log::warn;
use crate::app_state::AppState;
use crate::s3_utils::check_file_exists;
@ -9,21 +8,20 @@ use crate::s3_utils::check_file_exists;
pub async fn serve_file(file_key: &str, state: &AppState) -> Result<HttpResponse, actix_web::Error> {
// Проверяем наличие файла в Storj S3
if !check_file_exists(&state.storj_client, &state.storj_bucket, &file_key).await? {
warn!("{}", file_key);
return Err(ErrorInternalServerError("File not found in Storj"));
return Err(ErrorInternalServerError(format!("File {} not found in Storj", file_key)));
}
let file_path = state.get_path(file_key).await.unwrap().unwrap();
let file_path_in_storj = state.get_path(file_key).await.unwrap().unwrap();
// Получаем объект из Storj S3
let get_object_output = state
.storj_client
.get_object()
.bucket(&state.storj_bucket)
.key(file_path.clone())
.key(file_path_in_storj.clone())
.send()
.await
.map_err(|_| ErrorInternalServerError("Failed to get object from Storj"))?;
.map_err(|_| ErrorInternalServerError(format!("Failed to get {} object from Storj", file_path_in_storj)))?;
let data: aws_sdk_s3::primitives::AggregatedBytes = get_object_output
.body
@ -32,7 +30,7 @@ pub async fn serve_file(file_key: &str, state: &AppState) -> Result<HttpResponse
.map_err(|_| ErrorInternalServerError("Failed to read object body"))?;
let data_bytes = data.into_bytes();
let mime_type = MimeGuess::from_path(&file_path).first_or_octet_stream();
let mime_type = MimeGuess::from_path(&file_path_in_storj).first_or_octet_stream();
Ok(HttpResponse::Ok()
.content_type(mime_type.as_ref())