2015-12-10 11:26:08 -05:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright 2015 OpenMarket Ltd
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
|
|
|
from twisted.internet import defer
|
|
|
|
|
2015-12-21 10:28:54 -05:00
|
|
|
from synapse.types import UserID
|
|
|
|
|
2015-12-10 11:26:08 -05:00
|
|
|
import push_rule_evaluator
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class ActionGenerator:
|
2015-12-21 10:28:54 -05:00
|
|
|
def __init__(self, hs, store):
|
|
|
|
self.hs = hs
|
2015-12-10 11:26:08 -05:00
|
|
|
self.store = store
|
|
|
|
# really we want to get all user ids and all profile tags too,
|
|
|
|
# since we want the actions for each profile tag for every user and
|
|
|
|
# also actions for a client with no profile tag for each user.
|
|
|
|
# Currently the event stream doesn't support profile tags on an
|
|
|
|
# event stream, so we just run the rules for a client with no profile
|
|
|
|
# tag (ie. we just need all the users).
|
|
|
|
|
|
|
|
@defer.inlineCallbacks
|
|
|
|
def handle_event(self, event):
|
|
|
|
users = yield self.store.get_users_in_room(event['room_id'])
|
|
|
|
|
|
|
|
for uid in users:
|
2015-12-21 10:28:54 -05:00
|
|
|
if not self.hs.is_mine(UserID.from_string(uid)):
|
|
|
|
continue
|
|
|
|
|
2015-12-10 11:26:08 -05:00
|
|
|
evaluator = yield push_rule_evaluator.\
|
|
|
|
evaluator_for_user_name_and_profile_tag(
|
|
|
|
uid, None, event['room_id'], self.store
|
2015-12-10 12:51:15 -05:00
|
|
|
)
|
2015-12-10 11:26:08 -05:00
|
|
|
actions = yield evaluator.actions_for_event(event)
|
|
|
|
logger.info("actions for user %s: %s", uid, actions)
|
2015-12-10 13:40:28 -05:00
|
|
|
if len(actions):
|
|
|
|
self.store.set_actions_for_event(
|
2015-12-16 13:42:09 -05:00
|
|
|
event, uid, None, actions
|
2015-12-10 13:40:28 -05:00
|
|
|
)
|