mirror of
https://forgejo.ellis.link/continuwuation/continuwuity.git
synced 2025-08-02 21:28:31 +00:00
66 lines
1.7 KiB
Rust
66 lines
1.7 KiB
Rust
use conduwuit::{Err, Event, PduEvent, Result, debug, implement, warn};
|
|
use ruma::{
|
|
RoomId, ServerName,
|
|
api::federation::room::policy::v1::Request as PolicyRequest,
|
|
events::{StateEventType, room::policy::RoomPolicyEventContent},
|
|
};
|
|
|
|
/// Returns Ok if the policy server allows the event
|
|
#[implement(super::Service)]
|
|
#[tracing::instrument(skip_all, level = "debug")]
|
|
pub async fn policyserv_check(&self, pdu: &PduEvent, room_id: &RoomId) -> Result {
|
|
let Ok(policyserver) = self
|
|
.services
|
|
.state_accessor
|
|
.room_state_get_content(room_id, &StateEventType::RoomPolicy, "")
|
|
.await
|
|
.map(|c: RoomPolicyEventContent| c)
|
|
else {
|
|
return Ok(());
|
|
};
|
|
|
|
let via = match policyserver.via {
|
|
| Some(ref via) => ServerName::parse(via)?,
|
|
| None => {
|
|
debug!("No policy server configured for room {room_id}");
|
|
return Ok(());
|
|
},
|
|
};
|
|
let outgoing = self
|
|
.services
|
|
.sending
|
|
.convert_to_outgoing_federation_event(pdu.to_canonical_object())
|
|
.await;
|
|
debug!("Checking pdu {outgoing:?} for spam with policy server {via} for room {room_id}");
|
|
let response = self
|
|
.services
|
|
.sending
|
|
.send_federation_request(via, PolicyRequest {
|
|
event_id: pdu.event_id().to_owned(),
|
|
pdu: Some(outgoing),
|
|
})
|
|
.await;
|
|
let response = match response {
|
|
| Ok(response) => response,
|
|
| Err(e) => {
|
|
warn!(
|
|
via = %via,
|
|
event_id = %pdu.event_id(),
|
|
room_id = %room_id,
|
|
"Failed to contact policy server: {e}"
|
|
);
|
|
return Ok(());
|
|
},
|
|
};
|
|
if response.recommendation == "spam" {
|
|
warn!(
|
|
via = %via,
|
|
event_id = %pdu.event_id(),
|
|
room_id = %room_id,
|
|
"Event was marked as spam by policy server",
|
|
);
|
|
return Err!(Request(Forbidden("Event was marked as spam by policy server")));
|
|
}
|
|
|
|
Ok(())
|
|
}
|