summaryrefslogtreecommitdiffstats
path: root/bridge/keybase/keybase.go
diff options
context:
space:
mode:
authorGonçalo Ribeiro <darklaw13@yahoo.co.uk>2019-11-01 21:29:52 +0000
committerWim <wim@42.be>2019-11-01 22:29:52 +0100
commitc394de0c88fecf1841fa86c1c43305b0244d9b62 (patch)
tree55ef143a67d5b84151620ba3be3999445eff3fa7 /bridge/keybase/keybase.go
parentbad19901730d51416ebb12882840703e9743502b (diff)
downloadmatterbridge-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.go31
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
}