events: Add as_original methods to possiby-redacted event enums
This commit is contained in:
parent
f0177dc429
commit
548232ef5a
@ -497,9 +497,25 @@ impl_possibly_redacted_event!(MessageLikeEvent(MessageLikeEventContent, MessageL
|
|||||||
Self::Redacted(ev) => &ev.room_id,
|
Self::Redacted(ev) => &ev.room_id,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the inner `OriginalMessageLikeEvent` if this is an unredacted event.
|
||||||
|
pub fn as_original(&self) -> Option<&OriginalMessageLikeEvent<C>> {
|
||||||
|
match self {
|
||||||
|
Self::Original(v) => Some(v),
|
||||||
|
_ => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
impl_possibly_redacted_event!(SyncMessageLikeEvent(MessageLikeEventContent, MessageLikeEventType) {
|
impl_possibly_redacted_event!(SyncMessageLikeEvent(MessageLikeEventContent, MessageLikeEventType) {
|
||||||
|
/// Get the inner `OriginalSyncMessageLikeEvent` if this is an unredacted event.
|
||||||
|
pub fn as_original(&self) -> Option<&OriginalSyncMessageLikeEvent<C>> {
|
||||||
|
match self {
|
||||||
|
Self::Original(v) => Some(v),
|
||||||
|
_ => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Convert this sync event into a full event (one with a `room_id` field).
|
/// Convert this sync event into a full event (one with a `room_id` field).
|
||||||
pub fn into_full_event(self, room_id: Box<RoomId>) -> MessageLikeEvent<C> {
|
pub fn into_full_event(self, room_id: Box<RoomId>) -> MessageLikeEvent<C> {
|
||||||
match self {
|
match self {
|
||||||
@ -525,6 +541,14 @@ impl_possibly_redacted_event!(StateEvent(StateEventContent, StateEventType) {
|
|||||||
Self::Redacted(ev) => &ev.state_key,
|
Self::Redacted(ev) => &ev.state_key,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the inner `OriginalStateEvent` if this is an unredacted event.
|
||||||
|
pub fn as_original(&self) -> Option<&OriginalStateEvent<C>> {
|
||||||
|
match self {
|
||||||
|
Self::Original(v) => Some(v),
|
||||||
|
_ => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
impl_possibly_redacted_event!(SyncStateEvent(StateEventContent, StateEventType) {
|
impl_possibly_redacted_event!(SyncStateEvent(StateEventContent, StateEventType) {
|
||||||
@ -536,6 +560,14 @@ impl_possibly_redacted_event!(SyncStateEvent(StateEventContent, StateEventType)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the inner `OriginalSyncStateEvent` if this is an unredacted event.
|
||||||
|
pub fn as_original(&self) -> Option<&OriginalSyncStateEvent<C>> {
|
||||||
|
match self {
|
||||||
|
Self::Original(v) => Some(v),
|
||||||
|
_ => None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Convert this sync event into a full event (one with a `room_id` field).
|
/// Convert this sync event into a full event (one with a `room_id` field).
|
||||||
pub fn into_full_event(self, room_id: Box<RoomId>) -> StateEvent<C> {
|
pub fn into_full_event(self, room_id: Box<RoomId>) -> StateEvent<C> {
|
||||||
match self {
|
match self {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user