both way sync
This commit is contained in:
parent
f1c093896e
commit
5dbace10c6
14
ROADMAP.md
14
ROADMAP.md
@ -1,12 +1,12 @@
|
|||||||
# Features & roadmap
|
# Features & roadmap
|
||||||
* Matrix → GroupMe
|
* Matrix → GroupMe
|
||||||
* [ ] Message content
|
* [ ] Message content
|
||||||
* [ ] Plain text
|
* [x] Plain text
|
||||||
* [ ] Formatted messages
|
* [ ] Formatted messages
|
||||||
* [ ] Media/files
|
* [ ] Media/files
|
||||||
* [ ] Replies
|
* [ ] Replies
|
||||||
* [ ] Message redactions
|
* [ ] Message redactions
|
||||||
* [ ] Presence
|
* [ ] Presence - N/A
|
||||||
* [ ] Typing notifications
|
* [ ] Typing notifications
|
||||||
* [ ] Read receipts
|
* [ ] Read receipts
|
||||||
* [ ] Power level
|
* [ ] Power level
|
||||||
@ -22,7 +22,7 @@
|
|||||||
* [ ] Initial room metadata
|
* [ ] Initial room metadata
|
||||||
* GroupMe → Matrix
|
* GroupMe → Matrix
|
||||||
* [ ] Message content
|
* [ ] Message content
|
||||||
* [ ] Plain text
|
* [x] Plain text
|
||||||
* [ ] Formatted messages
|
* [ ] Formatted messages
|
||||||
* [ ] Media/files
|
* [ ] Media/files
|
||||||
* [ ] Location messages
|
* [ ] Location messages
|
||||||
@ -30,9 +30,7 @@
|
|||||||
* [ ] Replies
|
* [ ] Replies
|
||||||
* [ ] Chat types
|
* [ ] Chat types
|
||||||
* [ ] Private chat
|
* [ ] Private chat
|
||||||
* [ ] Group chat
|
* [x] Group chat
|
||||||
* [ ] Broadcast list<sup>[2]</sup>
|
|
||||||
* [ ] Message deletions
|
|
||||||
* [ ] Avatars
|
* [ ] Avatars
|
||||||
* [ ] Presence
|
* [ ] Presence
|
||||||
* [ ] Typing notifications
|
* [ ] Typing notifications
|
||||||
@ -49,14 +47,14 @@
|
|||||||
* [ ] Description
|
* [ ] Description
|
||||||
* [ ] Initial group metadata
|
* [ ] Initial group metadata
|
||||||
* [ ] User metadata changes
|
* [ ] User metadata changes
|
||||||
* [ ] Display name<sup>[3]</sup>
|
* [x] Display name
|
||||||
* [ ] Avatar
|
* [ ] Avatar
|
||||||
* [ ] Initial user metadata
|
* [ ] Initial user metadata
|
||||||
* [ ] Display name
|
* [ ] Display name
|
||||||
* [ ] Avatar
|
* [ ] Avatar
|
||||||
* Misc
|
* Misc
|
||||||
* [ ] Automatic portal creation
|
* [ ] Automatic portal creation
|
||||||
* [ ] At startup
|
* [x] At startup
|
||||||
* [ ] When receiving invite
|
* [ ] When receiving invite
|
||||||
* [ ] When receiving message
|
* [ ] When receiving message
|
||||||
* [ ] Private chat creation by inviting Matrix puppet of WhatsApp user to new room
|
* [ ] Private chat creation by inviting Matrix puppet of WhatsApp user to new room
|
||||||
|
2
go.mod
2
go.mod
@ -34,5 +34,3 @@ replace github.com/Rhymen/go-whatsapp => github.com/tulir/go-whatsapp v0.3.16
|
|||||||
replace github.com/karmanyaahm/groupme => ../groupme
|
replace github.com/karmanyaahm/groupme => ../groupme
|
||||||
|
|
||||||
replace maunium.net/go/mautrix => ../mautrix
|
replace maunium.net/go/mautrix => ../mautrix
|
||||||
|
|
||||||
replace maunium.net/go/mautrix/i => ../mautrix_go/id
|
|
||||||
|
354
portal.go
354
portal.go
@ -131,7 +131,7 @@ func (bridge *Bridge) NewManualPortal(key database.PortalKey) *Portal {
|
|||||||
bridge: bridge,
|
bridge: bridge,
|
||||||
log: bridge.Log.Sub(fmt.Sprintf("Portal/%s", key)),
|
log: bridge.Log.Sub(fmt.Sprintf("Portal/%s", key)),
|
||||||
|
|
||||||
recentlyHandled: [recentlyHandledLength]groupme.ID{},
|
recentlyHandled: [recentlyHandledLength]string{},
|
||||||
|
|
||||||
messages: make(chan PortalMessage, bridge.Config.Bridge.PortalMessageBuffer),
|
messages: make(chan PortalMessage, bridge.Config.Bridge.PortalMessageBuffer),
|
||||||
}
|
}
|
||||||
@ -146,7 +146,7 @@ func (bridge *Bridge) NewPortal(dbPortal *database.Portal) *Portal {
|
|||||||
bridge: bridge,
|
bridge: bridge,
|
||||||
log: bridge.Log.Sub(fmt.Sprintf("Portal/%s", dbPortal.Key)),
|
log: bridge.Log.Sub(fmt.Sprintf("Portal/%s", dbPortal.Key)),
|
||||||
|
|
||||||
recentlyHandled: [recentlyHandledLength]groupme.ID{},
|
recentlyHandled: [recentlyHandledLength]string{},
|
||||||
|
|
||||||
messages: make(chan PortalMessage, bridge.Config.Bridge.PortalMessageBuffer),
|
messages: make(chan PortalMessage, bridge.Config.Bridge.PortalMessageBuffer),
|
||||||
}
|
}
|
||||||
@ -171,7 +171,7 @@ type Portal struct {
|
|||||||
|
|
||||||
roomCreateLock sync.Mutex
|
roomCreateLock sync.Mutex
|
||||||
|
|
||||||
recentlyHandled [recentlyHandledLength]groupme.ID
|
recentlyHandled [recentlyHandledLength]string
|
||||||
recentlyHandledLock sync.Mutex
|
recentlyHandledLock sync.Mutex
|
||||||
recentlyHandledIndex uint8
|
recentlyHandledIndex uint8
|
||||||
|
|
||||||
@ -266,8 +266,9 @@ func (portal *Portal) handleMessage(msg PortalMessage) {
|
|||||||
|
|
||||||
func (portal *Portal) isRecentlyHandled(id groupme.ID) bool {
|
func (portal *Portal) isRecentlyHandled(id groupme.ID) bool {
|
||||||
start := portal.recentlyHandledIndex
|
start := portal.recentlyHandledIndex
|
||||||
for i := start; i != start; i = (i - 1) % recentlyHandledLength {
|
idStr := id.String()
|
||||||
if portal.recentlyHandled[i] == id {
|
for i := (start - 1) % recentlyHandledLength; i != start; i = (i - 1) % recentlyHandledLength {
|
||||||
|
if portal.recentlyHandled[i] == idStr {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -279,6 +280,7 @@ func (portal *Portal) isDuplicate(id groupme.ID) bool {
|
|||||||
if msg != nil {
|
if msg != nil {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +289,6 @@ func init() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) markHandled(source *User, message *groupme.Message, mxid id.EventID) {
|
func (portal *Portal) markHandled(source *User, message *groupme.Message, mxid id.EventID) {
|
||||||
print("handle message")
|
|
||||||
msg := portal.bridge.DB.Message.New()
|
msg := portal.bridge.DB.Message.New()
|
||||||
msg.Chat = portal.Key
|
msg.Chat = portal.Key
|
||||||
msg.JID = message.ID.String()
|
msg.JID = message.ID.String()
|
||||||
@ -311,7 +312,7 @@ func (portal *Portal) markHandled(source *User, message *groupme.Message, mxid i
|
|||||||
index := portal.recentlyHandledIndex
|
index := portal.recentlyHandledIndex
|
||||||
portal.recentlyHandledIndex = (portal.recentlyHandledIndex + 1) % recentlyHandledLength
|
portal.recentlyHandledIndex = (portal.recentlyHandledIndex + 1) % recentlyHandledLength
|
||||||
portal.recentlyHandledLock.Unlock()
|
portal.recentlyHandledLock.Unlock()
|
||||||
portal.recentlyHandled[index] = groupme.ID(msg.JID)
|
portal.recentlyHandled[index] = message.ID.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) getMessageIntent(user *User, info *groupme.Message) *appservice.IntentAPI {
|
func (portal *Portal) getMessageIntent(user *User, info *groupme.Message) *appservice.IntentAPI {
|
||||||
@ -704,7 +705,6 @@ func (portal *Portal) BackfillHistory(user *User, lastMessageTime uint64) error
|
|||||||
endBackfill := portal.beginBackfill()
|
endBackfill := portal.beginBackfill()
|
||||||
defer endBackfill()
|
defer endBackfill()
|
||||||
|
|
||||||
println("hi")
|
|
||||||
lastMessage := portal.bridge.DB.Message.GetLastInChat(portal.Key)
|
lastMessage := portal.bridge.DB.Message.GetLastInChat(portal.Key)
|
||||||
fmt.Println(lastMessage)
|
fmt.Println(lastMessage)
|
||||||
if lastMessage == nil {
|
if lastMessage == nil {
|
||||||
@ -1239,7 +1239,7 @@ func (portal *Portal) sendMessageDirect(intent *appservice.IntentAPI, eventType
|
|||||||
if timestamp == 0 {
|
if timestamp == 0 {
|
||||||
return intent.SendMessageEvent(portal.MXID, eventType, &wrappedContent)
|
return intent.SendMessageEvent(portal.MXID, eventType, &wrappedContent)
|
||||||
} else {
|
} else {
|
||||||
return intent.SendMassagedMessageEvent(portal.MXID, eventType, &wrappedContent, timestamp)
|
return intent.SendMassagedMessageEvent(portal.MXID, eventType, &wrappedContent, timestamp*1000) //milliseconds
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1259,7 +1259,7 @@ func (portal *Portal) HandleTextMessage(source *User, message *groupme.Message)
|
|||||||
//TODO: mentions
|
//TODO: mentions
|
||||||
|
|
||||||
_, _ = intent.UserTyping(portal.MXID, false, 0)
|
_, _ = intent.UserTyping(portal.MXID, false, 0)
|
||||||
resp, err := portal.sendMessage(intent, event.EventMessage, content, message.CreatedAt.ToTime().UnixNano())
|
resp, err := portal.sendMessage(intent, event.EventMessage, content, message.CreatedAt.ToTime().Unix())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
portal.log.Errorfln("Failed to handle message %s: %v", message.ID, err)
|
portal.log.Errorfln("Failed to handle message %s: %v", message.ID, err)
|
||||||
return
|
return
|
||||||
@ -1835,151 +1835,157 @@ func (portal *Portal) addRelaybotFormat(sender *User, content *event.MessageEven
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) (*groupme.Message, *User) {
|
func (portal *Portal) convertMatrixMessage(sender *User, evt *event.Event) ([]*groupme.Message, *User) {
|
||||||
print("convertMatrixMessage")
|
content, ok := evt.Content.Parsed.(*event.MessageEventContent)
|
||||||
return nil, nil
|
if !ok {
|
||||||
// content, ok := evt.Content.Parsed.(*event.MessageEventContent)
|
portal.log.Debugfln("Failed to handle event %s: unexpected parsed content type %T", evt.ID, evt.Content.Parsed)
|
||||||
// if !ok {
|
return nil, sender
|
||||||
// portal.log.Debugfln("Failed to handle event %s: unexpected parsed content type %T", evt.ID, evt.Content.Parsed)
|
}
|
||||||
// return nil, sender
|
|
||||||
// }
|
|
||||||
|
|
||||||
// ts := uint64(evt.Timestamp / 1000)
|
//ts := uint64(evt.Timestamp / 1000)
|
||||||
// status := waProto.WebMessageInfo_ERROR
|
//status := waProto.WebMessageInfo_ERROR
|
||||||
// fromMe := true
|
//fromMe := true
|
||||||
// info := &waProto.WebMessageInfo{
|
// info := &waProto.WebMessageInfo{
|
||||||
// Key: &waProto.MessageKey{
|
// Key: &waProto.MessageKey{
|
||||||
// FromMe: &fromMe,
|
// FromMe: &fromMe,
|
||||||
// Id: makeMessageID(),
|
// Id: makeMessageID(),
|
||||||
// RemoteJid: &portal.Key.JID,
|
// RemoteJid: &portal.Key.JID,
|
||||||
// },
|
// },
|
||||||
// MessageTimestamp: &ts,
|
// MessageTimestamp: &ts,
|
||||||
// Message: &waProto.Message{},
|
// Message: &waProto.Message{},
|
||||||
// Status: &status,
|
// Status: &status,
|
||||||
// }
|
// }
|
||||||
// ctxInfo := &waProto.ContextInfo{}
|
//
|
||||||
// replyToID := content.GetReplyTo()
|
info := groupme.Message{
|
||||||
// if len(replyToID) > 0 {
|
SourceGUID: evt.ID.String(), //TODO Figure out for multiple messages
|
||||||
// content.RemoveReplyFallback()
|
GroupID: groupme.ID(portal.Key.JID),
|
||||||
// msg := portal.bridge.DB.Message.GetByMXID(replyToID)
|
}
|
||||||
// if msg != nil && msg.Content != nil {
|
replyToID := content.GetReplyTo()
|
||||||
// ctxInfo.StanzaId = &msg.JID
|
if len(replyToID) > 0 {
|
||||||
// ctxInfo.Participant = &msg.Sender
|
// content.RemoveReplyFallback()
|
||||||
// ctxInfo.QuotedMessage = msg.Content
|
// msg := portal.bridge.DB.Message.GetByMXID(replyToID)
|
||||||
// }
|
// if msg != nil && msg.Content != nil {
|
||||||
// }
|
// ctxInfo.StanzaId = &msg.JID
|
||||||
// relaybotFormatted := false
|
// ctxInfo.Participant = &msg.Sender
|
||||||
// if sender.NeedsRelaybot(portal) {
|
// ctxInfo.QuotedMessage = msg.Content
|
||||||
// if !portal.HasRelaybot() {
|
// }
|
||||||
// if sender.HasSession() {
|
}
|
||||||
// portal.log.Debugln("Database says", sender.MXID, "not in chat and no relaybot, but trying to send anyway")
|
relaybotFormatted := false
|
||||||
// } else {
|
if sender.NeedsRelaybot(portal) {
|
||||||
// portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot")
|
if !portal.HasRelaybot() {
|
||||||
// return nil, sender
|
if sender.HasSession() {
|
||||||
// }
|
portal.log.Debugln("Database says", sender.MXID, "not in chat and no relaybot, but trying to send anyway")
|
||||||
// } else {
|
} else {
|
||||||
// relaybotFormatted = portal.addRelaybotFormat(sender, content)
|
portal.log.Debugln("Ignoring message from", sender.MXID, "in chat with no relaybot")
|
||||||
// sender = portal.bridge.Relaybot
|
return nil, sender
|
||||||
// }
|
}
|
||||||
// }
|
} else {
|
||||||
// if evt.Type == event.EventSticker {
|
relaybotFormatted = portal.addRelaybotFormat(sender, content)
|
||||||
// content.MsgType = event.MsgImage
|
sender = portal.bridge.Relaybot
|
||||||
// } else if content.MsgType == event.MsgImage && content.GetInfo().MimeType == "image/gif" {
|
}
|
||||||
// content.MsgType = event.MsgVideo
|
}
|
||||||
// }
|
if evt.Type == event.EventSticker {
|
||||||
|
content.MsgType = event.MsgImage
|
||||||
|
} else if content.MsgType == event.MsgImage && content.GetInfo().MimeType == "image/gif" {
|
||||||
|
content.MsgType = event.MsgVideo
|
||||||
|
}
|
||||||
|
|
||||||
// switch content.MsgType {
|
switch content.MsgType {
|
||||||
// case event.MsgText, event.MsgEmote, event.MsgNotice:
|
case event.MsgText, event.MsgEmote, event.MsgNotice:
|
||||||
// text := content.Body
|
text := content.Body
|
||||||
// if content.Format == event.FormatHTML {
|
if content.Format == event.FormatHTML {
|
||||||
// text, ctxInfo.MentionedJid = portal.bridge.Formatter.ParseMatrix(content.FormattedBody)
|
text, _ = portal.bridge.Formatter.ParseMatrix(content.FormattedBody)
|
||||||
// }
|
//TODO mentions
|
||||||
// if content.MsgType == event.MsgEmote && !relaybotFormatted {
|
}
|
||||||
// text = "/me " + text
|
if content.MsgType == event.MsgEmote && !relaybotFormatted {
|
||||||
// }
|
text = "/me " + text
|
||||||
// if ctxInfo.StanzaId != nil || ctxInfo.MentionedJid != nil {
|
}
|
||||||
// info.Message.ExtendedTextMessage = &waProto.ExtendedTextMessage{
|
info.Text = text
|
||||||
// Text: &text,
|
|
||||||
// ContextInfo: ctxInfo,
|
// if ctxInfo.StanzaId != nil || ctxInfo.MentionedJid != nil {
|
||||||
// }
|
// info.Message.ExtendedTextMessage = &waProto.ExtendedTextMessage{
|
||||||
// } else {
|
// Text: &text,
|
||||||
// info.Message.Conversation = &text
|
// ContextInfo: ctxInfo,
|
||||||
// }
|
// }
|
||||||
// case event.MsgImage:
|
|
||||||
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaImage)
|
|
||||||
// if media == nil {
|
|
||||||
// return nil, sender
|
|
||||||
// }
|
|
||||||
// ctxInfo.MentionedJid = media.MentionedJIDs
|
|
||||||
// info.Message.ImageMessage = &waProto.ImageMessage{
|
|
||||||
// ContextInfo: ctxInfo,
|
|
||||||
// Caption: &media.Caption,
|
|
||||||
// JpegThumbnail: media.Thumbnail,
|
|
||||||
// Url: &media.URL,
|
|
||||||
// MediaKey: media.MediaKey,
|
|
||||||
// Mimetype: &content.GetInfo().MimeType,
|
|
||||||
// FileEncSha256: media.FileEncSHA256,
|
|
||||||
// FileSha256: media.FileSHA256,
|
|
||||||
// FileLength: &media.FileLength,
|
|
||||||
// }
|
|
||||||
// case event.MsgVideo:
|
|
||||||
// gifPlayback := content.GetInfo().MimeType == "image/gif"
|
|
||||||
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaVideo)
|
|
||||||
// if media == nil {
|
|
||||||
// return nil, sender
|
|
||||||
// }
|
|
||||||
// duration := uint32(content.GetInfo().Duration)
|
|
||||||
// ctxInfo.MentionedJid = media.MentionedJIDs
|
|
||||||
// info.Message.VideoMessage = &waProto.VideoMessage{
|
|
||||||
// ContextInfo: ctxInfo,
|
|
||||||
// Caption: &media.Caption,
|
|
||||||
// JpegThumbnail: media.Thumbnail,
|
|
||||||
// Url: &media.URL,
|
|
||||||
// MediaKey: media.MediaKey,
|
|
||||||
// Mimetype: &content.GetInfo().MimeType,
|
|
||||||
// GifPlayback: &gifPlayback,
|
|
||||||
// Seconds: &duration,
|
|
||||||
// FileEncSha256: media.FileEncSHA256,
|
|
||||||
// FileSha256: media.FileSHA256,
|
|
||||||
// FileLength: &media.FileLength,
|
|
||||||
// }
|
|
||||||
// case event.MsgAudio:
|
|
||||||
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaAudio)
|
|
||||||
// if media == nil {
|
|
||||||
// return nil, sender
|
|
||||||
// }
|
|
||||||
// duration := uint32(content.GetInfo().Duration)
|
|
||||||
// info.Message.AudioMessage = &waProto.AudioMessage{
|
|
||||||
// ContextInfo: ctxInfo,
|
|
||||||
// Url: &media.URL,
|
|
||||||
// MediaKey: media.MediaKey,
|
|
||||||
// Mimetype: &content.GetInfo().MimeType,
|
|
||||||
// Seconds: &duration,
|
|
||||||
// FileEncSha256: media.FileEncSHA256,
|
|
||||||
// FileSha256: media.FileSHA256,
|
|
||||||
// FileLength: &media.FileLength,
|
|
||||||
// }
|
|
||||||
// case event.MsgFile:
|
|
||||||
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaDocument)
|
|
||||||
// if media == nil {
|
|
||||||
// return nil, sender
|
|
||||||
// }
|
|
||||||
// info.Message.DocumentMessage = &waProto.DocumentMessage{
|
|
||||||
// ContextInfo: ctxInfo,
|
|
||||||
// Url: &media.URL,
|
|
||||||
// Title: &content.Body,
|
|
||||||
// FileName: &content.Body,
|
|
||||||
// MediaKey: media.MediaKey,
|
|
||||||
// Mimetype: &content.GetInfo().MimeType,
|
|
||||||
// FileEncSha256: media.FileEncSHA256,
|
|
||||||
// FileSha256: media.FileSHA256,
|
|
||||||
// FileLength: &media.FileLength,
|
|
||||||
// }
|
|
||||||
// default:
|
|
||||||
// portal.log.Debugln("Unhandled Matrix event %s: unknown msgtype %s", evt.ID, content.MsgType)
|
|
||||||
// return nil, sender
|
|
||||||
// }
|
// }
|
||||||
// return info, sender
|
//else {
|
||||||
|
// info.Message.Conversation = &text
|
||||||
|
// }
|
||||||
|
// case event.MsgImage:
|
||||||
|
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaImage)
|
||||||
|
// if media == nil {
|
||||||
|
// return nil, sender
|
||||||
|
// }
|
||||||
|
// ctxInfo.MentionedJid = media.MentionedJIDs
|
||||||
|
// info.Message.ImageMessage = &waProto.ImageMessage{
|
||||||
|
// ContextInfo: ctxInfo,
|
||||||
|
// Caption: &media.Caption,
|
||||||
|
// JpegThumbnail: media.Thumbnail,
|
||||||
|
// Url: &media.URL,
|
||||||
|
// MediaKey: media.MediaKey,
|
||||||
|
// Mimetype: &content.GetInfo().MimeType,
|
||||||
|
// FileEncSha256: media.FileEncSHA256,
|
||||||
|
// FileSha256: media.FileSHA256,
|
||||||
|
// FileLength: &media.FileLength,
|
||||||
|
// }
|
||||||
|
// case event.MsgVideo:
|
||||||
|
// gifPlayback := content.GetInfo().MimeType == "image/gif"
|
||||||
|
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaVideo)
|
||||||
|
// if media == nil {
|
||||||
|
// return nil, sender
|
||||||
|
// }
|
||||||
|
// duration := uint32(content.GetInfo().Duration)
|
||||||
|
// ctxInfo.MentionedJid = media.MentionedJIDs
|
||||||
|
// info.Message.VideoMessage = &waProto.VideoMessage{
|
||||||
|
// ContextInfo: ctxInfo,
|
||||||
|
// Caption: &media.Caption,
|
||||||
|
// JpegThumbnail: media.Thumbnail,
|
||||||
|
// Url: &media.URL,
|
||||||
|
// MediaKey: media.MediaKey,
|
||||||
|
// Mimetype: &content.GetInfo().MimeType,
|
||||||
|
// GifPlayback: &gifPlayback,
|
||||||
|
// Seconds: &duration,
|
||||||
|
// FileEncSha256: media.FileEncSHA256,
|
||||||
|
// FileSha256: media.FileSHA256,
|
||||||
|
// FileLength: &media.FileLength,
|
||||||
|
// }
|
||||||
|
// case event.MsgAudio:
|
||||||
|
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaAudio)
|
||||||
|
// if media == nil {
|
||||||
|
// return nil, sender
|
||||||
|
// }
|
||||||
|
// duration := uint32(content.GetInfo().Duration)
|
||||||
|
// info.Message.AudioMessage = &waProto.AudioMessage{
|
||||||
|
// ContextInfo: ctxInfo,
|
||||||
|
// Url: &media.URL,
|
||||||
|
// MediaKey: media.MediaKey,
|
||||||
|
// Mimetype: &content.GetInfo().MimeType,
|
||||||
|
// Seconds: &duration,
|
||||||
|
// FileEncSha256: media.FileEncSHA256,
|
||||||
|
// FileSha256: media.FileSHA256,
|
||||||
|
// FileLength: &media.FileLength,
|
||||||
|
// }
|
||||||
|
// case event.MsgFile:
|
||||||
|
// media := portal.preprocessMatrixMedia(sender, relaybotFormatted, content, evt.ID, whatsapp.MediaDocument)
|
||||||
|
// if media == nil {
|
||||||
|
// return nil, sender
|
||||||
|
// }
|
||||||
|
// info.Message.DocumentMessage = &waProto.DocumentMessage{
|
||||||
|
// ContextInfo: ctxInfo,
|
||||||
|
// Url: &media.URL,
|
||||||
|
// Title: &content.Body,
|
||||||
|
// FileName: &content.Body,
|
||||||
|
// MediaKey: media.MediaKey,
|
||||||
|
// Mimetype: &content.GetInfo().MimeType,
|
||||||
|
// FileEncSha256: media.FileEncSHA256,
|
||||||
|
// FileSha256: media.FileSHA256,
|
||||||
|
// FileLength: &media.FileLength,
|
||||||
|
// }
|
||||||
|
default:
|
||||||
|
portal.log.Debugln("Unhandled Matrix event %s: unknown msgtype %s", evt.ID, content.MsgType)
|
||||||
|
return nil, sender
|
||||||
|
}
|
||||||
|
return []*groupme.Message{&info}, sender
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) wasMessageSent(sender *User, id string) bool {
|
func (portal *Portal) wasMessageSent(sender *User, id string) bool {
|
||||||
@ -2017,23 +2023,37 @@ func (portal *Portal) sendDeliveryReceipt(eventID id.EventID) {
|
|||||||
var timeout = errors.New("message sending timed out")
|
var timeout = errors.New("message sending timed out")
|
||||||
|
|
||||||
func (portal *Portal) HandleMatrixMessage(sender *User, evt *event.Event) {
|
func (portal *Portal) HandleMatrixMessage(sender *User, evt *event.Event) {
|
||||||
println("handle matrix message")
|
if !portal.HasRelaybot() && ((portal.IsPrivateChat() && sender.JID != portal.Key.Receiver) ||
|
||||||
return
|
portal.sendMatrixConnectionError(sender, evt.ID)) {
|
||||||
// if !portal.HasRelaybot() && ((portal.IsPrivateChat() && sender.JID != portal.Key.Receiver) ||
|
return
|
||||||
// portal.sendMatrixConnectionError(sender, evt.ID)) {
|
}
|
||||||
// return
|
portal.log.Debugfln("Received event %s", evt.ID)
|
||||||
// }
|
info, sender := portal.convertMatrixMessage(sender, evt)
|
||||||
// portal.log.Debugfln("Received event %s", evt.ID)
|
if info == nil {
|
||||||
// info, sender := portal.convertMatrixMessage(sender, evt)
|
return
|
||||||
// if info == nil {
|
}
|
||||||
// return
|
for _, i := range info {
|
||||||
// }
|
portal.log.Debugln("Sending event", evt.ID, "to WhatsApp", info[0].ID)
|
||||||
// portal.markHandled(sender, info, evt.ID)
|
i = portal.sendRaw(sender, evt, info[0], false) //TODO deal with multiple messages for longer messages
|
||||||
// portal.log.Debugln("Sending event", evt.ID, "to WhatsApp", info.ID)
|
portal.markHandled(sender, i, evt.ID)
|
||||||
// portal.sendRaw(sender, evt, info, false)
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (portal *Portal) sendRaw(sender *User, evt *event.Event, info *waProto.WebMessageInfo, isRetry bool) {
|
func (portal *Portal) sendRaw(sender *User, evt *event.Event, info *groupme.Message, isRetry bool) *groupme.Message {
|
||||||
|
|
||||||
|
m, err := sender.Client.CreateMessage(context.TODO(), info.GroupID, info)
|
||||||
|
id := ""
|
||||||
|
if m != nil {
|
||||||
|
id = m.ID.String()
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
portal.log.Warnln(err, id, info.GroupID.String())
|
||||||
|
}
|
||||||
|
if isRetry && err != nil {
|
||||||
|
m, err = sender.Client.CreateMessage(context.TODO(), info.GroupID, info)
|
||||||
|
}
|
||||||
|
return m
|
||||||
// errChan := make(chan error, 1)
|
// errChan := make(chan error, 1)
|
||||||
// go sender.Conn.SendRaw(info, errChan)
|
// go sender.Conn.SendRaw(info, errChan)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user