Merge pull request #8945 from element-hq/feature/bma/elementCallNotification

Ensure m.call.notify event is not filtered out by push rules.
This commit is contained in:
Benoit Marty 2024-11-18 14:56:53 +01:00 committed by GitHub
commit 367fcfa8f9
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 72 additions and 1 deletions

View File

@ -57,6 +57,9 @@ object RuleIds {
const val RULE_ID_POLL_END = ".m.rule.poll_end" const val RULE_ID_POLL_END = ".m.rule.poll_end"
const val RULE_ID_POLL_END_UNSTABLE = ".org.matrix.msc3930.rule.poll_end" const val RULE_ID_POLL_END_UNSTABLE = ".org.matrix.msc3930.rule.poll_end"
const val RULE_ID_ELEMENT_CALL_NOTIFY = ".m.call.notify"
const val RULE_ID_ELEMENT_CALL_NOTIFY_UNSTABLE = ".org.matrix.msc4075.call.notify"
// Not documented // Not documented
const val RULE_ID_FALLBACK = ".m.rule.fallback" const val RULE_ID_FALLBACK = ".m.rule.fallback"

View File

@ -103,7 +103,7 @@ internal class DefaultPushRuleService @Inject constructor(
} }
return RuleSet( return RuleSet(
content = contentRules, content = contentRules.withElementCallPushRules(),
override = overrideRules, override = overrideRules,
room = roomRules, room = roomRules,
sender = senderRules, sender = senderRules,

View File

@ -0,0 +1,68 @@
/*
* Copyright (c) 2024 The Matrix.org Foundation C.I.C.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.matrix.android.sdk.internal.session.pushrules
import org.matrix.android.sdk.api.session.pushrules.Action
import org.matrix.android.sdk.api.session.pushrules.RuleIds
import org.matrix.android.sdk.api.session.pushrules.rest.PushCondition
import org.matrix.android.sdk.api.session.pushrules.rest.PushRule
private val localElementCallPushRule = PushRule(
ruleId = RuleIds.RULE_ID_ELEMENT_CALL_NOTIFY,
conditions = listOf(
PushCondition(
kind = "event_match",
key = "type",
pattern = "m.call.notify",
)
),
actions = listOf(
Action.ACTION_NOTIFY,
),
enabled = true,
)
private val localElementCallPushRuleUnstable = PushRule(
ruleId = RuleIds.RULE_ID_ELEMENT_CALL_NOTIFY_UNSTABLE,
conditions = listOf(
PushCondition(
kind = "event_match",
key = "type",
pattern = "org.matrix.msc4075.call.notify",
)
),
actions = listOf(
Action.ACTION_NOTIFY,
),
enabled = true,
)
/**
* Ensure that the element call push rules are present.
*/
fun List<PushRule>.withElementCallPushRules(): List<PushRule> {
val ruleIds = map { it.ruleId }
return buildList {
addAll(this@withElementCallPushRules)
if (!ruleIds.contains(localElementCallPushRule.ruleId)) {
add(localElementCallPushRule)
}
if (!ruleIds.contains(localElementCallPushRuleUnstable.ruleId)) {
add(localElementCallPushRuleUnstable)
}
}
}