Don't drop messages even if database says authenticated user is not in chat

This commit is contained in:
Tulir Asokan 2019-11-13 09:36:43 +02:00
parent 3caca1b9a0
commit 14f039f5a4

View file

@ -1223,12 +1223,17 @@ func (portal *Portal) HandleMatrixMessage(sender *User, evt *mautrix.Event) {
relaybotFormatted := false relaybotFormatted := false
if sender.NeedsRelaybot(portal) { if sender.NeedsRelaybot(portal) {
if !portal.HasRelaybot() { if !portal.HasRelaybot() {
if user.HasSession() {
portal.log.Debugln("Database says", sender.MXID, "not in chat and no relaybot, but trying to send anyway")
} else {
portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot") portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot")
return return
} }
} else {
relaybotFormatted = portal.addRelaybotFormat(sender, evt) relaybotFormatted = portal.addRelaybotFormat(sender, evt)
sender = portal.bridge.Relaybot sender = portal.bridge.Relaybot
} }
}
var err error var err error
switch evt.Content.MsgType { switch evt.Content.MsgType {
case mautrix.MsgText, mautrix.MsgEmote: case mautrix.MsgText, mautrix.MsgEmote: