Add Default impls, ignore_all ctors to filter types
This commit is contained in:
		
							parent
							
								
									e30c82d248
								
							
						
					
					
						commit
						e7db530782
					
				| @ -18,7 +18,7 @@ pub enum EventFormat { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /// Filters to be applied to room events
 | /// Filters to be applied to room events
 | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Default, Deserialize, Serialize)] | ||||||
| pub struct RoomEventFilter { | pub struct RoomEventFilter { | ||||||
|     /// A list of event types to exclude.
 |     /// A list of event types to exclude.
 | ||||||
|     ///
 |     ///
 | ||||||
| @ -66,8 +66,18 @@ pub struct RoomEventFilter { | |||||||
|     pub contains_url: Option<bool>, |     pub contains_url: Option<bool>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl RoomEventFilter { | ||||||
|  |     /// A filter that can be used to ignore all room events
 | ||||||
|  |     pub fn ignore_all() -> Self { | ||||||
|  |         Self { | ||||||
|  |             types: Some(vec![]), | ||||||
|  |             ..Default::default() | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /// Filters to be applied to room data
 | /// Filters to be applied to room data
 | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Default, Deserialize, Serialize)] | ||||||
| pub struct RoomFilter { | pub struct RoomFilter { | ||||||
|     /// Include rooms that the user has left in the sync.
 |     /// Include rooms that the user has left in the sync.
 | ||||||
|     ///
 |     ///
 | ||||||
| @ -102,8 +112,18 @@ pub struct RoomFilter { | |||||||
|     pub rooms: Option<Vec<RoomId>>, |     pub rooms: Option<Vec<RoomId>>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl RoomFilter { | ||||||
|  |     /// A filter that can be used to ignore all room events (of any type)
 | ||||||
|  |     pub fn ignore_all() -> Self { | ||||||
|  |         Self { | ||||||
|  |             rooms: Some(vec![]), | ||||||
|  |             ..Default::default() | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /// Filter for not-room data
 | /// Filter for not-room data
 | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Default, Deserialize, Serialize)] | ||||||
| pub struct Filter { | pub struct Filter { | ||||||
|     /// A list of event types to exclude.
 |     /// A list of event types to exclude.
 | ||||||
|     ///
 |     ///
 | ||||||
| @ -134,8 +154,18 @@ pub struct Filter { | |||||||
|     pub not_senders: Vec<UserId>, |     pub not_senders: Vec<UserId>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl Filter { | ||||||
|  |     /// A filter that can be used to ignore all events
 | ||||||
|  |     pub fn ignore_all() -> Self { | ||||||
|  |         Self { | ||||||
|  |             types: Some(vec![]), | ||||||
|  |             ..Default::default() | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /// A filter definition
 | /// A filter definition
 | ||||||
| #[derive(Clone, Debug, Deserialize, Serialize)] | #[derive(Clone, Debug, Default, Deserialize, Serialize)] | ||||||
| pub struct FilterDefinition { | pub struct FilterDefinition { | ||||||
|     /// List of event fields to include.
 |     /// List of event fields to include.
 | ||||||
|     ///
 |     ///
 | ||||||
| @ -148,7 +178,7 @@ pub struct FilterDefinition { | |||||||
|     /// The format to use for events.
 |     /// The format to use for events.
 | ||||||
|     ///
 |     ///
 | ||||||
|     /// 'client' will return the events in a format suitable for clients. 'federation' will return
 |     /// 'client' will return the events in a format suitable for clients. 'federation' will return
 | ||||||
|     /// the raw event as receieved over federation. The default is 'client'.
 |     /// the raw event as received over federation. The default is 'client'.
 | ||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub event_format: Option<EventFormat>, |     pub event_format: Option<EventFormat>, | ||||||
|     /// The user account data that isn't associated with rooms to include.
 |     /// The user account data that isn't associated with rooms to include.
 | ||||||
| @ -161,3 +191,15 @@ pub struct FilterDefinition { | |||||||
|     #[serde(skip_serializing_if = "Option::is_none")] |     #[serde(skip_serializing_if = "Option::is_none")] | ||||||
|     pub presence: Option<Filter>, |     pub presence: Option<Filter>, | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | impl FilterDefinition { | ||||||
|  |     /// A filter that can be used to ignore all events
 | ||||||
|  |     pub fn ignore_all() -> Self { | ||||||
|  |         Self { | ||||||
|  |             account_data: Some(Filter::ignore_all()), | ||||||
|  |             room: Some(RoomFilter::ignore_all()), | ||||||
|  |             presence: Some(Filter::ignore_all()), | ||||||
|  |             ..Default::default() | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user