pcloud: fix initial config "Auth state doesn't match" message #4210

pCloud should be passing back the state parameter that rclone passed
in on config but it seems to have got lost somewhere.

This sets a work-around for the pCloud backend allowing an empty state
parameter.

See: https://forum.rclone.org/t/cannot-connect-to-pcloud/16592
See: https://forum.rclone.org/t/cannot-create-pcloud-config-file-on-osx/16583
This commit is contained in:
Nick Craig-Wood 2020-05-25 15:12:25 +01:00
parent 49ba4eeb86
commit 78ca08ba8a
2 changed files with 9 additions and 5 deletions

View File

@ -67,7 +67,10 @@ func init() {
Description: "Pcloud", Description: "Pcloud",
NewFs: NewFs, NewFs: NewFs,
Config: func(name string, m configmap.Mapper) { Config: func(name string, m configmap.Mapper) {
err := oauthutil.Config("pcloud", name, m, oauthConfig, nil) opt := oauthutil.Options{
StateBlankOK: true, // pCloud seems to drop the state parameter now - see #4210
}
err := oauthutil.Config("pcloud", name, m, oauthConfig, &opt)
if err != nil { if err != nil {
log.Fatalf("Failed to configure token: %v", err) log.Fatalf("Failed to configure token: %v", err)
} }

View File

@ -362,9 +362,10 @@ type CheckAuthFn func(*oauth2.Config, *AuthResult) error
// Options for the oauth config // Options for the oauth config
type Options struct { type Options struct {
NoOffline bool // If set then "access_type=offline" parameter is not passed NoOffline bool // If set then "access_type=offline" parameter is not passed
CheckAuth CheckAuthFn // When the AuthResult is known the checkAuth function is called if set CheckAuth CheckAuthFn // When the AuthResult is known the checkAuth function is called if set
OAuth2Opts []oauth2.AuthCodeOption // extra oauth2 options OAuth2Opts []oauth2.AuthCodeOption // extra oauth2 options
StateBlankOK bool // If set, state returned as "" is deemed to be OK
} }
// Config does the initial creation of the token // Config does the initial creation of the token
@ -580,7 +581,7 @@ func (s *authServer) handleAuth(w http.ResponseWriter, req *http.Request) {
// check state // check state
state := req.Form.Get("state") state := req.Form.Get("state")
if state != s.state { if state != s.state && !(state == "" && s.opt.StateBlankOK) {
reply(http.StatusBadRequest, &AuthResult{ reply(http.StatusBadRequest, &AuthResult{
Name: "Auth state doesn't match", Name: "Auth state doesn't match",
Description: fmt.Sprintf("Expecting %q got %q", s.state, state), Description: fmt.Sprintf("Expecting %q got %q", s.state, state),