mirror of
https://github.com/project-zot/zot.git
synced 2025-01-20 22:52:51 -05:00
5c07e19c8d
now it copies to a local cache and then it copies over storage APIs - accept all images with or without signatures - disable sync writing to stdout - added more logs - fixed switch statement in routes - fixed enabling sync multiple times for storage subpaths closes #266 Signed-off-by: Petu Eusebiu <peusebiu@cisco.com>
69 lines
1.7 KiB
Go
69 lines
1.7 KiB
Go
package sync
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
|
|
"github.com/anuvu/zot/pkg/log"
|
|
"github.com/anuvu/zot/pkg/storage"
|
|
guuid "github.com/gofrs/uuid"
|
|
)
|
|
|
|
type PostHandler struct {
|
|
StoreController storage.StoreController
|
|
Cfg Config
|
|
Log log.Logger
|
|
}
|
|
|
|
func (h *PostHandler) Handler(w http.ResponseWriter, r *http.Request) {
|
|
var credentialsFile CredentialsFile
|
|
|
|
var err error
|
|
|
|
if h.Cfg.CredentialsFile != "" {
|
|
credentialsFile, err = getFileCredentials(h.Cfg.CredentialsFile)
|
|
if err != nil {
|
|
h.Log.Error().Err(err).Msgf("sync http handler: couldn't get registry credentials from %s", h.Cfg.CredentialsFile)
|
|
WriteData(w, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
}
|
|
|
|
localCtx, policyCtx, err := getLocalContexts(h.Log)
|
|
if err != nil {
|
|
WriteData(w, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
|
|
defer policyCtx.Destroy() //nolint: errcheck
|
|
|
|
uuid, err := guuid.NewV4()
|
|
if err != nil {
|
|
WriteData(w, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
|
|
for _, regCfg := range h.Cfg.Registries {
|
|
upstreamRegistryName := strings.Replace(strings.Replace(regCfg.URL, "http://", "", 1), "https://", "", 1)
|
|
|
|
if err := syncRegistry(regCfg, h.StoreController, h.Log, localCtx, policyCtx,
|
|
credentialsFile[upstreamRegistryName], uuid.String()); err != nil {
|
|
h.Log.Err(err).Msg("sync http handler: error while syncing in")
|
|
WriteData(w, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
}
|
|
|
|
WriteData(w, http.StatusOK, "")
|
|
}
|
|
|
|
func WriteData(w http.ResponseWriter, status int, msg string) {
|
|
w.Header().Set("Content-Type", "application/json")
|
|
w.WriteHeader(status)
|
|
_, _ = w.Write([]byte(fmt.Sprintf("error: %s", msg)))
|
|
}
|