1//! Types for the `org.matrix.msc3489.beacon` event, the unstable version of
2//! `m.beacon` ([MSC3489]).
3//!
4//! [MSC3489]: https://github.com/matrix-org/matrix-spec-proposals/pull/3489
56use ruma_common::{MilliSecondsSinceUnixEpoch, OwnedEventId};
7use ruma_events::{location::LocationContent, relation::Reference};
8use ruma_macros::EventContent;
9use serde::{Deserialize, Serialize};
1011/// The content of a beacon.
12#[derive(Clone, Debug, Serialize, Deserialize, EventContent)]
13#[cfg_attr(not(ruma_unstable_exhaustive_types), non_exhaustive)]
14#[ruma_event(type = "org.matrix.msc3672.beacon", alias = "m.beacon", kind = MessageLike)]
15pub struct BeaconEventContent {
16/// The beacon_info event id this relates to.
17#[serde(rename = "m.relates_to")]
18pub relates_to: Reference,
1920/// The location of the beacon.
21#[serde(rename = "org.matrix.msc3488.location")]
22pub location: LocationContent,
2324/// The timestamp of the event.
25#[serde(rename = "org.matrix.msc3488.ts")]
26pub ts: MilliSecondsSinceUnixEpoch,
27}
2829impl BeaconEventContent {
30/// Creates a new `BeaconEventContent` with the given beacon_info event id, geo uri and
31 /// optional ts. If ts is None, the current time will be used.
32pub fn new(
33 beacon_info_event_id: OwnedEventId,
34 geo_uri: String,
35 ts: Option<MilliSecondsSinceUnixEpoch>,
36 ) -> Self {
37Self {
38 relates_to: Reference::new(beacon_info_event_id),
39 location: LocationContent::new(geo_uri),
40 ts: ts.unwrap_or_else(MilliSecondsSinceUnixEpoch::now),
41 }
42 }
43}