diff options
author | Gonçalo Ribeiro <darklaw13@yahoo.co.uk> | 2019-11-01 21:29:52 +0000 |
---|---|---|
committer | Wim <wim@42.be> | 2019-11-01 22:29:52 +0100 |
commit | c394de0c88fecf1841fa86c1c43305b0244d9b62 (patch) | |
tree | 55ef143a67d5b84151620ba3be3999445eff3fa7 /bridge/keybase/keybase.go | |
parent | bad19901730d51416ebb12882840703e9743502b (diff) | |
download | matterbridge-msglm-c394de0c88fecf1841fa86c1c43305b0244d9b62.tar.gz matterbridge-msglm-c394de0c88fecf1841fa86c1c43305b0244d9b62.tar.bz2 matterbridge-msglm-c394de0c88fecf1841fa86c1c43305b0244d9b62.zip |
Add support for receiving attachments (keybase) (#923)
Diffstat (limited to 'bridge/keybase/keybase.go')
-rw-r--r-- | bridge/keybase/keybase.go | 31 |
1 files changed, 27 insertions, 4 deletions
diff --git a/bridge/keybase/keybase.go b/bridge/keybase/keybase.go index a4b12742..6d0b478d 100644 --- a/bridge/keybase/keybase.go +++ b/bridge/keybase/keybase.go @@ -1,6 +1,9 @@ package bkeybase import ( + "io/ioutil" + "os" + "path/filepath" "strconv" "github.com/42wim/matterbridge/bridge" @@ -66,17 +69,37 @@ func (b *Bkeybase) Send(msg config.Message) (string, error) { // Delete message if we have an ID // Delete message not supported by keybase go library yet - // Upload a file if it exists - // kbchat lib does not support attachments yet - // Edit message if we have an ID // kbchat lib does not support message editing yet + if len(msg.Extra["file"]) > 0 { + // Upload a file + dir, err := ioutil.TempDir("", "matterbridge") + if err != nil { + return "", err + } + defer os.RemoveAll(dir) + + for _, f := range msg.Extra["file"] { + fname := f.(config.FileInfo).Name + fdata := *f.(config.FileInfo).Data + fcaption := f.(config.FileInfo).Comment + fpath := filepath.Join(dir, fname) + + if err = ioutil.WriteFile(fpath, fdata, 0600); err != nil { + return "", err + } + + _, _ = b.kbc.SendAttachmentByTeam(b.team, fpath, fcaption, &b.channel) + } + + return "", nil + } + // Send regular message resp, err := b.kbc.SendMessageByTeamName(b.team, msg.Username+msg.Text, &b.channel) if err != nil { return "", err } - return strconv.Itoa(resp.Result.MsgID), err } |