diff options
author | Wim <wim@42.be> | 2017-12-03 01:29:25 +0100 |
---|---|---|
committer | Wim <wim@42.be> | 2017-12-03 01:29:25 +0100 |
commit | 67a9d133e9cfef9317b3950383b6a48680998905 (patch) | |
tree | 7bd11118c066efca7965bc593ba6547e35c73114 /bridge/sshchat/sshchat.go | |
parent | ed9118b34620f1ecd5f28506328d4ffe1b04793d (diff) | |
download | matterbridge-msglm-67a9d133e9cfef9317b3950383b6a48680998905.tar.gz matterbridge-msglm-67a9d133e9cfef9317b3950383b6a48680998905.tar.bz2 matterbridge-msglm-67a9d133e9cfef9317b3950383b6a48680998905.zip |
Add quick & dirty sshchat support (https://github.com/shazow/ssh-chat)
Diffstat (limited to 'bridge/sshchat/sshchat.go')
-rw-r--r-- | bridge/sshchat/sshchat.go | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/bridge/sshchat/sshchat.go b/bridge/sshchat/sshchat.go new file mode 100644 index 00000000..becb688c --- /dev/null +++ b/bridge/sshchat/sshchat.go @@ -0,0 +1,138 @@ +package bsshchat + +import ( + "bufio" + "github.com/42wim/matterbridge/bridge/config" + log "github.com/Sirupsen/logrus" + "github.com/shazow/ssh-chat/sshd" + "io" + "strings" +) + +type Bsshchat struct { + r *bufio.Scanner + w io.WriteCloser + Config *config.Protocol + Remote chan config.Message + Account string +} + +var flog *log.Entry +var protocol = "sshchat" + +func init() { + flog = log.WithFields(log.Fields{"module": protocol}) +} + +func New(cfg config.Protocol, account string, c chan config.Message) *Bsshchat { + b := &Bsshchat{} + b.Config = &cfg + b.Account = account + b.Remote = c + return b +} + +func (b *Bsshchat) Connect() error { + var err error + flog.Infof("Connecting %s", b.Config.Server) + go func() { + err = sshd.ConnectShell(b.Config.Server, b.Config.Nick, func(r io.Reader, w io.WriteCloser) error { + b.r = bufio.NewScanner(r) + b.w = w + b.r.Scan() + w.Write([]byte("/theme mono\r\n")) + b.handleSshChat() + return nil + }) + }() + if err != nil { + flog.Debugf("%#v", err) + return err + } + flog.Info("Connection succeeded") + return nil +} + +func (b *Bsshchat) Disconnect() error { + return nil +} + +func (b *Bsshchat) JoinChannel(channel config.ChannelInfo) error { + return nil +} + +func (b *Bsshchat) Send(msg config.Message) (string, error) { + // ignore delete messages + if msg.Event == config.EVENT_MSG_DELETE { + return "", nil + } + flog.Debugf("Receiving %#v", msg) + if msg.Extra != nil { + if len(msg.Extra["file"]) > 0 { + for _, f := range msg.Extra["file"] { + fi := f.(config.FileInfo) + if fi.URL != "" { + msg.Text = fi.URL + } + b.w.Write([]byte(msg.Username + msg.Text)) + } + return "", nil + } + } + b.w.Write([]byte(msg.Username + msg.Text + "\r\n")) + return "", nil +} + +/* +func (b *Bsshchat) sshchatKeepAlive() chan bool { + done := make(chan bool) + go func() { + ticker := time.NewTicker(90 * time.Second) + defer ticker.Stop() + for { + select { + case <-ticker.C: + flog.Debugf("PING") + err := b.xc.PingC2S("", "") + if err != nil { + flog.Debugf("PING failed %#v", err) + } + case <-done: + return + } + } + }() + return done +} +*/ + +func stripPrompt(s string) string { + pos := strings.LastIndex(s, "\033[K") + if pos < 0 { + return s + } + return s[pos+3:] +} + +func (b *Bsshchat) handleSshChat() error { + /* + done := b.sshchatKeepAlive() + defer close(done) + */ + wait := true + for { + if b.r.Scan() { + res := strings.Split(stripPrompt(b.r.Text()), ":") + if res[0] == "-> Set theme" { + wait = false + log.Debugf("mono found, allowing") + continue + } + if !wait { + flog.Debugf("message %#v", res) + rmsg := config.Message{Username: res[0], Text: strings.Join(res[1:], ":"), Channel: "sshchat", Account: b.Account, UserID: "nick"} + b.Remote <- rmsg + } + } + } +} |