sftp: Fix operations with a internal service account (#20293)

sftp sends local requests to the S3 port while passing the session token
header when the account corresponds to a service account. However, this
is not permitted and will throw an error: "The security token included in the
request is invalid"

This commit will avoid passing the session token to the upper layer that
initializes MinIO client to avoid this error.
This commit is contained in:
Anis Eleuch 2024-08-20 21:00:29 +01:00 committed by GitHub
parent 8a11282522
commit 7b239ae154
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -162,30 +162,31 @@ internalAuth:
}
if caPublicKey != nil && pass == nil {
err := validateKey(c, key)
if err != nil {
return nil, errAuthentication
}
} else {
// Temporary credentials are not allowed.
if ui.Credentials.IsTemp() {
return nil, errAuthentication
}
if subtle.ConstantTimeCompare([]byte(ui.Credentials.SecretKey), pass) != 1 {
return nil, errAuthentication
}
}
copts := map[string]string{
"AccessKey": ui.Credentials.AccessKey,
"SecretKey": ui.Credentials.SecretKey,
}
if ui.Credentials.IsTemp() {
copts["SessionToken"] = ui.Credentials.SessionToken
}
return &ssh.Permissions{
CriticalOptions: map[string]string{
"AccessKey": ui.Credentials.AccessKey,
"SecretKey": ui.Credentials.SecretKey,
"SessionToken": ui.Credentials.SessionToken,
},
CriticalOptions: copts,
Extensions: make(map[string]string),
}, nil
}
@ -209,7 +210,6 @@ func processLDAPAuthentication(key ssh.PublicKey, pass []byte, user string) (per
CriticalOptions: map[string]string{
"AccessKey": sa.Credentials.AccessKey,
"SecretKey": sa.Credentials.SecretKey,
"SessionToken": sa.Credentials.SessionToken,
},
Extensions: make(map[string]string),
}, nil