Browse Source

Set the desired DisplayName for a client when it is being configured

kegan/configure-client-name
Kegan Dougal 8 years ago
parent
commit
314b63e900
  1. 12
      src/github.com/matrix-org/go-neb/clients/clients.go
  2. 14
      src/github.com/matrix-org/go-neb/matrix/matrix.go
  3. 1
      src/github.com/matrix-org/go-neb/types/types.go

12
src/github.com/matrix-org/go-neb/clients/clients.go

@ -115,6 +115,18 @@ func (c *Clients) updateClientInDB(newConfig types.ClientConfig) (new clientEntr
return return
} }
// set the new display name if they differ
if old.config.DisplayName != new.config.DisplayName {
if err := new.client.SetDisplayName(new.config.DisplayName); err != nil {
// whine about it but don't stop: this isn't fatal.
log.WithFields(log.Fields{
log.ErrorKey: err,
"displayname": new.config.DisplayName,
"user_id": new.config.UserID,
}).Error("Failed to set display name")
}
}
if old.config, err = c.db.StoreMatrixClientConfig(new.config); err != nil { if old.config, err = c.db.StoreMatrixClientConfig(new.config); err != nil {
new.client.StopSync() new.client.StopSync()
return return

14
src/github.com/matrix-org/go-neb/matrix/matrix.go

@ -104,6 +104,16 @@ func (cli *Client) JoinRoom(roomIDorAlias, serverName, invitingUserID string) (s
return joinRoomResponse.RoomID, nil return joinRoomResponse.RoomID, nil
} }
// SetDisplayName sets the user's profile display name
func (cli *Client) SetDisplayName(displayName string) error {
urlPath := cli.buildURL("profile", cli.UserID, "displayname")
s := struct {
DisplayName string `json:"displayname"`
}{displayName}
_, err := cli.sendJSON("PUT", urlPath, &s)
return err
}
// SendMessageEvent sends a message event into a room, returning the event_id on success. // SendMessageEvent sends a message event into a room, returning the event_id on success.
// contentJSON should be a pointer to something that can be encoded as JSON using json.Marshal. // contentJSON should be a pointer to something that can be encoded as JSON using json.Marshal.
func (cli *Client) SendMessageEvent(roomID string, eventType string, contentJSON interface{}) (string, error) { func (cli *Client) SendMessageEvent(roomID string, eventType string, contentJSON interface{}) (string, error) {
@ -282,11 +292,13 @@ func (cli *Client) sendJSON(method string, httpURL string, contentJSON interface
}) })
logger.Print("Sending JSON request") logger.Print("Sending JSON request")
res, err := cli.httpClient.Do(req) res, err := cli.httpClient.Do(req)
if res != nil {
defer res.Body.Close()
}
if err != nil { if err != nil {
logger.WithError(err).Warn("Failed to send JSON request") logger.WithError(err).Warn("Failed to send JSON request")
return nil, err return nil, err
} }
defer res.Body.Close()
contents, err := ioutil.ReadAll(res.Body) contents, err := ioutil.ReadAll(res.Body)
if res.StatusCode >= 300 { if res.StatusCode >= 300 {
logger.WithFields(log.Fields{ logger.WithFields(log.Fields{

1
src/github.com/matrix-org/go-neb/types/types.go

@ -18,6 +18,7 @@ type ClientConfig struct {
AccessToken string // The matrix access token to authenticate the requests with. AccessToken string // The matrix access token to authenticate the requests with.
Sync bool // True to start a sync stream for this user Sync bool // True to start a sync stream for this user
AutoJoinRooms bool // True to automatically join all rooms for this user AutoJoinRooms bool // True to automatically join all rooms for this user
DisplayName string // The display name to set for the matrix client
} }
// Check that the client has the correct fields. // Check that the client has the correct fields.

Loading…
Cancel
Save