2014-08-12 16:10:52 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2014-09-03 18:29:13 +02:00
|
|
|
# Copyright 2014 OpenMarket Ltd
|
2014-08-12 16:10:52 +02: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.
|
2014-08-13 04:14:34 +02:00
|
|
|
|
2014-08-26 18:49:46 +02:00
|
|
|
from synapse.api.constants import Feedback, Membership
|
2014-08-26 10:26:07 +02:00
|
|
|
from synapse.api.errors import SynapseError
|
2014-08-28 11:59:15 +02:00
|
|
|
from . import SynapseEvent, SynapseStateEvent
|
2014-08-12 16:10:52 +02:00
|
|
|
|
|
|
|
|
2014-08-15 17:06:08 +02:00
|
|
|
class GenericEvent(SynapseEvent):
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
|
|
|
|
2014-08-15 17:17:36 +02:00
|
|
|
|
2014-08-12 16:10:52 +02:00
|
|
|
class RoomTopicEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.topic"
|
|
|
|
|
2014-08-15 11:26:35 +02:00
|
|
|
internal_keys = SynapseEvent.internal_keys + [
|
|
|
|
"topic",
|
|
|
|
]
|
|
|
|
|
2014-08-12 16:10:52 +02:00
|
|
|
def __init__(self, **kwargs):
|
|
|
|
kwargs["state_key"] = ""
|
2014-08-15 11:26:35 +02:00
|
|
|
if "topic" in kwargs["content"]:
|
|
|
|
kwargs["topic"] = kwargs["content"]["topic"]
|
2014-08-12 16:10:52 +02:00
|
|
|
super(RoomTopicEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {"topic": u"string"}
|
|
|
|
|
|
|
|
|
2014-08-15 11:26:35 +02:00
|
|
|
class RoomNameEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.name"
|
|
|
|
|
|
|
|
internal_keys = SynapseEvent.internal_keys + [
|
|
|
|
"name",
|
|
|
|
]
|
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
kwargs["state_key"] = ""
|
|
|
|
if "name" in kwargs["content"]:
|
|
|
|
kwargs["name"] = kwargs["content"]["name"]
|
|
|
|
super(RoomNameEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {"name": u"string"}
|
|
|
|
|
|
|
|
|
2014-08-12 16:10:52 +02:00
|
|
|
class RoomMemberEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.member"
|
|
|
|
|
|
|
|
valid_keys = SynapseEvent.valid_keys + [
|
2014-08-26 10:26:07 +02:00
|
|
|
# target is the state_key
|
2014-08-12 16:10:52 +02:00
|
|
|
"membership", # action
|
|
|
|
]
|
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
2014-08-18 11:59:57 +02:00
|
|
|
if "membership" not in kwargs:
|
|
|
|
kwargs["membership"] = kwargs.get("content", {}).get("membership")
|
2014-08-26 10:26:07 +02:00
|
|
|
if not kwargs["membership"] in Membership.LIST:
|
|
|
|
raise SynapseError(400, "Bad membership value.")
|
2014-08-12 16:10:52 +02:00
|
|
|
super(RoomMemberEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {"membership": u"string"}
|
|
|
|
|
|
|
|
|
|
|
|
class MessageEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.message"
|
|
|
|
|
|
|
|
valid_keys = SynapseEvent.valid_keys + [
|
|
|
|
"msg_id", # unique per room + user combo
|
|
|
|
]
|
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(MessageEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {"msgtype": u"string"}
|
|
|
|
|
|
|
|
|
|
|
|
class FeedbackEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.message.feedback"
|
|
|
|
|
2014-08-26 18:49:46 +02:00
|
|
|
valid_keys = SynapseEvent.valid_keys
|
2014-08-12 16:10:52 +02:00
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(FeedbackEvent, self).__init__(**kwargs)
|
2014-08-26 18:49:46 +02:00
|
|
|
if not kwargs["content"]["type"] in Feedback.LIST:
|
|
|
|
raise SynapseError(400, "Bad feedback value.")
|
2014-08-12 16:10:52 +02:00
|
|
|
|
|
|
|
def get_content_template(self):
|
2014-08-26 18:49:46 +02:00
|
|
|
return {
|
|
|
|
"type": u"string",
|
2014-09-03 14:08:17 +02:00
|
|
|
"target_event_id": u"string"
|
2014-08-26 18:49:46 +02:00
|
|
|
}
|
2014-08-12 16:10:52 +02:00
|
|
|
|
|
|
|
|
|
|
|
class InviteJoinEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.invite_join"
|
|
|
|
|
|
|
|
valid_keys = SynapseEvent.valid_keys + [
|
2014-08-26 10:26:07 +02:00
|
|
|
# target_user_id is the state_key
|
2014-08-12 16:10:52 +02:00
|
|
|
"target_host",
|
|
|
|
]
|
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
super(InviteJoinEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
|
|
|
|
|
|
|
|
|
|
|
class RoomConfigEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.config"
|
|
|
|
|
|
|
|
def __init__(self, **kwargs):
|
|
|
|
kwargs["state_key"] = ""
|
|
|
|
super(RoomConfigEvent, self).__init__(**kwargs)
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
2014-08-28 11:59:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
class RoomCreateEvent(SynapseStateEvent):
|
|
|
|
TYPE = "m.room.create"
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
|
|
|
|
|
|
|
|
|
|
|
class RoomJoinRulesEvent(SynapseStateEvent):
|
|
|
|
TYPE = "m.room.join_rules"
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
|
|
|
|
|
|
|
|
|
|
|
class RoomPowerLevelsEvent(SynapseStateEvent):
|
|
|
|
TYPE = "m.room.power_levels"
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
|
|
|
|
2014-11-10 14:46:44 +01:00
|
|
|
|
2014-09-05 22:35:56 +02:00
|
|
|
class RoomAliasesEvent(SynapseStateEvent):
|
|
|
|
TYPE = "m.room.aliases"
|
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|
2014-09-23 16:28:32 +02:00
|
|
|
|
|
|
|
|
2014-09-24 16:27:59 +02:00
|
|
|
class RoomRedactionEvent(SynapseEvent):
|
|
|
|
TYPE = "m.room.redaction"
|
2014-09-23 16:28:32 +02:00
|
|
|
|
2014-09-24 16:27:59 +02:00
|
|
|
valid_keys = SynapseEvent.valid_keys + ["redacts"]
|
2014-09-23 16:28:32 +02:00
|
|
|
|
|
|
|
def get_content_template(self):
|
|
|
|
return {}
|