diff options
author | Wim <wim@42.be> | 2019-12-29 23:57:41 +0100 |
---|---|---|
committer | Wim <wim@42.be> | 2020-03-01 22:19:33 +0100 |
commit | 8eb6ed563995d48e9835693d7a0af3155571113b (patch) | |
tree | 925eb77f9f5dd19e0d9a9e18adce4411f8f9f7a9 /bridge/msteams/msteams.go | |
parent | 795a8705c3fdc5bf55e83d382e7d3ff233896a0b (diff) | |
download | matterbridge-msglm-8eb6ed563995d48e9835693d7a0af3155571113b.tar.gz matterbridge-msglm-8eb6ed563995d48e9835693d7a0af3155571113b.tar.bz2 matterbridge-msglm-8eb6ed563995d48e9835693d7a0af3155571113b.zip |
Support receiving attachments from msteams
Diffstat (limited to 'bridge/msteams/msteams.go')
-rw-r--r-- | bridge/msteams/msteams.go | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/bridge/msteams/msteams.go b/bridge/msteams/msteams.go index f2f0308b..4f72bd29 100644 --- a/bridge/msteams/msteams.go +++ b/bridge/msteams/msteams.go @@ -1,8 +1,9 @@ -package bgitter +package bmsteams import ( "context" "os" + "regexp" "strings" "time" @@ -96,6 +97,7 @@ func (b *Bmsteams) getMessages(channel string) ([]msgraph.ChatMessage, error) { } func (b *Bmsteams) poll(channelName string) { + re := regexp.MustCompile(`<attachment id=.*?attachment>`) msgmap := make(map[string]time.Time) b.Log.Debug("getting initial messages") res, err := b.getMessages(channelName) @@ -136,8 +138,28 @@ func (b *Bmsteams) poll(channelName string) { } b.Log.Debugf("<= Sending message from %s on %s to gateway", *msg.From.User.DisplayName, b.Account) text := b.convertToMD(*msg.Body.Content) - rmsg := config.Message{Username: *msg.From.User.DisplayName, Text: text, Channel: channelName, - Account: b.Account, Avatar: "", UserID: *msg.From.User.ID, ID: *msg.ID} + rmsg := config.Message{ + Username: *msg.From.User.DisplayName, + Text: text, + Channel: channelName, + Account: b.Account, + Avatar: "", + UserID: *msg.From.User.ID, + ID: *msg.ID, + Extra: make(map[string][]interface{}), + } + + if len(msg.Attachments) > 0 { + for _, a := range msg.Attachments { + //remove the attachment tags from the text + rmsg.Text = re.ReplaceAllString(rmsg.Text, "") + //handle the download + err := b.handleDownloadFile(&rmsg, *a.Name, *a.ContentURL) + if err != nil { + b.Log.Errorf("download of %s failed: %s", *a.Name, err) + } + } + } b.Log.Debugf("<= Message is %#v", rmsg) b.Remote <- rmsg } |