mirror of
https://github.com/project-zot/zot.git
synced 2026-06-18 05:28:07 +08:00
2402296e9a
* fix: migrate to Go module v2 for proper semantic versioning This change updates the module path from 'zotregistry.dev/zot' to 'zotregistry.dev/zot/v2' to comply with Go's semantic versioning rules. According to Go's module versioning requirements, major version v2+ must include the major version in the module path. The current module path 'zotregistry.dev/zot' only supports v0.x.x and v1.x.x versions, making existing v2.x.x tags (like v2.1.8) unusable. Changes: - Updated go.mod module path to zotregistry.dev/zot/v2 - Updated all internal import paths across 280+ Go source files - Updated configuration files (golangcilint.yaml, gqlgen.yml) - Updated README.md Go reference badge This fix enables proper use of existing v2.x.x Git tags and allows external packages to import zot v2+ versions without compatibility errors. Resolves: Go module import compatibility for v2+ versions Fixes: #3071 Signed-off-by: Luca Muscariello <muscariello@ieee.org> * fix: regenerate GraphQL files with updated v2 import paths The gqlgen tool needs to regenerate the GraphQL schema files after the module path change to use the new v2 imports. Signed-off-by: Luca Muscariello <muscariello@ieee.org> --------- Signed-off-by: Luca Muscariello <muscariello@ieee.org>
134 lines
2.4 KiB
Go
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/v2/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
|
|
}
|