mirror of
https://github.com/rclone/rclone.git
synced 2025-01-22 06:09:21 +01:00
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:
parent
49ba4eeb86
commit
78ca08ba8a
@ -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)
|
||||||
}
|
}
|
||||||
|
@ -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),
|
||||||
|
Loading…
Reference in New Issue
Block a user