Fix more places where lids aren't ignored

This commit is contained in:
Tulir Asokan 2023-08-13 00:54:51 +03:00
parent 32d26ec0ab
commit 205d4e651b

View file

@ -640,7 +640,7 @@ func (portal *Portal) UpdateGroupDisappearingMessages(sender *types.JID, timesta
portal.ExpirationTime = timer portal.ExpirationTime = timer
portal.Update(nil) portal.Update(nil)
intent := portal.MainIntent() intent := portal.MainIntent()
if sender != nil { if sender != nil && sender.Server == types.DefaultUserServer {
intent = portal.bridge.GetPuppetByJID(sender.ToNonAD()).IntentFor(portal) intent = portal.bridge.GetPuppetByJID(sender.ToNonAD()).IntentFor(portal)
} else { } else {
sender = &types.EmptyJID sender = &types.EmptyJID
@ -2766,6 +2766,10 @@ func (portal *Portal) HandleWhatsAppKick(source *User, senderJID types.JID, jids
sender := portal.bridge.GetPuppetByJID(senderJID) sender := portal.bridge.GetPuppetByJID(senderJID)
senderIntent := sender.IntentFor(portal) senderIntent := sender.IntentFor(portal)
for _, jid := range jids { for _, jid := range jids {
if jid.Server != types.DefaultUserServer {
// TODO handle lids
continue
}
//if source != nil && source.JID.User == jid.User { //if source != nil && source.JID.User == jid.User {
// portal.log.Debugln("Ignoring self-kick by", source.MXID) // portal.log.Debugln("Ignoring self-kick by", source.MXID)
// continue // continue
@ -2793,6 +2797,10 @@ func (portal *Portal) HandleWhatsAppInvite(source *User, senderJID *types.JID, j
intent = sender.IntentFor(portal) intent = sender.IntentFor(portal)
} }
for _, jid := range jids { for _, jid := range jids {
if jid.Server != types.DefaultUserServer {
// TODO handle lids
continue
}
puppet := portal.bridge.GetPuppetByJID(jid) puppet := portal.bridge.GetPuppetByJID(jid)
puppet.SyncContact(source, true, false, "handling whatsapp invite") puppet.SyncContact(source, true, false, "handling whatsapp invite")
resp, err := intent.SendStateEvent(portal.MXID, event.StateMember, puppet.MXID.String(), &event.MemberEventContent{ resp, err := intent.SendStateEvent(portal.MXID, event.StateMember, puppet.MXID.String(), &event.MemberEventContent{