From a5651456039317df06776c287619a67740386409 Mon Sep 17 00:00:00 2001 From: Kegan Dougal Date: Mon, 5 Dec 2016 15:25:09 +0000 Subject: [PATCH] Add AppServiceUserID string for app services. --- client.go | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/client.go b/client.go index 6a6beb7..6d4a19f 100644 --- a/client.go +++ b/client.go @@ -35,11 +35,17 @@ type Client struct { Prefix string // The API prefix eg '/_matrix/client/r0' UserID string // The user ID of the client. Used for forming HTTP paths which use the client's user ID. AccessToken string // The access_token for the client. - syncingMutex sync.Mutex // protects syncingID - syncingID uint32 // Identifies the current Sync. Only one Sync can be active at any given time. Client *http.Client // The underlying HTTP client which will be used to make HTTP requests. Syncer Syncer // The thing which can process /sync responses Store Storer // The thing which can store rooms/tokens/ids + + // The ?user_id= query parameter for application services. This must be set *prior* to calling a method. If this is empty, + // no user_id parameter will be sent. + // See http://matrix.org/docs/spec/application_service/unstable.html#identity-assertion + AppServiceUserID string + + syncingMutex sync.Mutex // protects syncingID + syncingID uint32 // Identifies the current Sync. Only one Sync can be active at any given time. } // HTTPError An HTTP Error response, which may wrap an underlying native Go Error. @@ -78,6 +84,9 @@ func (cli *Client) BuildBaseURL(urlPath ...string) string { if cli.AccessToken != "" { query.Set("access_token", cli.AccessToken) } + if cli.AppServiceUserID != "" { + query.Set("user_id", cli.AppServiceUserID) + } hsURL.RawQuery = query.Encode() return hsURL.String() }