okay try some different things
This commit is contained in:
parent
a98ff65290
commit
a2f0042536
28
portal.go
28
portal.go
@ -190,15 +190,31 @@ type Portal struct {
|
|||||||
|
|
||||||
const MaxMessageAgeToCreatePortal = 5 * 60 // 5 minutes
|
const MaxMessageAgeToCreatePortal = 5 * 60 // 5 minutes
|
||||||
|
|
||||||
|
func (portal *Portal) syncDoublePuppetDetailsAfterCreate(source *User) {
|
||||||
|
doublePuppet := portal.bridge.GetPuppetByCustomMXID(source.MXID)
|
||||||
|
if doublePuppet == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
source.Conn.Store.ChatsLock.RLock()
|
||||||
|
chat, ok := source.Conn.Store.Chats[portal.Key.JID]
|
||||||
|
source.Conn.Store.ChatsLock.RUnlock()
|
||||||
|
if !ok {
|
||||||
|
portal.log.Debugln("Not syncing chat mute/tags with %s: chat info not found", source.MXID)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
source.syncChatDoublePuppetDetails(doublePuppet, Chat{
|
||||||
|
Chat: chat,
|
||||||
|
Portal: portal,
|
||||||
|
}, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
func (portal *Portal) handleMessageLoop() {
|
func (portal *Portal) handleMessageLoop() {
|
||||||
for msg := range portal.messages {
|
for msg := range portal.messages {
|
||||||
if len(portal.MXID) == 0 {
|
if len(portal.MXID) == 0 {
|
||||||
if msg.timestamp+MaxMessageAgeToCreatePortal < uint64(time.Now().Unix()) {
|
if msg.timestamp+MaxMessageAgeToCreatePortal < uint64(time.Now().Unix()) {
|
||||||
portal.log.Debugln("Not creating portal room for incoming message: message is too old")
|
portal.log.Debugln("Not creating portal room for incoming message: message is too old")
|
||||||
continue
|
continue
|
||||||
} else if !portal.shouldCreateRoom(msg) {
|
|
||||||
portal.log.Debugln("Not creating portal room for incoming message: message is not a chat message")
|
|
||||||
continue
|
|
||||||
}
|
}
|
||||||
portal.log.Debugln("Creating Matrix room from incoming message")
|
portal.log.Debugln("Creating Matrix room from incoming message")
|
||||||
err := portal.CreateMatrixRoom(msg.source)
|
err := portal.CreateMatrixRoom(msg.source)
|
||||||
@ -214,13 +230,13 @@ func (portal *Portal) handleMessageLoop() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) handleMessage(msg PortalMessage) {
|
func (portal *Portal) handleMessage(msg PortalMessage, isBackfill bool) {
|
||||||
if len(portal.MXID) == 0 {
|
if len(portal.MXID) == 0 {
|
||||||
portal.log.Warnln("handleMessage called even though portal.MXID is empty")
|
portal.log.Warnln("handleMessage called even though portal.MXID is empty")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
portal.HandleTextMessage(msg.source, msg.data)
|
portal.HandleTextMessage(msg.source, msg.data)
|
||||||
portal.handleReaction(msg.data.ID.String(), msg.data.FavoritedBy)
|
// portal.handleReaction(msg.data.ID.String(), msg.data.FavoritedBy)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) isRecentlyHandled(id groupme.ID) bool {
|
func (portal *Portal) isRecentlyHandled(id groupme.ID) bool {
|
||||||
@ -968,7 +984,7 @@ func (portal *Portal) CreateMatrixRoom(user *User) error {
|
|||||||
} else {
|
} else {
|
||||||
portal.log.Debugln("else: it's not a private chat")
|
portal.log.Debugln("else: it's not a private chat")
|
||||||
var err error
|
var err error
|
||||||
metadata, err = user.Conn.GetGroupMetaData(portal.Key.JID)
|
metadata, err = user.Client.ShowGroup(context.TODO(), groupme.ID(portal.Key.JID))
|
||||||
if err == nil && metadata.Status == 0 {
|
if err == nil && metadata.Status == 0 {
|
||||||
portal.Name = metadata.Name
|
portal.Name = metadata.Name
|
||||||
portal.Topic = metadata.Topic
|
portal.Topic = metadata.Topic
|
||||||
|
23
user.go
23
user.go
@ -677,6 +677,29 @@ func (user *User) getDirectChats() map[id.UserID][]id.RoomID {
|
|||||||
return res
|
return res
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (user *User) syncChatDoublePuppetDetails(doublePuppet *Puppet, chat Chat, justCreated bool) {
|
||||||
|
if doublePuppet == nil || doublePuppet.CustomIntent() == nil || len(chat.Portal.MXID) == 0 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
intent := doublePuppet.CustomIntent()
|
||||||
|
if chat.UnreadCount == 0 && (justCreated || !user.bridge.Config.Bridge.MarkReadOnlyOnCreate) {
|
||||||
|
lastMessage := user.bridge.DB.Message.GetLastInChatBefore(chat.Portal.Key, chat.ReceivedAt.Unix())
|
||||||
|
if lastMessage != nil {
|
||||||
|
err := intent.MarkReadWithContent(chat.Portal.MXID, lastMessage.MXID, &CustomReadReceipt{DoublePuppet: true})
|
||||||
|
if err != nil {
|
||||||
|
user.log.Warnfln("Failed to mark %s in %s as read after backfill: %v", lastMessage.MXID, chat.Portal.MXID, err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if chat.UnreadCount == -1 {
|
||||||
|
user.log.Debugfln("Invalid unread count (missing field?) in chat info %+v", chat.Source)
|
||||||
|
}
|
||||||
|
if justCreated || !user.bridge.Config.Bridge.TagOnlyOnCreate {
|
||||||
|
user.updateChatMute(intent, chat.Portal, chat.MutedUntil)
|
||||||
|
user.updateChatTag(intent, chat.Portal, user.bridge.Config.Bridge.ArchiveTag, chat.IsArchived)
|
||||||
|
user.updateChatTag(intent, chat.Portal, user.bridge.Config.Bridge.PinnedTag, chat.IsPinned)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (user *User) UpdateDirectChats(chats map[id.UserID][]id.RoomID) {
|
func (user *User) UpdateDirectChats(chats map[id.UserID][]id.RoomID) {
|
||||||
if !user.bridge.Config.Bridge.SyncDirectChatList {
|
if !user.bridge.Config.Bridge.SyncDirectChatList {
|
||||||
return
|
return
|
||||||
|
Loading…
Reference in New Issue
Block a user