Move common::push::AnyPushRule to client_api::r0::push::PushRule
This commit is contained in:
parent
22f7f28e1b
commit
b79ef0303a
@ -1,6 +1,14 @@
|
|||||||
//! Endpoints for push notifications.
|
//! Endpoints for push notifications.
|
||||||
|
use std::{
|
||||||
|
convert::TryFrom,
|
||||||
|
error::Error,
|
||||||
|
fmt::{self, Display, Formatter},
|
||||||
|
};
|
||||||
|
|
||||||
use ruma_common::push::PusherData;
|
use ruma_common::push::{
|
||||||
|
Action, ConditionalPushRule, ConditionalPushRuleInit, PatternedPushRule, PatternedPushRuleInit,
|
||||||
|
PushCondition, PusherData, SimplePushRule, SimplePushRuleInit,
|
||||||
|
};
|
||||||
use ruma_serde::StringEnum;
|
use ruma_serde::StringEnum;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
@ -17,6 +25,143 @@ pub mod set_pushrule;
|
|||||||
pub mod set_pushrule_actions;
|
pub mod set_pushrule_actions;
|
||||||
pub mod set_pushrule_enabled;
|
pub mod set_pushrule_enabled;
|
||||||
|
|
||||||
|
/// Like `SimplePushRule`, but may represent any kind of push rule
|
||||||
|
/// thanks to `pattern` and `conditions` being optional.
|
||||||
|
///
|
||||||
|
/// To create an instance of this type, use one of its `From` implementations.
|
||||||
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct PushRule {
|
||||||
|
/// The actions to perform when this rule is matched.
|
||||||
|
pub actions: Vec<Action>,
|
||||||
|
|
||||||
|
/// Whether this is a default rule, or has been set explicitly.
|
||||||
|
pub default: bool,
|
||||||
|
|
||||||
|
/// Whether the push rule is enabled or not.
|
||||||
|
pub enabled: bool,
|
||||||
|
|
||||||
|
/// The ID of this rule.
|
||||||
|
pub rule_id: String,
|
||||||
|
|
||||||
|
/// The conditions that must hold true for an event in order for a rule to be applied to an
|
||||||
|
/// event. A rule with no conditions always matches.
|
||||||
|
///
|
||||||
|
/// Only applicable to underride and override rules.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub conditions: Option<Vec<PushCondition>>,
|
||||||
|
|
||||||
|
/// The glob-style pattern to match against. Only applicable to content rules.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub pattern: Option<String>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<SimplePushRule> for PushRule {
|
||||||
|
fn from(push_rule: SimplePushRule) -> Self {
|
||||||
|
let SimplePushRule { actions, default, enabled, rule_id, .. } = push_rule;
|
||||||
|
Self { actions, default, enabled, rule_id, conditions: None, pattern: None }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<PatternedPushRule> for PushRule {
|
||||||
|
fn from(push_rule: PatternedPushRule) -> Self {
|
||||||
|
let PatternedPushRule { actions, default, enabled, rule_id, pattern, .. } = push_rule;
|
||||||
|
Self { actions, default, enabled, rule_id, conditions: None, pattern: Some(pattern) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<ConditionalPushRule> for PushRule {
|
||||||
|
fn from(push_rule: ConditionalPushRule) -> Self {
|
||||||
|
let ConditionalPushRule { actions, default, enabled, rule_id, conditions, .. } = push_rule;
|
||||||
|
Self { actions, default, enabled, rule_id, conditions: Some(conditions), pattern: None }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<SimplePushRuleInit> for PushRule {
|
||||||
|
fn from(init: SimplePushRuleInit) -> Self {
|
||||||
|
let SimplePushRuleInit { actions, default, enabled, rule_id } = init;
|
||||||
|
Self { actions, default, enabled, rule_id, pattern: None, conditions: None }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<ConditionalPushRuleInit> for PushRule {
|
||||||
|
fn from(init: ConditionalPushRuleInit) -> Self {
|
||||||
|
let ConditionalPushRuleInit { actions, default, enabled, rule_id, conditions } = init;
|
||||||
|
Self { actions, default, enabled, rule_id, pattern: None, conditions: Some(conditions) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<PatternedPushRuleInit> for PushRule {
|
||||||
|
fn from(init: PatternedPushRuleInit) -> Self {
|
||||||
|
let PatternedPushRuleInit { actions, default, enabled, rule_id, pattern } = init;
|
||||||
|
Self { actions, default, enabled, rule_id, pattern: Some(pattern), conditions: None }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<PushRule> for SimplePushRule {
|
||||||
|
fn from(push_rule: PushRule) -> Self {
|
||||||
|
let PushRule { actions, default, enabled, rule_id, .. } = push_rule;
|
||||||
|
SimplePushRuleInit { actions, default, enabled, rule_id }.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An error that happens when `PushRule` cannot
|
||||||
|
/// be converted into `PatternedPushRule`
|
||||||
|
#[derive(Debug)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct MissingPatternError;
|
||||||
|
|
||||||
|
impl Display for MissingPatternError {
|
||||||
|
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
||||||
|
write!(f, "Push rule does not have a pattern.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Error for MissingPatternError {}
|
||||||
|
|
||||||
|
impl TryFrom<PushRule> for PatternedPushRule {
|
||||||
|
type Error = MissingPatternError;
|
||||||
|
|
||||||
|
fn try_from(push_rule: PushRule) -> Result<Self, Self::Error> {
|
||||||
|
if let PushRule { actions, default, enabled, rule_id, pattern: Some(pattern), .. } =
|
||||||
|
push_rule
|
||||||
|
{
|
||||||
|
Ok(PatternedPushRuleInit { actions, default, enabled, rule_id, pattern }.into())
|
||||||
|
} else {
|
||||||
|
Err(MissingPatternError)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// An error that happens when `PushRule` cannot
|
||||||
|
/// be converted into `ConditionalPushRule`
|
||||||
|
#[derive(Debug)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct MissingConditionsError;
|
||||||
|
|
||||||
|
impl Display for MissingConditionsError {
|
||||||
|
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
||||||
|
write!(f, "Push rule has no conditions.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Error for MissingConditionsError {}
|
||||||
|
|
||||||
|
impl TryFrom<PushRule> for ConditionalPushRule {
|
||||||
|
type Error = MissingConditionsError;
|
||||||
|
|
||||||
|
fn try_from(push_rule: PushRule) -> Result<Self, Self::Error> {
|
||||||
|
if let PushRule {
|
||||||
|
actions, default, enabled, rule_id, conditions: Some(conditions), ..
|
||||||
|
} = push_rule
|
||||||
|
{
|
||||||
|
Ok(ConditionalPushRuleInit { actions, default, enabled, rule_id, conditions }.into())
|
||||||
|
} else {
|
||||||
|
Err(MissingConditionsError)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// The kinds of push rules that are available.
|
/// The kinds of push rules that are available.
|
||||||
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, StringEnum)]
|
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, StringEnum)]
|
||||||
#[ruma_enum(rename_all = "snake_case")]
|
#[ruma_enum(rename_all = "snake_case")]
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
//! [GET /_matrix/client/r0/pushrules/{scope}/{kind}/{ruleId}](https://matrix.org/docs/spec/client_server/r0.6.0#get-matrix-client-r0-pushrules-scope-kind-ruleid)
|
//! [GET /_matrix/client/r0/pushrules/{scope}/{kind}/{ruleId}](https://matrix.org/docs/spec/client_server/r0.6.0#get-matrix-client-r0-pushrules-scope-kind-ruleid)
|
||||||
|
|
||||||
use ruma_api::ruma_api;
|
use ruma_api::ruma_api;
|
||||||
use ruma_common::push::AnyPushRule;
|
|
||||||
|
|
||||||
use super::RuleKind;
|
use super::{PushRule, RuleKind};
|
||||||
|
|
||||||
ruma_api! {
|
ruma_api! {
|
||||||
metadata: {
|
metadata: {
|
||||||
@ -32,7 +31,7 @@ ruma_api! {
|
|||||||
response: {
|
response: {
|
||||||
/// The specific push rule.
|
/// The specific push rule.
|
||||||
#[ruma_api(body)]
|
#[ruma_api(body)]
|
||||||
pub rule: AnyPushRule,
|
pub rule: PushRule,
|
||||||
}
|
}
|
||||||
|
|
||||||
error: crate::Error
|
error: crate::Error
|
||||||
@ -47,7 +46,7 @@ impl<'a> Request<'a> {
|
|||||||
|
|
||||||
impl Response {
|
impl Response {
|
||||||
/// Creates a new `Response` with the given rule.
|
/// Creates a new `Response` with the given rule.
|
||||||
pub fn new(rule: AnyPushRule) -> Self {
|
pub fn new(rule: PushRule) -> Self {
|
||||||
Self { rule }
|
Self { rule }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,8 @@ Breaking changes:
|
|||||||
|
|
||||||
* Update set of conversion trait implementations for enums
|
* Update set of conversion trait implementations for enums
|
||||||
* Replace `BTreeSet` by `IndexSet` in `push::Ruleset`.
|
* Replace `BTreeSet` by `IndexSet` in `push::Ruleset`.
|
||||||
|
* Remove `push::AnyPushRule`. Use `r0::push::PushRule`
|
||||||
|
from `ruma-client-api`.
|
||||||
* … (there's a lot more, but this changelog was not kept up to date; PRs to
|
* … (there's a lot more, but this changelog was not kept up to date; PRs to
|
||||||
improve it are welcome)
|
improve it are welcome)
|
||||||
|
|
||||||
|
@ -30,9 +30,6 @@
|
|||||||
//!
|
//!
|
||||||
//! It is still possible to write code that is generic over a representation by manipulating
|
//! It is still possible to write code that is generic over a representation by manipulating
|
||||||
//! `SimplePushRule`, `ConditonalPushRule` or `PatternedPushRule` directly, instead of the wrappers.
|
//! `SimplePushRule`, `ConditonalPushRule` or `PatternedPushRule` directly, instead of the wrappers.
|
||||||
//!
|
|
||||||
//! There is also the `AnyPushRule` type that is the most generic form of push rule, with all
|
|
||||||
//! the possible fields.
|
|
||||||
|
|
||||||
use std::hash::{Hash, Hasher};
|
use std::hash::{Hash, Hasher};
|
||||||
|
|
||||||
@ -44,13 +41,11 @@ use ruma_serde::StringEnum;
|
|||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
mod action;
|
mod action;
|
||||||
mod any_push_rule;
|
|
||||||
mod condition;
|
mod condition;
|
||||||
mod predefined;
|
mod predefined;
|
||||||
|
|
||||||
pub use self::{
|
pub use self::{
|
||||||
action::{Action, Tweak},
|
action::{Action, Tweak},
|
||||||
any_push_rule::{AnyPushRule, MissingConditionsError, MissingPatternError},
|
|
||||||
condition::{ComparisonOperator, PushCondition, RoomMemberCountIs},
|
condition::{ComparisonOperator, PushCondition, RoomMemberCountIs},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -108,34 +103,34 @@ pub struct RulesetIter {
|
|||||||
underride: IndexSetIter<UnderridePushRule>,
|
underride: IndexSetIter<UnderridePushRule>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Iterator for RulesetIter {
|
// impl Iterator for RulesetIter {
|
||||||
type Item = AnyPushRule;
|
// type Item = AnyPushRule;
|
||||||
|
|
||||||
fn next(&mut self) -> Option<Self::Item> {
|
// fn next(&mut self) -> Option<Self::Item> {
|
||||||
self.override_
|
// self.override_
|
||||||
.next()
|
// .next()
|
||||||
.map(|x| x.0.into())
|
// .map(|x| x.0.into())
|
||||||
.or_else(|| self.content.next().map(|x| x.0.into()))
|
// .or_else(|| self.content.next().map(|x| x.0.into()))
|
||||||
.or_else(|| self.room.next().map(|x| x.0.into()))
|
// .or_else(|| self.room.next().map(|x| x.0.into()))
|
||||||
.or_else(|| self.sender.next().map(|x| x.0.into()))
|
// .or_else(|| self.sender.next().map(|x| x.0.into()))
|
||||||
.or_else(|| self.underride.next().map(|x| x.0.into()))
|
// .or_else(|| self.underride.next().map(|x| x.0.into()))
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
impl IntoIterator for Ruleset {
|
// impl IntoIterator for Ruleset {
|
||||||
type Item = AnyPushRule;
|
// type Item = AnyPushRule;
|
||||||
type IntoIter = RulesetIter;
|
// type IntoIter = RulesetIter;
|
||||||
|
|
||||||
fn into_iter(self) -> Self::IntoIter {
|
// fn into_iter(self) -> Self::IntoIter {
|
||||||
RulesetIter {
|
// RulesetIter {
|
||||||
content: self.content.into_iter(),
|
// content: self.content.into_iter(),
|
||||||
override_: self.override_.into_iter(),
|
// override_: self.override_.into_iter(),
|
||||||
room: self.room.into_iter(),
|
// room: self.room.into_iter(),
|
||||||
sender: self.sender.into_iter(),
|
// sender: self.sender.into_iter(),
|
||||||
underride: self.underride.into_iter(),
|
// underride: self.underride.into_iter(),
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
/// A trait for types that can be added in a Ruleset
|
/// A trait for types that can be added in a Ruleset
|
||||||
pub trait RulesetMember: private::Sealed {
|
pub trait RulesetMember: private::Sealed {
|
||||||
|
@ -1,154 +0,0 @@
|
|||||||
use std::{
|
|
||||||
convert::TryFrom,
|
|
||||||
error::Error,
|
|
||||||
fmt::{self, Display, Formatter},
|
|
||||||
};
|
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
|
|
||||||
use super::{
|
|
||||||
Action, ConditionalPushRule, ConditionalPushRuleInit, PatternedPushRule, PatternedPushRuleInit,
|
|
||||||
PushCondition, SimplePushRule, SimplePushRuleInit,
|
|
||||||
};
|
|
||||||
|
|
||||||
/// Like `SimplePushRule`, but may represent any kind of push rule
|
|
||||||
/// thanks to `pattern` and `conditions` being optional.
|
|
||||||
///
|
|
||||||
/// To create an instance of this type, use one of its `From` implementations.
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct AnyPushRule {
|
|
||||||
/// The actions to perform when this rule is matched.
|
|
||||||
pub actions: Vec<Action>,
|
|
||||||
|
|
||||||
/// Whether this is a default rule, or has been set explicitly.
|
|
||||||
pub default: bool,
|
|
||||||
|
|
||||||
/// Whether the push rule is enabled or not.
|
|
||||||
pub enabled: bool,
|
|
||||||
|
|
||||||
/// The ID of this rule.
|
|
||||||
pub rule_id: String,
|
|
||||||
|
|
||||||
/// The conditions that must hold true for an event in order for a rule to be applied to an
|
|
||||||
/// event. A rule with no conditions always matches.
|
|
||||||
///
|
|
||||||
/// Only applicable to underride and override rules.
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
|
||||||
pub conditions: Option<Vec<PushCondition>>,
|
|
||||||
|
|
||||||
/// The glob-style pattern to match against. Only applicable to content rules.
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
|
||||||
pub pattern: Option<String>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<SimplePushRule> for AnyPushRule {
|
|
||||||
fn from(push_rule: SimplePushRule) -> Self {
|
|
||||||
let SimplePushRule { actions, default, enabled, rule_id } = push_rule;
|
|
||||||
Self { actions, default, enabled, rule_id, conditions: None, pattern: None }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<PatternedPushRule> for AnyPushRule {
|
|
||||||
fn from(push_rule: PatternedPushRule) -> Self {
|
|
||||||
let PatternedPushRule { actions, default, enabled, rule_id, pattern } = push_rule;
|
|
||||||
Self { actions, default, enabled, rule_id, conditions: None, pattern: Some(pattern) }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<ConditionalPushRule> for AnyPushRule {
|
|
||||||
fn from(push_rule: ConditionalPushRule) -> Self {
|
|
||||||
let ConditionalPushRule { actions, default, enabled, rule_id, conditions } = push_rule;
|
|
||||||
Self { actions, default, enabled, rule_id, conditions: Some(conditions), pattern: None }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<SimplePushRuleInit> for AnyPushRule {
|
|
||||||
fn from(init: SimplePushRuleInit) -> Self {
|
|
||||||
let SimplePushRuleInit { actions, default, enabled, rule_id } = init;
|
|
||||||
Self { actions, default, enabled, rule_id, pattern: None, conditions: None }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<ConditionalPushRuleInit> for AnyPushRule {
|
|
||||||
fn from(init: ConditionalPushRuleInit) -> Self {
|
|
||||||
let ConditionalPushRuleInit { actions, default, enabled, rule_id, conditions } = init;
|
|
||||||
Self { actions, default, enabled, rule_id, pattern: None, conditions: Some(conditions) }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<PatternedPushRuleInit> for AnyPushRule {
|
|
||||||
fn from(init: PatternedPushRuleInit) -> Self {
|
|
||||||
let PatternedPushRuleInit { actions, default, enabled, rule_id, pattern } = init;
|
|
||||||
Self { actions, default, enabled, rule_id, pattern: Some(pattern), conditions: None }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<AnyPushRule> for SimplePushRule {
|
|
||||||
fn from(push_rule: AnyPushRule) -> Self {
|
|
||||||
let AnyPushRule { actions, default, enabled, rule_id, .. } = push_rule;
|
|
||||||
Self { actions, default, enabled, rule_id }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// An error that happens when `AnyPushRule` cannot
|
|
||||||
/// be converted into `PatternedPushRule`
|
|
||||||
#[derive(Debug)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct MissingPatternError;
|
|
||||||
|
|
||||||
impl Display for MissingPatternError {
|
|
||||||
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
|
||||||
write!(f, "Push rule does not have a pattern.")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Error for MissingPatternError {}
|
|
||||||
|
|
||||||
impl TryFrom<AnyPushRule> for PatternedPushRule {
|
|
||||||
type Error = MissingPatternError;
|
|
||||||
|
|
||||||
fn try_from(push_rule: AnyPushRule) -> Result<Self, Self::Error> {
|
|
||||||
if let AnyPushRule { actions, default, enabled, rule_id, pattern: Some(pattern), .. } =
|
|
||||||
push_rule
|
|
||||||
{
|
|
||||||
Ok(PatternedPushRule { actions, default, enabled, rule_id, pattern })
|
|
||||||
} else {
|
|
||||||
Err(MissingPatternError)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// An error that happens when `AnyPushRule` cannot
|
|
||||||
/// be converted into `ConditionalPushRule`
|
|
||||||
#[derive(Debug)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct MissingConditionsError;
|
|
||||||
|
|
||||||
impl Display for MissingConditionsError {
|
|
||||||
fn fmt(&self, f: &mut Formatter) -> fmt::Result {
|
|
||||||
write!(f, "Push rule has no conditions.")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Error for MissingConditionsError {}
|
|
||||||
|
|
||||||
impl TryFrom<AnyPushRule> for ConditionalPushRule {
|
|
||||||
type Error = MissingConditionsError;
|
|
||||||
|
|
||||||
fn try_from(push_rule: AnyPushRule) -> Result<Self, Self::Error> {
|
|
||||||
if let AnyPushRule {
|
|
||||||
actions,
|
|
||||||
default,
|
|
||||||
enabled,
|
|
||||||
rule_id,
|
|
||||||
conditions: Some(conditions),
|
|
||||||
..
|
|
||||||
} = push_rule
|
|
||||||
{
|
|
||||||
Ok(ConditionalPushRule { actions, default, enabled, rule_id, conditions })
|
|
||||||
} else {
|
|
||||||
Err(MissingConditionsError)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
x
Reference in New Issue
Block a user