Use reference package internally
Most places in the registry were using string types to refer to repository names. This changes them to use reference.Named, so the type system can enforce validation of the naming rules. Signed-off-by: Aaron Lehmann <aaron.lehmann@docker.com>
This commit is contained in:
		
							parent
							
								
									e9bcc96ad2
								
							
						
					
					
						commit
						e9692b8037
					
				
					 26 changed files with 235 additions and 193 deletions
				
			
		|  | @ -10,6 +10,7 @@ import ( | |||
| 	"github.com/docker/distribution" | ||||
| 	"github.com/docker/distribution/context" | ||||
| 	"github.com/docker/distribution/digest" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/proxy/scheduler" | ||||
| ) | ||||
| 
 | ||||
|  | @ -133,7 +134,7 @@ func (pbs *proxyBlobStore) ServeBlob(ctx context.Context, w http.ResponseWriter, | |||
| 		if err := pbs.storeLocal(ctx, dgst); err != nil { | ||||
| 			context.GetLogger(ctx).Errorf("Error committing to storage: %s", err.Error()) | ||||
| 		} | ||||
| 		pbs.scheduler.AddBlob(dgst.String(), repositoryTTL) | ||||
| 		pbs.scheduler.AddBlob(dgst, repositoryTTL) | ||||
| 	}(dgst) | ||||
| 
 | ||||
| 	_, err = pbs.copyContent(ctx, dgst, w) | ||||
|  | @ -169,7 +170,7 @@ func (pbs *proxyBlobStore) Resume(ctx context.Context, id string) (distribution. | |||
| 	return nil, distribution.ErrUnsupported | ||||
| } | ||||
| 
 | ||||
| func (pbs *proxyBlobStore) Mount(ctx context.Context, sourceRepo string, dgst digest.Digest) (distribution.Descriptor, error) { | ||||
| func (pbs *proxyBlobStore) Mount(ctx context.Context, sourceRepo reference.Named, dgst digest.Digest) (distribution.Descriptor, error) { | ||||
| 	return distribution.Descriptor{}, distribution.ErrUnsupported | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -12,6 +12,7 @@ import ( | |||
| 	"github.com/docker/distribution" | ||||
| 	"github.com/docker/distribution/context" | ||||
| 	"github.com/docker/distribution/digest" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/proxy/scheduler" | ||||
| 	"github.com/docker/distribution/registry/storage" | ||||
| 	"github.com/docker/distribution/registry/storage/cache/memory" | ||||
|  | @ -114,6 +115,11 @@ func (te *testEnv) RemoteStats() *map[string]int { | |||
| 
 | ||||
| // Populate remote store and record the digests | ||||
| func makeTestEnv(t *testing.T, name string) *testEnv { | ||||
| 	nameRef, err := reference.ParseNamed(name) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unable to parse reference: %s", err) | ||||
| 	} | ||||
| 
 | ||||
| 	ctx := context.Background() | ||||
| 
 | ||||
| 	truthDir, err := ioutil.TempDir("", "truth") | ||||
|  | @ -131,7 +137,7 @@ func makeTestEnv(t *testing.T, name string) *testEnv { | |||
| 	if err != nil { | ||||
| 		t.Fatalf("error creating registry: %v", err) | ||||
| 	} | ||||
| 	localRepo, err := localRegistry.Repository(ctx, name) | ||||
| 	localRepo, err := localRegistry.Repository(ctx, nameRef) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unexpected error getting repo: %v", err) | ||||
| 	} | ||||
|  | @ -140,7 +146,7 @@ func makeTestEnv(t *testing.T, name string) *testEnv { | |||
| 	if err != nil { | ||||
| 		t.Fatalf("error creating registry: %v", err) | ||||
| 	} | ||||
| 	truthRepo, err := truthRegistry.Repository(ctx, name) | ||||
| 	truthRepo, err := truthRegistry.Repository(ctx, nameRef) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unexpected error getting repo: %v", err) | ||||
| 	} | ||||
|  |  | |||
|  | @ -6,6 +6,7 @@ import ( | |||
| 	"github.com/docker/distribution" | ||||
| 	"github.com/docker/distribution/context" | ||||
| 	"github.com/docker/distribution/digest" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/proxy/scheduler" | ||||
| ) | ||||
| 
 | ||||
|  | @ -16,7 +17,7 @@ type proxyManifestStore struct { | |||
| 	ctx             context.Context | ||||
| 	localManifests  distribution.ManifestService | ||||
| 	remoteManifests distribution.ManifestService | ||||
| 	repositoryName  string | ||||
| 	repositoryName  reference.Named | ||||
| 	scheduler       *scheduler.TTLExpirationScheduler | ||||
| } | ||||
| 
 | ||||
|  | @ -65,7 +66,7 @@ func (pms proxyManifestStore) Get(ctx context.Context, dgst digest.Digest, optio | |||
| 		pms.scheduler.AddManifest(pms.repositoryName, repositoryTTL) | ||||
| 
 | ||||
| 		// Ensure the manifest blob is cleaned up | ||||
| 		pms.scheduler.AddBlob(dgst.String(), repositoryTTL) | ||||
| 		pms.scheduler.AddBlob(dgst, repositoryTTL) | ||||
| 	} | ||||
| 
 | ||||
| 	return manifest, err | ||||
|  |  | |||
|  | @ -9,6 +9,7 @@ import ( | |||
| 	"github.com/docker/distribution/digest" | ||||
| 	"github.com/docker/distribution/manifest" | ||||
| 	"github.com/docker/distribution/manifest/schema1" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/proxy/scheduler" | ||||
| 	"github.com/docker/distribution/registry/storage" | ||||
| 	"github.com/docker/distribution/registry/storage/cache/memory" | ||||
|  | @ -64,12 +65,17 @@ func (sm statsManifest) Put(ctx context.Context, manifest distribution.Manifest, | |||
| */ | ||||
| 
 | ||||
| func newManifestStoreTestEnv(t *testing.T, name, tag string) *manifestStoreTestEnv { | ||||
| 	nameRef, err := reference.ParseNamed(name) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unable to parse reference: %s", err) | ||||
| 	} | ||||
| 
 | ||||
| 	ctx := context.Background() | ||||
| 	truthRegistry, err := storage.NewRegistry(ctx, inmemory.New(), storage.BlobDescriptorCacheProvider(memory.NewInMemoryBlobDescriptorCacheProvider())) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("error creating registry: %v", err) | ||||
| 	} | ||||
| 	truthRepo, err := truthRegistry.Repository(ctx, name) | ||||
| 	truthRepo, err := truthRegistry.Repository(ctx, nameRef) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unexpected error getting repo: %v", err) | ||||
| 	} | ||||
|  | @ -91,7 +97,7 @@ func newManifestStoreTestEnv(t *testing.T, name, tag string) *manifestStoreTestE | |||
| 	if err != nil { | ||||
| 		t.Fatalf("error creating registry: %v", err) | ||||
| 	} | ||||
| 	localRepo, err := localRegistry.Repository(ctx, name) | ||||
| 	localRepo, err := localRegistry.Repository(ctx, nameRef) | ||||
| 	if err != nil { | ||||
| 		t.Fatalf("unexpected error getting repo: %v", err) | ||||
| 	} | ||||
|  |  | |||
|  | @ -7,6 +7,7 @@ import ( | |||
| 	"github.com/docker/distribution" | ||||
| 	"github.com/docker/distribution/configuration" | ||||
| 	"github.com/docker/distribution/context" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/client" | ||||
| 	"github.com/docker/distribution/registry/client/auth" | ||||
| 	"github.com/docker/distribution/registry/client/transport" | ||||
|  | @ -71,9 +72,9 @@ func (pr *proxyingRegistry) Repositories(ctx context.Context, repos []string, la | |||
| 	return pr.embedded.Repositories(ctx, repos, last) | ||||
| } | ||||
| 
 | ||||
| func (pr *proxyingRegistry) Repository(ctx context.Context, name string) (distribution.Repository, error) { | ||||
| func (pr *proxyingRegistry) Repository(ctx context.Context, name reference.Named) (distribution.Repository, error) { | ||||
| 	tr := transport.NewTransport(http.DefaultTransport, | ||||
| 		auth.NewAuthorizer(pr.challengeManager, auth.NewTokenHandler(http.DefaultTransport, pr.credentialStore, name, "pull"))) | ||||
| 		auth.NewAuthorizer(pr.challengeManager, auth.NewTokenHandler(http.DefaultTransport, pr.credentialStore, name.Name(), "pull"))) | ||||
| 
 | ||||
| 	localRepo, err := pr.embedded.Repository(ctx, name) | ||||
| 	if err != nil { | ||||
|  | @ -121,7 +122,7 @@ func (pr *proxyingRegistry) Repository(ctx context.Context, name string) (distri | |||
| type proxiedRepository struct { | ||||
| 	blobStore distribution.BlobStore | ||||
| 	manifests distribution.ManifestService | ||||
| 	name      string | ||||
| 	name      reference.Named | ||||
| 	tags      distribution.TagService | ||||
| } | ||||
| 
 | ||||
|  | @ -133,7 +134,7 @@ func (pr *proxiedRepository) Blobs(ctx context.Context) distribution.BlobStore { | |||
| 	return pr.blobStore | ||||
| } | ||||
| 
 | ||||
| func (pr *proxiedRepository) Name() string { | ||||
| func (pr *proxiedRepository) Name() reference.Named { | ||||
| 	return pr.name | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,6 +7,8 @@ import ( | |||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/docker/distribution/context" | ||||
| 	"github.com/docker/distribution/digest" | ||||
| 	"github.com/docker/distribution/reference" | ||||
| 	"github.com/docker/distribution/registry/storage/driver" | ||||
| ) | ||||
| 
 | ||||
|  | @ -80,19 +82,19 @@ func (ttles *TTLExpirationScheduler) OnManifestExpire(f expiryFunc) { | |||
| } | ||||
| 
 | ||||
| // AddBlob schedules a blob cleanup after ttl expires | ||||
| func (ttles *TTLExpirationScheduler) AddBlob(dgst string, ttl time.Duration) error { | ||||
| func (ttles *TTLExpirationScheduler) AddBlob(dgst digest.Digest, ttl time.Duration) error { | ||||
| 	ttles.Lock() | ||||
| 	defer ttles.Unlock() | ||||
| 
 | ||||
| 	if ttles.stopped { | ||||
| 		return fmt.Errorf("scheduler not started") | ||||
| 	} | ||||
| 	ttles.add(dgst, ttl, entryTypeBlob) | ||||
| 	ttles.add(dgst.String(), ttl, entryTypeBlob) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // AddManifest schedules a manifest cleanup after ttl expires | ||||
| func (ttles *TTLExpirationScheduler) AddManifest(repoName string, ttl time.Duration) error { | ||||
| func (ttles *TTLExpirationScheduler) AddManifest(repoName reference.Named, ttl time.Duration) error { | ||||
| 	ttles.Lock() | ||||
| 	defer ttles.Unlock() | ||||
| 
 | ||||
|  | @ -100,7 +102,7 @@ func (ttles *TTLExpirationScheduler) AddManifest(repoName string, ttl time.Durat | |||
| 		return fmt.Errorf("scheduler not started") | ||||
| 	} | ||||
| 
 | ||||
| 	ttles.add(repoName, ttl, entryTypeManifest) | ||||
| 	ttles.add(repoName.Name(), ttl, entryTypeManifest) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue