From fd04e08c9c99d5bc2e819c4679ff419aea8a3b71 Mon Sep 17 00:00:00 2001 From: Wim Date: Tue, 29 May 2018 23:28:13 +0200 Subject: Update vendor matterbridge/go-xmpp --- vendor/github.com/matterbridge/go-xmpp/xmpp.go | 20 +++++++++++++++++++- vendor/manifest | 2 +- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/vendor/github.com/matterbridge/go-xmpp/xmpp.go b/vendor/github.com/matterbridge/go-xmpp/xmpp.go index 253b7613..39aa2d8c 100644 --- a/vendor/github.com/matterbridge/go-xmpp/xmpp.go +++ b/vendor/github.com/matterbridge/go-xmpp/xmpp.go @@ -575,6 +575,8 @@ type Chat struct { Thread string Ooburl string Oobdesc string + ID string + ReplaceID string Roster Roster Other []string OtherElem []XMLElement @@ -626,6 +628,8 @@ func (c *Client) Recv() (stanza interface{}, err error) { Text: v.Body, Subject: v.Subject, Thread: v.Thread, + ID: v.ID, + ReplaceID: v.ReplaceID.ID, Other: v.OtherStrings(), OtherElem: v.Other, Stamp: stamp, @@ -657,6 +661,8 @@ func (c *Client) Send(chat Chat) (n int, err error) { var subtext = `` var thdtext = `` var oobtext = `` + var msgidtext = `` + var msgcorrecttext = `` if chat.Subject != `` { subtext = `` + xmlEscape(chat.Subject) + `` } @@ -670,7 +676,13 @@ func (c *Client) Send(chat Chat) (n int, err error) { } oobtext += `` } - return fmt.Fprintf(c.conn, "" + subtext + "%s" + oobtext + thdtext + "", + if chat.ID != `` { + msgidtext = `id='` + xmlEscape(chat.ID) + `'` + } + if chat.ReplaceID != `` { + msgcorrecttext = `` + } + return fmt.Fprintf(c.conn, "" + subtext + "%s" + msgcorrecttext + oobtext + thdtext + "", xmlEscape(chat.Remote), xmlEscape(chat.Type), xmlEscape(chat.Text)) } @@ -787,6 +799,11 @@ type bindBind struct { Jid string `xml:"jid"` } +type clientMessageCorrect struct { + XMLName xml.Name `xml:"urn:xmpp:message-correct:0 replace"` + ID string `xml:"id,attr"` +} + // RFC 3921 B.1 jabber:client type clientMessage struct { XMLName xml.Name `xml:"jabber:client message"` @@ -799,6 +816,7 @@ type clientMessage struct { Subject string `xml:"subject"` Body string `xml:"body"` Thread string `xml:"thread"` + ReplaceID clientMessageCorrect // Any hasn't matched element Other []XMLElement `xml:",any"` diff --git a/vendor/manifest b/vendor/manifest index d5414c9c..bbd0df1f 100644 --- a/vendor/manifest +++ b/vendor/manifest @@ -402,7 +402,7 @@ "importpath": "github.com/matterbridge/go-xmpp", "repository": "https://github.com/matterbridge/go-xmpp", "vcs": "git", - "revision": "3cceb718219057817b66c4bb55673f5f417c0bff", + "revision": "cd19799fba91790ac733655c546bce2107e5b838", "branch": "work", "notests": true }, -- cgit v1.2.3