60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
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
 | 
						|
	}
 | 
						|
}
 |