Files
zot/pkg/extensions/sync/utils.go
T
peusebiu 0e2aa81439 feat(sync): use regclient for sync extension (#2903)
* feat(sync): use regclient for sync extension

replaced containers/image package with regclient/regclient package

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(sync): fixed converting innner docker list mediatype

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* feat(sync): added option to preserve digest

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(sync): added coverage and various fixes

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(metadb): fixed converting manifest list not setting platform and annotations

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(sync): remove read lock on storage, not used concurrently

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* feat(sync): added cache for repo tags

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(sync): fixed Makefile
removed opengpg tag

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

* fix(sync): add test for on demand referrer

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>

---------

Signed-off-by: Eusebiu Petu <petu.eusebiu@gmail.com>
2025-04-15 16:58:15 -07:00

134 lines
2.4 KiB
Go

//go:build sync
// +build sync
package sync
import (
"encoding/json"
"net/url"
"os"
"path"
"strings"
"github.com/opencontainers/go-digest"
ispec "github.com/opencontainers/image-spec/specs-go/v1"
syncconf "zotregistry.dev/zot/pkg/extensions/config/sync"
)
// Get sync.FileCredentials from file.
func getFileCredentials(filepath string) (syncconf.CredentialsFile, error) {
credsFile, err := os.ReadFile(filepath)
if err != nil {
return nil, err
}
var creds syncconf.CredentialsFile
err = json.Unmarshal(credsFile, &creds)
if err != nil {
return nil, err
}
return creds, nil
}
// parse a reference, return its digest and if it's valid.
func parseReference(reference string) (digest.Digest, bool) {
var ok bool
d, err := digest.Parse(reference)
if err == nil {
ok = true
}
return d, ok
}
// Given a list of registry string URLs parse them and return *url.URLs slice.
func parseRegistryURLs(rawURLs []string) ([]*url.URL, error) {
urls := make([]*url.URL, 0)
for _, rawURL := range rawURLs {
u, err := url.Parse(rawURL)
if err != nil {
return nil, err
}
urls = append(urls, u)
}
return urls, nil
}
func GetDescriptorReference(desc ispec.Descriptor) string {
v, ok := desc.Annotations[ispec.AnnotationRefName]
if ok {
return v
}
return desc.Digest.String()
}
func StripRegistryTransport(url string) string {
return strings.Replace(strings.Replace(url, "http://", "", 1), "https://", "", 1)
}
func getCertificates(certDir string) (string, string, string, error) {
var clientCert string
var clientKey string
var regCert string
files, err := os.ReadDir(certDir)
if err != nil {
if os.IsNotExist(err) {
return "", "", "", nil
}
return "", "", "", err
}
for _, file := range files {
if file.IsDir() {
continue
}
if strings.HasSuffix(file.Name(), ".cert") {
certPath := path.Join(certDir, file.Name())
buf, err := os.ReadFile(certPath)
if err != nil {
return "", "", "", err
}
clientCert = string(buf)
}
if strings.HasSuffix(file.Name(), ".key") {
certPath := path.Join(certDir, file.Name())
buf, err := os.ReadFile(certPath)
if err != nil {
return "", "", "", err
}
clientKey = string(buf)
}
if strings.HasSuffix(file.Name(), ".crt") {
certPath := path.Join(certDir, file.Name())
buf, err := os.ReadFile(certPath)
if err != nil {
return "", "", "", err
}
regCert = string(buf)
}
}
return clientCert, clientKey, regCert, nil
}