You've already forked AstralRinth
forked from didirus/AstralRinth
* search patch for accurate loader/gv filtering * backup * basic search test * finished test * incomplete commit; backing up * Working multipat reroute backup * working rough draft v3 * most tests passing * works * search v2 conversion * added some tags.rs v2 conversions * Worked through warnings, unwraps, prints * refactors * new search test * version files changes fixes * redesign to revs * removed old caches * removed games * fmt clippy * merge conflicts * fmt, prepare * moved v2 routes over to v3 * fixes; tests passing * project type changes * moved files over * fmt, clippy, prepare, etc * loaders to loader_fields, added tests * fmt, clippy, prepare * fixed sorting bug * reversed back- wrong order for consistency * fmt; clippy; prepare --------- Co-authored-by: Jai A <jaiagr+gpg@pm.me>
60 lines
1.6 KiB
Rust
60 lines
1.6 KiB
Rust
use std::sync::Arc;
|
|
|
|
use crate::database::redis::RedisPool;
|
|
use crate::file_hosting::FileHost;
|
|
use crate::models::ids::{ThreadMessageId, VersionId};
|
|
use crate::models::reports::ReportId;
|
|
use crate::queue::session::AuthQueue;
|
|
use crate::routes::{v3, ApiError};
|
|
use actix_web::{post, web, HttpRequest, HttpResponse};
|
|
use serde::{Deserialize, Serialize};
|
|
use sqlx::PgPool;
|
|
|
|
pub fn config(cfg: &mut web::ServiceConfig) {
|
|
cfg.service(images_add);
|
|
}
|
|
|
|
#[derive(Serialize, Deserialize)]
|
|
pub struct ImageUpload {
|
|
pub ext: String,
|
|
|
|
// Context must be an allowed context
|
|
// currently: project, version, thread_message, report
|
|
pub context: String,
|
|
|
|
// Optional context id to associate with
|
|
pub project_id: Option<String>, // allow slug or id
|
|
pub version_id: Option<VersionId>,
|
|
pub thread_message_id: Option<ThreadMessageId>,
|
|
pub report_id: Option<ReportId>,
|
|
}
|
|
|
|
#[post("image")]
|
|
pub async fn images_add(
|
|
req: HttpRequest,
|
|
web::Query(data): web::Query<ImageUpload>,
|
|
file_host: web::Data<Arc<dyn FileHost + Send + Sync>>,
|
|
payload: web::Payload,
|
|
pool: web::Data<PgPool>,
|
|
redis: web::Data<RedisPool>,
|
|
session_queue: web::Data<AuthQueue>,
|
|
) -> Result<HttpResponse, ApiError> {
|
|
v3::images::images_add(
|
|
req,
|
|
web::Query(v3::images::ImageUpload {
|
|
ext: data.ext,
|
|
context: data.context,
|
|
project_id: data.project_id,
|
|
version_id: data.version_id,
|
|
thread_message_id: data.thread_message_id,
|
|
report_id: data.report_id,
|
|
}),
|
|
file_host,
|
|
payload,
|
|
pool,
|
|
redis,
|
|
session_queue,
|
|
)
|
|
.await
|
|
}
|