mirror of
https://github.com/project-zot/zot.git
synced 2025-01-06 22:40:28 -05:00
ac3801ea2d
Signed-off-by: Ramkumar Chinchani <rchincha@cisco.com>
83 lines
2.2 KiB
Go
83 lines
2.2 KiB
Go
package sync
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
|
|
guuid "github.com/gofrs/uuid"
|
|
"zotregistry.io/zot/pkg/log"
|
|
"zotregistry.io/zot/pkg/storage"
|
|
)
|
|
|
|
type PostHandler struct {
|
|
StoreController storage.StoreController
|
|
Cfg Config
|
|
Log log.Logger
|
|
}
|
|
|
|
func (h *PostHandler) Handler(response http.ResponseWriter, request *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(response, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
}
|
|
|
|
localCtx, policyCtx, err := getLocalContexts(h.Log)
|
|
if err != nil {
|
|
WriteData(response, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
|
|
defer policyCtx.Destroy() //nolint: errcheck
|
|
|
|
uuid, err := guuid.NewV4()
|
|
if err != nil {
|
|
WriteData(response, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
|
|
for _, regCfg := range h.Cfg.Registries {
|
|
// if content not provided, don't run periodically sync
|
|
if len(regCfg.Content) == 0 {
|
|
h.Log.Info().Msgf("sync config content not configured for %s, will not run periodically sync", regCfg.URL)
|
|
|
|
continue
|
|
}
|
|
|
|
// if pollInterval is not provided, don't run periodically sync
|
|
if regCfg.PollInterval == 0 {
|
|
h.Log.Warn().Msgf("sync config PollInterval not configured for %s, will not run periodically sync", regCfg.URL)
|
|
|
|
continue
|
|
}
|
|
|
|
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(response, http.StatusInternalServerError, err.Error())
|
|
|
|
return
|
|
}
|
|
}
|
|
|
|
WriteData(response, 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)))
|
|
}
|