rename config.rs to account_data.rs, refactor, add some missing checks
Signed-off-by: strawberry <strawberry@puppygock.gay>
This commit is contained in:
parent
ef8392cbbe
commit
80f9536d21
2 changed files with 54 additions and 32 deletions
|
@ -1,18 +1,20 @@
|
||||||
use axum::extract::State;
|
use axum::extract::State;
|
||||||
use conduit::err;
|
use conduit::{err, Err};
|
||||||
use ruma::{
|
use ruma::{
|
||||||
api::client::{
|
api::client::config::{
|
||||||
config::{get_global_account_data, get_room_account_data, set_global_account_data, set_room_account_data},
|
get_global_account_data, get_room_account_data, set_global_account_data, set_room_account_data,
|
||||||
error::ErrorKind,
|
},
|
||||||
|
events::{
|
||||||
|
AnyGlobalAccountDataEventContent, AnyRoomAccountDataEventContent, GlobalAccountDataEventType,
|
||||||
|
RoomAccountDataEventType,
|
||||||
},
|
},
|
||||||
events::{AnyGlobalAccountDataEventContent, AnyRoomAccountDataEventContent},
|
|
||||||
serde::Raw,
|
serde::Raw,
|
||||||
OwnedUserId, RoomId,
|
RoomId, UserId,
|
||||||
};
|
};
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
use serde_json::{json, value::RawValue as RawJsonValue};
|
use serde_json::{json, value::RawValue as RawJsonValue};
|
||||||
|
|
||||||
use crate::{service::Services, Error, Result, Ruma};
|
use crate::{service::Services, Result, Ruma};
|
||||||
|
|
||||||
/// # `PUT /_matrix/client/r0/user/{userId}/account_data/{type}`
|
/// # `PUT /_matrix/client/r0/user/{userId}/account_data/{type}`
|
||||||
///
|
///
|
||||||
|
@ -20,14 +22,13 @@ use crate::{service::Services, Error, Result, Ruma};
|
||||||
pub(crate) async fn set_global_account_data_route(
|
pub(crate) async fn set_global_account_data_route(
|
||||||
State(services): State<crate::State>, body: Ruma<set_global_account_data::v3::Request>,
|
State(services): State<crate::State>, body: Ruma<set_global_account_data::v3::Request>,
|
||||||
) -> Result<set_global_account_data::v3::Response> {
|
) -> Result<set_global_account_data::v3::Response> {
|
||||||
set_account_data(
|
let sender_user = body.sender_user();
|
||||||
&services,
|
|
||||||
None,
|
if sender_user != body.user_id && body.appservice_info.is_none() {
|
||||||
body.sender_user.as_ref(),
|
return Err!(Request(Forbidden("You cannot set account data for other users.")));
|
||||||
&body.event_type.to_string(),
|
}
|
||||||
body.data.json(),
|
|
||||||
)
|
set_account_data(&services, None, &body.user_id, &body.event_type.to_string(), body.data.json()).await?;
|
||||||
.await?;
|
|
||||||
|
|
||||||
Ok(set_global_account_data::v3::Response {})
|
Ok(set_global_account_data::v3::Response {})
|
||||||
}
|
}
|
||||||
|
@ -38,10 +39,16 @@ pub(crate) async fn set_global_account_data_route(
|
||||||
pub(crate) async fn set_room_account_data_route(
|
pub(crate) async fn set_room_account_data_route(
|
||||||
State(services): State<crate::State>, body: Ruma<set_room_account_data::v3::Request>,
|
State(services): State<crate::State>, body: Ruma<set_room_account_data::v3::Request>,
|
||||||
) -> Result<set_room_account_data::v3::Response> {
|
) -> Result<set_room_account_data::v3::Response> {
|
||||||
|
let sender_user = body.sender_user();
|
||||||
|
|
||||||
|
if sender_user != body.user_id && body.appservice_info.is_none() {
|
||||||
|
return Err!(Request(Forbidden("You cannot set account data for other users.")));
|
||||||
|
}
|
||||||
|
|
||||||
set_account_data(
|
set_account_data(
|
||||||
&services,
|
&services,
|
||||||
Some(&body.room_id),
|
Some(&body.room_id),
|
||||||
body.sender_user.as_ref(),
|
&body.user_id,
|
||||||
&body.event_type.to_string(),
|
&body.event_type.to_string(),
|
||||||
body.data.json(),
|
body.data.json(),
|
||||||
)
|
)
|
||||||
|
@ -56,11 +63,15 @@ pub(crate) async fn set_room_account_data_route(
|
||||||
pub(crate) async fn get_global_account_data_route(
|
pub(crate) async fn get_global_account_data_route(
|
||||||
State(services): State<crate::State>, body: Ruma<get_global_account_data::v3::Request>,
|
State(services): State<crate::State>, body: Ruma<get_global_account_data::v3::Request>,
|
||||||
) -> Result<get_global_account_data::v3::Response> {
|
) -> Result<get_global_account_data::v3::Response> {
|
||||||
let sender_user = body.sender_user.as_ref().expect("user is authenticated");
|
let sender_user = body.sender_user();
|
||||||
|
|
||||||
|
if sender_user != body.user_id && body.appservice_info.is_none() {
|
||||||
|
return Err!(Request(Forbidden("You cannot get account data of other users.")));
|
||||||
|
}
|
||||||
|
|
||||||
let account_data: ExtractGlobalEventContent = services
|
let account_data: ExtractGlobalEventContent = services
|
||||||
.account_data
|
.account_data
|
||||||
.get_global(sender_user, body.event_type.clone())
|
.get_global(&body.user_id, body.event_type.clone())
|
||||||
.await
|
.await
|
||||||
.map_err(|_| err!(Request(NotFound("Data not found."))))?;
|
.map_err(|_| err!(Request(NotFound("Data not found."))))?;
|
||||||
|
|
||||||
|
@ -75,11 +86,15 @@ pub(crate) async fn get_global_account_data_route(
|
||||||
pub(crate) async fn get_room_account_data_route(
|
pub(crate) async fn get_room_account_data_route(
|
||||||
State(services): State<crate::State>, body: Ruma<get_room_account_data::v3::Request>,
|
State(services): State<crate::State>, body: Ruma<get_room_account_data::v3::Request>,
|
||||||
) -> Result<get_room_account_data::v3::Response> {
|
) -> Result<get_room_account_data::v3::Response> {
|
||||||
let sender_user = body.sender_user.as_ref().expect("user is authenticated");
|
let sender_user = body.sender_user();
|
||||||
|
|
||||||
|
if sender_user != body.user_id && body.appservice_info.is_none() {
|
||||||
|
return Err!(Request(Forbidden("You cannot get account data of other users.")));
|
||||||
|
}
|
||||||
|
|
||||||
let account_data: ExtractRoomEventContent = services
|
let account_data: ExtractRoomEventContent = services
|
||||||
.account_data
|
.account_data
|
||||||
.get_room(&body.room_id, sender_user, body.event_type.clone())
|
.get_room(&body.room_id, &body.user_id, body.event_type.clone())
|
||||||
.await
|
.await
|
||||||
.map_err(|_| err!(Request(NotFound("Data not found."))))?;
|
.map_err(|_| err!(Request(NotFound("Data not found."))))?;
|
||||||
|
|
||||||
|
@ -89,28 +104,35 @@ pub(crate) async fn get_room_account_data_route(
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn set_account_data(
|
async fn set_account_data(
|
||||||
services: &Services, room_id: Option<&RoomId>, sender_user: Option<&OwnedUserId>, event_type: &str,
|
services: &Services, room_id: Option<&RoomId>, sender_user: &UserId, event_type_s: &str, data: &RawJsonValue,
|
||||||
data: &RawJsonValue,
|
) -> Result {
|
||||||
) -> Result<()> {
|
if event_type_s == RoomAccountDataEventType::FullyRead.to_cow_str() {
|
||||||
let sender_user = sender_user.as_ref().expect("user is authenticated");
|
return Err!(Request(BadJson(
|
||||||
|
"This endpoint cannot be used for marking a room as fully read (setting m.fully_read)"
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
|
if event_type_s == GlobalAccountDataEventType::PushRules.to_cow_str() {
|
||||||
|
return Err!(Request(BadJson(
|
||||||
|
"This endpoint cannot be used for setting/configuring push rules."
|
||||||
|
)));
|
||||||
|
}
|
||||||
|
|
||||||
let data: serde_json::Value =
|
let data: serde_json::Value =
|
||||||
serde_json::from_str(data.get()).map_err(|_| Error::BadRequest(ErrorKind::BadJson, "Data is invalid."))?;
|
serde_json::from_str(data.get()).map_err(|e| err!(Request(BadJson(warn!("Invalid JSON provided: {e}")))))?;
|
||||||
|
|
||||||
services
|
services
|
||||||
.account_data
|
.account_data
|
||||||
.update(
|
.update(
|
||||||
room_id,
|
room_id,
|
||||||
sender_user,
|
sender_user,
|
||||||
event_type.into(),
|
event_type_s.into(),
|
||||||
&json!({
|
&json!({
|
||||||
"type": event_type,
|
"type": event_type_s,
|
||||||
"content": data,
|
"content": data,
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
.await?;
|
.await
|
||||||
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
|
@ -1,9 +1,9 @@
|
||||||
pub(super) mod account;
|
pub(super) mod account;
|
||||||
|
pub(super) mod account_data;
|
||||||
pub(super) mod alias;
|
pub(super) mod alias;
|
||||||
pub(super) mod appservice;
|
pub(super) mod appservice;
|
||||||
pub(super) mod backup;
|
pub(super) mod backup;
|
||||||
pub(super) mod capabilities;
|
pub(super) mod capabilities;
|
||||||
pub(super) mod config;
|
|
||||||
pub(super) mod context;
|
pub(super) mod context;
|
||||||
pub(super) mod device;
|
pub(super) mod device;
|
||||||
pub(super) mod directory;
|
pub(super) mod directory;
|
||||||
|
@ -41,11 +41,11 @@ pub(super) mod well_known;
|
||||||
|
|
||||||
pub use account::full_user_deactivate;
|
pub use account::full_user_deactivate;
|
||||||
pub(super) use account::*;
|
pub(super) use account::*;
|
||||||
|
pub(super) use account_data::*;
|
||||||
pub(super) use alias::*;
|
pub(super) use alias::*;
|
||||||
pub(super) use appservice::*;
|
pub(super) use appservice::*;
|
||||||
pub(super) use backup::*;
|
pub(super) use backup::*;
|
||||||
pub(super) use capabilities::*;
|
pub(super) use capabilities::*;
|
||||||
pub(super) use config::*;
|
|
||||||
pub(super) use context::*;
|
pub(super) use context::*;
|
||||||
pub(super) use device::*;
|
pub(super) use device::*;
|
||||||
pub(super) use directory::*;
|
pub(super) use directory::*;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue