2016-01-06 21:26:29 -07:00
|
|
|
# Copyright 2015, 2016 OpenMarket Ltd
|
2017-10-05 05:39:18 -06:00
|
|
|
# Copyright 2017 New Vector Ltd
|
2019-07-05 10:37:52 -06:00
|
|
|
# Copyright 2019 The Matrix.org Foundation C.I.C.
|
2015-04-24 03:35:29 -06:00
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
2016-02-26 07:28:19 -07:00
|
|
|
import copy
|
2020-12-11 09:43:53 -07:00
|
|
|
from typing import Any, Dict, List
|
2015-02-05 07:46:06 -07:00
|
|
|
|
2018-07-09 00:09:20 -06:00
|
|
|
from synapse.push.rulekinds import PRIORITY_CLASS_INVERSE_MAP, PRIORITY_CLASS_MAP
|
|
|
|
|
2015-02-10 09:30:48 -07:00
|
|
|
|
2022-02-02 07:49:31 -07:00
|
|
|
def list_with_base_rules(rawrules: List[Dict[str, Any]]) -> List[Dict[str, Any]]:
|
2016-02-26 07:28:19 -07:00
|
|
|
"""Combine the list of rules set by the user with the default push rules
|
|
|
|
|
2016-04-01 09:08:59 -06:00
|
|
|
Args:
|
2020-12-11 09:43:53 -07:00
|
|
|
rawrules: The rules the user has modified or set.
|
2016-04-01 09:08:59 -06:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
A new list with the rules set by the user combined with the defaults.
|
2016-02-26 07:28:19 -07:00
|
|
|
"""
|
2015-02-05 07:46:06 -07:00
|
|
|
ruleslist = []
|
|
|
|
|
2016-02-26 07:28:19 -07:00
|
|
|
# Grab the base rules that the user has modified.
|
|
|
|
# The modified base rules have a priority_class of -1.
|
|
|
|
modified_base_rules = {r["rule_id"]: r for r in rawrules if r["priority_class"] < 0}
|
|
|
|
|
|
|
|
# Remove the modified base rules from the list, They'll be added back
|
2020-10-23 10:38:40 -06:00
|
|
|
# in the default positions in the list.
|
2016-02-26 07:28:19 -07:00
|
|
|
rawrules = [r for r in rawrules if r["priority_class"] >= 0]
|
|
|
|
|
2015-02-05 07:46:06 -07:00
|
|
|
# shove the server default rules for each kind onto the end of each
|
2018-05-31 03:03:47 -06:00
|
|
|
current_prio_class = list(PRIORITY_CLASS_INVERSE_MAP)[-1]
|
2015-03-10 11:26:25 -06:00
|
|
|
|
|
|
|
ruleslist.extend(
|
|
|
|
make_base_prepend_rules(
|
2022-02-02 07:49:31 -07:00
|
|
|
PRIORITY_CLASS_INVERSE_MAP[current_prio_class], modified_base_rules
|
2015-03-10 11:26:25 -06:00
|
|
|
)
|
2019-06-20 03:32:02 -06:00
|
|
|
)
|
2015-03-10 11:26:25 -06:00
|
|
|
|
2015-02-05 07:46:06 -07:00
|
|
|
for r in rawrules:
|
2015-02-09 07:17:52 -07:00
|
|
|
if r["priority_class"] < current_prio_class:
|
|
|
|
while r["priority_class"] < current_prio_class:
|
2015-03-10 11:26:25 -06:00
|
|
|
ruleslist.extend(
|
|
|
|
make_base_append_rules(
|
2016-02-26 07:28:19 -07:00
|
|
|
PRIORITY_CLASS_INVERSE_MAP[current_prio_class],
|
|
|
|
modified_base_rules,
|
2015-03-10 11:26:25 -06:00
|
|
|
)
|
2019-06-20 03:32:02 -06:00
|
|
|
)
|
2015-02-09 07:17:52 -07:00
|
|
|
current_prio_class -= 1
|
2015-03-10 11:26:25 -06:00
|
|
|
if current_prio_class > 0:
|
|
|
|
ruleslist.extend(
|
|
|
|
make_base_prepend_rules(
|
2016-02-26 07:28:19 -07:00
|
|
|
PRIORITY_CLASS_INVERSE_MAP[current_prio_class],
|
|
|
|
modified_base_rules,
|
2019-06-20 03:32:02 -06:00
|
|
|
)
|
|
|
|
)
|
2015-02-05 07:46:06 -07:00
|
|
|
|
|
|
|
ruleslist.append(r)
|
|
|
|
|
2015-02-09 07:17:52 -07:00
|
|
|
while current_prio_class > 0:
|
2015-03-10 11:26:25 -06:00
|
|
|
ruleslist.extend(
|
|
|
|
make_base_append_rules(
|
2022-02-02 07:49:31 -07:00
|
|
|
PRIORITY_CLASS_INVERSE_MAP[current_prio_class], modified_base_rules
|
2019-06-20 03:32:02 -06:00
|
|
|
)
|
2015-02-10 09:30:48 -07:00
|
|
|
)
|
2015-02-09 07:17:52 -07:00
|
|
|
current_prio_class -= 1
|
2015-03-10 11:26:25 -06:00
|
|
|
if current_prio_class > 0:
|
|
|
|
ruleslist.extend(
|
|
|
|
make_base_prepend_rules(
|
2022-02-02 07:49:31 -07:00
|
|
|
PRIORITY_CLASS_INVERSE_MAP[current_prio_class], modified_base_rules
|
2019-06-20 03:32:02 -06:00
|
|
|
)
|
2015-03-10 11:26:25 -06:00
|
|
|
)
|
2015-02-05 07:46:06 -07:00
|
|
|
|
|
|
|
return ruleslist
|
|
|
|
|
|
|
|
|
2020-12-11 09:43:53 -07:00
|
|
|
def make_base_append_rules(
|
2022-02-02 07:49:31 -07:00
|
|
|
kind: str, modified_base_rules: Dict[str, Dict[str, Any]]
|
2020-12-11 09:43:53 -07:00
|
|
|
) -> List[Dict[str, Any]]:
|
2015-02-05 07:46:06 -07:00
|
|
|
rules = []
|
|
|
|
|
|
|
|
if kind == "override":
|
2022-02-02 07:49:31 -07:00
|
|
|
rules = BASE_APPEND_OVERRIDE_RULES
|
2015-02-26 11:58:14 -07:00
|
|
|
elif kind == "underride":
|
2022-02-02 07:49:31 -07:00
|
|
|
rules = BASE_APPEND_UNDERRIDE_RULES
|
2015-02-05 07:46:06 -07:00
|
|
|
elif kind == "content":
|
2016-01-18 03:09:14 -07:00
|
|
|
rules = BASE_APPEND_CONTENT_RULES
|
2015-03-10 11:26:25 -06:00
|
|
|
|
2016-02-26 07:28:19 -07:00
|
|
|
# Copy the rules before modifying them
|
|
|
|
rules = copy.deepcopy(rules)
|
|
|
|
for r in rules:
|
|
|
|
# Only modify the actions, keep the conditions the same.
|
2020-12-11 09:43:53 -07:00
|
|
|
assert isinstance(r["rule_id"], str)
|
2016-02-26 07:28:19 -07:00
|
|
|
modified = modified_base_rules.get(r["rule_id"])
|
|
|
|
if modified:
|
|
|
|
r["actions"] = modified["actions"]
|
|
|
|
|
2015-03-10 11:26:25 -06:00
|
|
|
return rules
|
|
|
|
|
2015-03-11 04:01:17 -06:00
|
|
|
|
2020-12-11 09:43:53 -07:00
|
|
|
def make_base_prepend_rules(
|
|
|
|
kind: str,
|
|
|
|
modified_base_rules: Dict[str, Dict[str, Any]],
|
|
|
|
) -> List[Dict[str, Any]]:
|
2015-03-10 11:26:25 -06:00
|
|
|
rules = []
|
|
|
|
|
|
|
|
if kind == "override":
|
2020-08-06 03:52:26 -06:00
|
|
|
rules = BASE_PREPEND_OVERRIDE_RULES
|
2015-02-05 07:46:06 -07:00
|
|
|
|
2016-02-26 07:28:19 -07:00
|
|
|
# Copy the rules before modifying them
|
|
|
|
rules = copy.deepcopy(rules)
|
|
|
|
for r in rules:
|
|
|
|
# Only modify the actions, keep the conditions the same.
|
2020-12-11 09:43:53 -07:00
|
|
|
assert isinstance(r["rule_id"], str)
|
2016-02-26 07:28:19 -07:00
|
|
|
modified = modified_base_rules.get(r["rule_id"])
|
|
|
|
if modified:
|
|
|
|
r["actions"] = modified["actions"]
|
|
|
|
|
2015-02-05 07:46:06 -07:00
|
|
|
return rules
|
|
|
|
|
|
|
|
|
2022-02-18 08:57:26 -07:00
|
|
|
# We have to annotate these types, otherwise mypy infers them as
|
|
|
|
# `List[Dict[str, Sequence[Collection[str]]]]`.
|
|
|
|
BASE_APPEND_CONTENT_RULES: List[Dict[str, Any]] = [
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/content/.m.rule.contains_user_name",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "content.body",
|
2022-05-24 07:23:23 -06:00
|
|
|
# Match the localpart of the requester's MXID.
|
2016-01-18 03:09:14 -07:00
|
|
|
"pattern_type": "user_localpart",
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": [
|
|
|
|
"notify",
|
|
|
|
{"set_tweak": "sound", "value": "default"},
|
|
|
|
{"set_tweak": "highlight"},
|
2019-06-20 03:32:02 -06:00
|
|
|
],
|
2016-01-18 03:09:14 -07:00
|
|
|
}
|
|
|
|
]
|
2015-02-05 07:46:06 -07:00
|
|
|
|
|
|
|
|
2022-02-18 08:57:26 -07:00
|
|
|
BASE_PREPEND_OVERRIDE_RULES: List[Dict[str, Any]] = [
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/override/.m.rule.master",
|
|
|
|
"enabled": False,
|
|
|
|
"conditions": [],
|
|
|
|
"actions": ["dont_notify"],
|
|
|
|
}
|
|
|
|
]
|
2015-03-10 11:26:25 -06:00
|
|
|
|
|
|
|
|
2022-02-18 08:57:26 -07:00
|
|
|
BASE_APPEND_OVERRIDE_RULES: List[Dict[str, Any]] = [
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/override/.m.rule.suppress_notices",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "content.msgtype",
|
|
|
|
"pattern": "m.notice",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_suppress_notices",
|
2016-01-18 03:09:14 -07:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["dont_notify"],
|
2016-03-24 07:19:39 -06:00
|
|
|
},
|
2016-04-08 08:29:59 -06:00
|
|
|
# NB. .m.rule.invite_for_me must be higher prio than .m.rule.member_event
|
|
|
|
# otherwise invites will be matched by .m.rule.member_event
|
|
|
|
{
|
2016-04-11 09:10:39 -06:00
|
|
|
"rule_id": "global/override/.m.rule.invite_for_me",
|
2016-04-08 08:29:59 -06:00
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.member",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_member",
|
2016-04-08 08:29:59 -06:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "content.membership",
|
|
|
|
"pattern": "invite",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_invite_member",
|
2016-04-08 08:29:59 -06:00
|
|
|
},
|
2022-05-24 07:23:23 -06:00
|
|
|
# Match the requester's MXID.
|
2016-04-08 08:29:59 -06:00
|
|
|
{"kind": "event_match", "key": "state_key", "pattern_type": "user_id"},
|
2019-06-20 03:32:02 -06:00
|
|
|
],
|
|
|
|
"actions": [
|
|
|
|
"notify",
|
2016-04-08 08:29:59 -06:00
|
|
|
{"set_tweak": "sound", "value": "default"},
|
|
|
|
{"set_tweak": "highlight", "value": False},
|
|
|
|
],
|
|
|
|
},
|
2016-03-24 07:19:39 -06:00
|
|
|
# Will we sometimes want to know about people joining and leaving?
|
|
|
|
# Perhaps: if so, this could be expanded upon. Seems the most usual case
|
|
|
|
# is that we don't though. We add this override rule so that even if
|
|
|
|
# the room rule is set to notify, we don't get notifications about
|
|
|
|
# join/leave/avatar/displayname events.
|
|
|
|
# See also: https://matrix.org/jira/browse/SYN-607
|
|
|
|
{
|
|
|
|
"rule_id": "global/override/.m.rule.member_event",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.member",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_member",
|
2016-03-24 07:19:39 -06:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["dont_notify"],
|
|
|
|
},
|
2016-08-15 11:34:53 -06:00
|
|
|
# This was changed from underride to override so it's closer in priority
|
|
|
|
# to the content rules where the user name highlight rule lives. This
|
|
|
|
# way a room rule is lower priority than both but a custom override rule
|
|
|
|
# is higher priority than both.
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
2016-08-16 09:44:07 -06:00
|
|
|
"rule_id": "global/override/.m.rule.contains_display_name",
|
2016-08-15 11:34:53 -06:00
|
|
|
"conditions": [{"kind": "contains_display_name"}],
|
2019-06-20 03:32:02 -06:00
|
|
|
"actions": [
|
|
|
|
"notify",
|
2016-01-18 03:09:14 -07:00
|
|
|
{"set_tweak": "sound", "value": "default"},
|
2016-04-08 08:29:59 -06:00
|
|
|
{"set_tweak": "highlight"},
|
2016-01-18 03:09:14 -07:00
|
|
|
],
|
|
|
|
},
|
2017-10-05 05:39:18 -06:00
|
|
|
{
|
2017-10-05 06:03:44 -06:00
|
|
|
"rule_id": "global/override/.m.rule.roomnotif",
|
2017-10-05 05:39:18 -06:00
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "content.body",
|
2017-10-16 06:38:10 -06:00
|
|
|
"pattern": "@room",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_roomnotif_content",
|
2017-10-05 05:39:18 -06:00
|
|
|
},
|
|
|
|
{
|
2017-10-10 08:23:00 -06:00
|
|
|
"kind": "sender_notification_permission",
|
|
|
|
"key": "room",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_roomnotif_pl",
|
2017-10-05 05:39:18 -06:00
|
|
|
},
|
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": True}],
|
2019-04-29 15:40:31 -06:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"rule_id": "global/override/.m.rule.tombstone",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.tombstone",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_tombstone",
|
2019-07-31 09:22:38 -06:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "state_key",
|
|
|
|
"pattern": "",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_tombstone_statekey",
|
2019-07-31 09:22:38 -06:00
|
|
|
},
|
2019-04-29 15:40:31 -06:00
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": True}],
|
|
|
|
},
|
2019-07-05 10:37:52 -06:00
|
|
|
{
|
|
|
|
"rule_id": "global/override/.m.rule.reaction",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.reaction",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_reaction",
|
2019-07-05 10:37:52 -06:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["dont_notify"],
|
|
|
|
},
|
2022-05-10 01:57:36 -06:00
|
|
|
# XXX: This is an experimental rule that is only enabled if msc3786_enabled
|
|
|
|
# is enabled, if it is not the rule gets filtered out in _load_rules() in
|
|
|
|
# PushRulesWorkerStore
|
|
|
|
{
|
|
|
|
"rule_id": "global/override/.org.matrix.msc3786.rule.room.server_acl",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.server_acl",
|
|
|
|
"_cache_key": "_room_server_acl",
|
|
|
|
}
|
|
|
|
],
|
2022-05-24 10:42:32 -06:00
|
|
|
"actions": [],
|
2022-05-10 01:57:36 -06:00
|
|
|
},
|
2016-08-15 11:34:53 -06:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2022-02-18 08:57:26 -07:00
|
|
|
BASE_APPEND_UNDERRIDE_RULES: List[Dict[str, Any]] = [
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
2016-08-15 11:34:53 -06:00
|
|
|
"rule_id": "global/underride/.m.rule.call",
|
2016-01-18 03:09:14 -07:00
|
|
|
"conditions": [
|
|
|
|
{
|
2016-08-15 11:34:53 -06:00
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.call.invite",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_call",
|
2016-01-18 03:09:14 -07:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": [
|
|
|
|
"notify",
|
|
|
|
{"set_tweak": "sound", "value": "ring"},
|
2016-08-15 11:34:53 -06:00
|
|
|
{"set_tweak": "highlight", "value": False},
|
2016-01-18 03:09:14 -07:00
|
|
|
],
|
|
|
|
},
|
2016-09-17 15:05:06 -06:00
|
|
|
# XXX: once m.direct is standardised everywhere, we should use it to detect
|
|
|
|
# a DM from the user's perspective rather than this heuristic.
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.m.rule.room_one_to_one",
|
|
|
|
"conditions": [
|
2022-03-11 06:45:26 -07:00
|
|
|
{"kind": "room_member_count", "is": "2", "_cache_key": "member_count"},
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"kind": "event_match",
|
2019-06-20 03:32:02 -06:00
|
|
|
"key": "type",
|
2016-01-18 03:09:14 -07:00
|
|
|
"pattern": "m.room.message",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_message",
|
2016-01-26 03:21:41 -07:00
|
|
|
},
|
2016-01-18 03:09:14 -07:00
|
|
|
],
|
|
|
|
"actions": [
|
|
|
|
"notify",
|
|
|
|
{"set_tweak": "sound", "value": "default"},
|
|
|
|
{"set_tweak": "highlight", "value": False},
|
|
|
|
],
|
|
|
|
},
|
2016-09-17 15:05:06 -06:00
|
|
|
# XXX: this is going to fire for events which aren't m.room.messages
|
|
|
|
# but are encrypted (e.g. m.call.*)...
|
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.m.rule.encrypted_room_one_to_one",
|
|
|
|
"conditions": [
|
2022-03-11 06:45:26 -07:00
|
|
|
{"kind": "room_member_count", "is": "2", "_cache_key": "member_count"},
|
2016-09-17 15:05:06 -06:00
|
|
|
{
|
|
|
|
"kind": "event_match",
|
2019-06-20 03:32:02 -06:00
|
|
|
"key": "type",
|
2016-09-17 15:05:06 -06:00
|
|
|
"pattern": "m.room.encrypted",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_encrypted",
|
2016-09-17 15:05:06 -06:00
|
|
|
},
|
|
|
|
],
|
|
|
|
"actions": [
|
|
|
|
"notify",
|
|
|
|
{"set_tweak": "sound", "value": "default"},
|
|
|
|
{"set_tweak": "highlight", "value": False},
|
|
|
|
],
|
|
|
|
},
|
2022-05-24 07:23:23 -06:00
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.org.matrix.msc3772.thread_reply",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "org.matrix.msc3772.relation_match",
|
|
|
|
"rel_type": "m.thread",
|
|
|
|
# Match the requester's MXID.
|
|
|
|
"sender_type": "user_id",
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": False}],
|
|
|
|
},
|
2016-01-18 03:09:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.m.rule.message",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.message",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_message",
|
2016-01-18 03:09:14 -07:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": False}],
|
2016-09-17 15:05:06 -06:00
|
|
|
},
|
|
|
|
# XXX: this is going to fire for events which aren't m.room.messages
|
|
|
|
# but are encrypted (e.g. m.call.*)...
|
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.m.rule.encrypted",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "m.room.encrypted",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_encrypted",
|
2016-09-17 15:05:06 -06:00
|
|
|
}
|
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": False}],
|
|
|
|
},
|
2020-11-02 09:36:14 -07:00
|
|
|
{
|
|
|
|
"rule_id": "global/underride/.im.vector.jitsi",
|
|
|
|
"conditions": [
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "type",
|
|
|
|
"pattern": "im.vector.modular.widgets",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_type_modular_widgets",
|
2020-11-02 09:36:14 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "content.type",
|
|
|
|
"pattern": "jitsi",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_content_type_jitsi",
|
2020-11-02 09:36:14 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
"kind": "event_match",
|
|
|
|
"key": "state_key",
|
|
|
|
"pattern": "*",
|
2022-03-11 06:45:26 -07:00
|
|
|
"_cache_key": "_is_state_event",
|
2020-11-02 09:36:14 -07:00
|
|
|
},
|
|
|
|
],
|
|
|
|
"actions": ["notify", {"set_tweak": "highlight", "value": False}],
|
|
|
|
},
|
2016-01-18 03:09:14 -07:00
|
|
|
]
|
2015-02-05 07:46:06 -07:00
|
|
|
|
2015-03-10 11:26:25 -06:00
|
|
|
|
2016-02-26 07:28:19 -07:00
|
|
|
BASE_RULE_IDS = set()
|
|
|
|
|
2016-01-18 08:29:41 -07:00
|
|
|
for r in BASE_APPEND_CONTENT_RULES:
|
|
|
|
r["priority_class"] = PRIORITY_CLASS_MAP["content"]
|
|
|
|
r["default"] = True
|
2016-02-26 07:28:19 -07:00
|
|
|
BASE_RULE_IDS.add(r["rule_id"])
|
2015-03-10 11:26:25 -06:00
|
|
|
|
2016-01-18 08:29:41 -07:00
|
|
|
for r in BASE_PREPEND_OVERRIDE_RULES:
|
|
|
|
r["priority_class"] = PRIORITY_CLASS_MAP["override"]
|
|
|
|
r["default"] = True
|
2016-02-26 07:28:19 -07:00
|
|
|
BASE_RULE_IDS.add(r["rule_id"])
|
2015-04-24 07:26:33 -06:00
|
|
|
|
2016-04-08 08:29:59 -06:00
|
|
|
for r in BASE_APPEND_OVERRIDE_RULES:
|
2016-01-18 08:29:41 -07:00
|
|
|
r["priority_class"] = PRIORITY_CLASS_MAP["override"]
|
|
|
|
r["default"] = True
|
2016-02-26 07:28:19 -07:00
|
|
|
BASE_RULE_IDS.add(r["rule_id"])
|
2015-04-24 07:26:33 -06:00
|
|
|
|
2016-01-18 08:29:41 -07:00
|
|
|
for r in BASE_APPEND_UNDERRIDE_RULES:
|
|
|
|
r["priority_class"] = PRIORITY_CLASS_MAP["underride"]
|
|
|
|
r["default"] = True
|
2016-02-26 07:28:19 -07:00
|
|
|
BASE_RULE_IDS.add(r["rule_id"])
|