summaryrefslogtreecommitdiff
path: root/teleirc/matterbridge/bridge/keybase/handlers.go
diff options
context:
space:
mode:
Diffstat (limited to 'teleirc/matterbridge/bridge/keybase/handlers.go')
-rw-r--r--teleirc/matterbridge/bridge/keybase/handlers.go59
1 files changed, 59 insertions, 0 deletions
diff --git a/teleirc/matterbridge/bridge/keybase/handlers.go b/teleirc/matterbridge/bridge/keybase/handlers.go
new file mode 100644
index 0000000..a29208d
--- /dev/null
+++ b/teleirc/matterbridge/bridge/keybase/handlers.go
@@ -0,0 +1,59 @@
+package bkeybase
+
+import (
+ "strconv"
+
+ "github.com/42wim/matterbridge/bridge/config"
+ "github.com/keybase/go-keybase-chat-bot/kbchat/types/chat1"
+)
+
+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())
+ }
+
+ if msg.Message.Content.TypeName != "text" {
+ continue
+ }
+
+ if msg.Message.Sender.Username == b.kbc.GetUsername() {
+ continue
+ }
+
+ b.handleMessage(msg.Message)
+
+ }
+ }()
+}
+
+func (b *Bkeybase) handleMessage(msg chat1.MsgSummary) {
+ 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
+ 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}
+
+ // Text must be a string
+ if msg.Content.TypeName != "text" {
+ 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
+ }
+}