2015-11-08 16:29:58 +01:00
|
|
|
package hubic
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
2018-09-04 22:00:36 +02:00
|
|
|
"time"
|
2015-11-08 16:29:58 +01:00
|
|
|
|
|
|
|
"github.com/ncw/swift"
|
2019-07-28 19:47:38 +02:00
|
|
|
"github.com/rclone/rclone/fs"
|
2015-11-08 16:29:58 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// auth is an authenticator for swift
|
|
|
|
type auth struct {
|
|
|
|
f *Fs
|
|
|
|
}
|
|
|
|
|
|
|
|
// newAuth creates a swift authenticator
|
|
|
|
func newAuth(f *Fs) *auth {
|
|
|
|
return &auth{
|
|
|
|
f: f,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Request constructs a http.Request for authentication
|
|
|
|
//
|
|
|
|
// returns nil for not needed
|
2018-09-04 22:00:36 +02:00
|
|
|
func (a *auth) Request(*swift.Connection) (r *http.Request, err error) {
|
|
|
|
const retries = 10
|
|
|
|
for try := 1; try <= retries; try++ {
|
|
|
|
err = a.f.getCredentials()
|
|
|
|
if err == nil {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
time.Sleep(100 * time.Millisecond)
|
|
|
|
fs.Debugf(a.f, "retrying auth request %d/%d: %v", try, retries, err)
|
2015-11-08 16:29:58 +01:00
|
|
|
}
|
2018-09-04 22:00:36 +02:00
|
|
|
return nil, err
|
2015-11-08 16:29:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Response parses the result of an http request
|
|
|
|
func (a *auth) Response(resp *http.Response) error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// The public storage URL - set Internal to true to read
|
|
|
|
// internal/service net URL
|
2018-05-05 12:49:03 +02:00
|
|
|
func (a *auth) StorageUrl(Internal bool) string { // nolint
|
2015-11-08 16:29:58 +01:00
|
|
|
return a.f.credentials.Endpoint
|
|
|
|
}
|
|
|
|
|
|
|
|
// The access token
|
|
|
|
func (a *auth) Token() string {
|
|
|
|
return a.f.credentials.Token
|
|
|
|
}
|
|
|
|
|
|
|
|
// The CDN url if available
|
2018-05-05 12:49:03 +02:00
|
|
|
func (a *auth) CdnUrl() string { // nolint
|
2015-11-08 16:29:58 +01:00
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check the interfaces are satisfied
|
|
|
|
var _ swift.Authenticator = (*auth)(nil)
|