2019-08-26 19:00:31 +00:00
|
|
|
package bkeybase
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strconv"
|
|
|
|
|
|
|
|
"github.com/42wim/matterbridge/bridge/config"
|
2020-02-08 15:50:53 +00:00
|
|
|
"github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1"
|
2019-08-26 19:00:31 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func (b *Bkeybase) handleKeybase() {
|
|
|
|
sub, err := b.kbc.ListenForNewTextMessages()
|
|
|
|
if err != nil {
|
|
|
|
b.Log.Errorf("Error listening: %s", err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
for {
|
|
|
|
msg, err := sub.Read()
|
|
|
|
if err != nil {
|
|
|
|
b.Log.Errorf("failed to read message: %s", err.Error())
|
|
|
|
}
|
|
|
|
|
2020-02-08 15:50:53 +00:00
|
|
|
if msg.Message.Content.TypeName != "text" {
|
2019-08-26 19:00:31 +00:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if msg.Message.Sender.Username == b.kbc.GetUsername() {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
b.handleMessage(msg.Message)
|
|
|
|
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|
|
|
|
|
2020-02-08 15:50:53 +00:00
|
|
|
func (b *Bkeybase) handleMessage(msg chat1.MsgSummary) {
|
2019-08-26 19:00:31 +00:00
|
|
|
b.Log.Debugf("== Receiving event: %#v", msg)
|
|
|
|
if msg.Channel.TopicName != b.channel || msg.Channel.Name != b.team {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if msg.Sender.Username != b.kbc.GetUsername() {
|
|
|
|
|
|
|
|
// TODO download avatar
|
|
|
|
|
|
|
|
// Create our message
|
2020-02-08 15:50:53 +00:00
|
|
|
rmsg := config.Message{Username: msg.Sender.Username, Text: msg.Content.Text.Body, UserID: string(msg.Sender.Uid), Channel: msg.Channel.TopicName, ID: strconv.Itoa(int(msg.Id)), Account: b.Account}
|
2019-08-26 19:00:31 +00:00
|
|
|
|
|
|
|
// Text must be a string
|
2020-02-08 15:50:53 +00:00
|
|
|
if msg.Content.TypeName != "text" {
|
2019-08-26 19:00:31 +00:00
|
|
|
b.Log.Errorf("message is not text")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
b.Log.Debugf("<= Sending message from %s on %s to gateway", msg.Sender.Username, msg.Channel.Name)
|
|
|
|
b.Remote <- rmsg
|
|
|
|
}
|
|
|
|
}
|