42wim/matterbridge

View on GitHub
bridge/keybase/handlers.go

Summary

Maintainability
A
0 mins
Test Coverage
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
    }
}