From 4ede51e2b049c1d55b6456685baea58313d7a0f3 Mon Sep 17 00:00:00 2001 From: Simon Ser Date: Sat, 7 Mar 2020 18:09:50 +0100 Subject: [PATCH] protonmail: fix "invalid refresh token" errors The UID is now provided as a header field. Closes: https://github.com/emersion/hydroxide/issues/81 --- protonmail/auth.go | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/protonmail/auth.go b/protonmail/auth.go index 0bfba1e..3c8efdc 100644 --- a/protonmail/auth.go +++ b/protonmail/auth.go @@ -169,7 +169,6 @@ func (c *Client) AuthTOTP(code string) (scope string, err error) { } type authRefreshReq struct { - UID string `json:"Uid"` RefreshToken string // Unused but required @@ -180,7 +179,6 @@ type authRefreshReq struct { func (c *Client) AuthRefresh(expiredAuth *Auth) (*Auth, error) { reqData := &authRefreshReq{ - UID: expiredAuth.UID, RefreshToken: expiredAuth.RefreshToken, ResponseType: "token", GrantType: "refresh_token", @@ -191,6 +189,7 @@ func (c *Client) AuthRefresh(expiredAuth *Auth) (*Auth, error) { if err != nil { return nil, err } + req.Header.Set("X-Pm-Uid", expiredAuth.UID) var respData authResp if err := c.doJSON(req, &respData); err != nil {