mirror of
https://github.com/distribution/distribution.git
synced 2025-08-21 16:24:00 +00:00
https://github.com/distribution/distribution/pull/4146 introduced a new rewrite storage middleware but somehow missed to update the init logging message. This commit fixes that. Signed-off-by: Milos Gajdos <milosthegajdos@gmail.com>
87 lines
1.9 KiB
Go
87 lines
1.9 KiB
Go
package middleware
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
"net/url"
|
|
"strings"
|
|
|
|
storagedriver "github.com/distribution/distribution/v3/registry/storage/driver"
|
|
storagemiddleware "github.com/distribution/distribution/v3/registry/storage/driver/middleware"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
func init() {
|
|
if err := storagemiddleware.Register("rewrite", newRewriteStorageMiddleware); err != nil {
|
|
logrus.Errorf("failed to register rewrite storage middleware: %v", err)
|
|
}
|
|
}
|
|
|
|
type rewriteStorageMiddleware struct {
|
|
storagedriver.StorageDriver
|
|
overrideScheme string
|
|
overrideHost string
|
|
trimPathPrefix string
|
|
}
|
|
|
|
var _ storagedriver.StorageDriver = &rewriteStorageMiddleware{}
|
|
|
|
func getStringOption(key string, options map[string]interface{}) (string, error) {
|
|
o, ok := options[key]
|
|
if !ok {
|
|
return "", nil
|
|
}
|
|
s, ok := o.(string)
|
|
if !ok {
|
|
return "", fmt.Errorf("%s must be a string", key)
|
|
}
|
|
return s, nil
|
|
}
|
|
|
|
func newRewriteStorageMiddleware(ctx context.Context, sd storagedriver.StorageDriver, options map[string]interface{}) (storagedriver.StorageDriver, error) {
|
|
var err error
|
|
|
|
r := &rewriteStorageMiddleware{StorageDriver: sd}
|
|
|
|
if r.overrideScheme, err = getStringOption("scheme", options); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if r.overrideHost, err = getStringOption("host", options); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if r.trimPathPrefix, err = getStringOption("trimpathprefix", options); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return r, nil
|
|
}
|
|
|
|
func (r *rewriteStorageMiddleware) RedirectURL(req *http.Request, path string) (string, error) {
|
|
storagePath, err := r.StorageDriver.RedirectURL(req, path)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
u, err := url.Parse(storagePath)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
if r.overrideScheme != "" {
|
|
u.Scheme = r.overrideScheme
|
|
}
|
|
|
|
if r.overrideHost != "" {
|
|
u.Host = r.overrideHost
|
|
}
|
|
|
|
if r.trimPathPrefix != "" {
|
|
u.Path = strings.TrimPrefix(u.Path, r.trimPathPrefix)
|
|
}
|
|
|
|
return u.String(), nil
|
|
}
|