Can retrieve room media
This commit is contained in:
@@ -1,17 +1,22 @@
|
||||
use crate::controllers::HttpResult;
|
||||
use crate::controllers::matrix::matrix_media_controller;
|
||||
use crate::controllers::matrix::matrix_media_controller::MediaQuery;
|
||||
use crate::controllers::matrix::matrix_room_controller::RoomIdInPath;
|
||||
use crate::extractors::matrix_client_extractor::MatrixClientExtractor;
|
||||
use actix_web::{HttpResponse, web};
|
||||
use actix_web::dev::Payload;
|
||||
use actix_web::{FromRequest, HttpRequest, HttpResponse, web};
|
||||
use futures_util::{StreamExt, stream};
|
||||
use matrix_sdk::Room;
|
||||
use matrix_sdk::deserialized_responses::{TimelineEvent, TimelineEventKind};
|
||||
use matrix_sdk::media::MediaEventContent;
|
||||
use matrix_sdk::room::MessagesOptions;
|
||||
use matrix_sdk::room::edit::EditedContent;
|
||||
use matrix_sdk::ruma::events::reaction::ReactionEventContent;
|
||||
use matrix_sdk::ruma::events::relation::Annotation;
|
||||
use matrix_sdk::ruma::events::room::message::{
|
||||
RoomMessageEventContent, RoomMessageEventContentWithoutRelation,
|
||||
MessageType, RoomMessageEvent, RoomMessageEventContent, RoomMessageEventContentWithoutRelation,
|
||||
};
|
||||
use matrix_sdk::ruma::events::{AnyMessageLikeEvent, AnyTimelineEvent};
|
||||
use matrix_sdk::ruma::{MilliSecondsSinceUnixEpoch, OwnedEventId, OwnedUserId, RoomId, UInt};
|
||||
use serde::{Deserialize, Serialize};
|
||||
use serde_json::value::RawValue;
|
||||
@@ -162,6 +167,67 @@ pub async fn set_text_content(
|
||||
})
|
||||
}
|
||||
|
||||
pub async fn event_file(
|
||||
req: HttpRequest,
|
||||
client: MatrixClientExtractor,
|
||||
path: web::Path<RoomIdInPath>,
|
||||
event_path: web::Path<EventIdInPath>,
|
||||
) -> HttpResult {
|
||||
let query = web::Query::<MediaQuery>::from_request(&req, &mut Payload::None).await?;
|
||||
|
||||
let Some(room) = client.client.client.get_room(&path.room_id) else {
|
||||
return Ok(HttpResponse::NotFound().json("Room not found!"));
|
||||
};
|
||||
|
||||
let event = match room.load_or_fetch_event(&event_path.event_id, None).await {
|
||||
Ok(event) => event,
|
||||
Err(e) => {
|
||||
log::error!("Failed to load event information! {e}");
|
||||
return Ok(HttpResponse::InternalServerError()
|
||||
.json(format!("Failed to load event information! {e}")));
|
||||
}
|
||||
};
|
||||
|
||||
let event = match event.kind {
|
||||
TimelineEventKind::Decrypted(dec) => dec.event.deserialize()?,
|
||||
TimelineEventKind::UnableToDecrypt { event, .. }
|
||||
| TimelineEventKind::PlainText { event } => event
|
||||
.deserialize()?
|
||||
.into_full_event(room.room_id().to_owned()),
|
||||
};
|
||||
|
||||
let AnyTimelineEvent::MessageLike(message) = event else {
|
||||
return Ok(HttpResponse::BadRequest().json("Event is not message like!"));
|
||||
};
|
||||
|
||||
let AnyMessageLikeEvent::RoomMessage(message) = message else {
|
||||
return Ok(HttpResponse::BadRequest().json("Event is not a room message!"));
|
||||
};
|
||||
|
||||
let RoomMessageEvent::Original(message) = message else {
|
||||
return Ok(HttpResponse::BadRequest().json("Event has been redacted!"));
|
||||
};
|
||||
|
||||
let (source, thumb_source) = match message.content.msgtype {
|
||||
MessageType::Audio(c) => (c.source(), c.thumbnail_source()),
|
||||
MessageType::File(c) => (c.source(), c.thumbnail_source()),
|
||||
MessageType::Image(c) => (c.source(), c.thumbnail_source()),
|
||||
MessageType::Location(c) => (c.source(), c.thumbnail_source()),
|
||||
MessageType::Video(c) => (c.source(), c.thumbnail_source()),
|
||||
_ => (None, None),
|
||||
};
|
||||
|
||||
println!("{source:#?} {thumb_source:#?}");
|
||||
|
||||
let source = match (query.thumbnail, source, thumb_source) {
|
||||
(false, Some(s), _) => s,
|
||||
(true, _, Some(s)) => s,
|
||||
_ => return Ok(HttpResponse::NotFound().json("Requested file not available!")),
|
||||
};
|
||||
|
||||
matrix_media_controller::serve_media(req, source, false).await
|
||||
}
|
||||
|
||||
#[derive(Deserialize)]
|
||||
struct EventReactionBody {
|
||||
key: String,
|
||||
|
||||
Reference in New Issue
Block a user