Skip to content

Commit

Permalink
registry: implement blob deletion (#1432)
Browse files Browse the repository at this point in the history
  • Loading branch information
imjasonh authored Oct 19, 2022
1 parent 969699e commit d3ed408
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 0 deletions.
38 changes: 38 additions & 0 deletions pkg/registry/blobs.go
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,13 @@ type blobPutHandler interface {
Put(ctx context.Context, repo string, h v1.Hash, rc io.ReadCloser) error
}

// blobDeleteHandler is an extension interface representing a blob storage
// backend that can delete blob contents.
type blobDeleteHandler interface {
// Delete the blob contents.
Delete(ctx context.Context, repo string, h v1.Hash) error
}

// redirectError represents a signal that the blob handler doesn't have the blob
// contents, but that those contents are at another location which registry
// clients should redirect to.
Expand Down Expand Up @@ -129,6 +136,17 @@ func (m *memHandler) Put(_ context.Context, _ string, h v1.Hash, rc io.ReadClose
m.m[h.String()] = all
return nil
}
func (m *memHandler) Delete(_ context.Context, _ string, h v1.Hash) error {
m.lock.Lock()
defer m.lock.Unlock()

if _, found := m.m[h.String()]; !found {
return errNotFound
}

delete(m.m, h.String())
return nil
}

// blobs
type blobs struct {
Expand Down Expand Up @@ -435,6 +453,26 @@ func (b *blobs) handle(resp http.ResponseWriter, req *http.Request) *regError {
resp.WriteHeader(http.StatusCreated)
return nil

case http.MethodDelete:
bdh, ok := b.blobHandler.(blobDeleteHandler)
if !ok {
return regErrUnsupported
}

h, err := v1.NewHash(target)
if err != nil {
return &regError{
Status: http.StatusBadRequest,
Code: "NAME_INVALID",
Message: "invalid digest",
}
}
if err := bdh.Delete(req.Context(), repo, h); err != nil {
return regErrInternal(err)
}
resp.WriteHeader(http.StatusAccepted)
return nil

default:
return &regError{
Status: http.StatusBadRequest,
Expand Down
7 changes: 7 additions & 0 deletions pkg/registry/registry_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,13 @@ func TestCalls(t *testing.T) {
"Docker-Content-Digest": "sha256:2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae",
},
},
{
Description: "DELETE blob",
Digests: map[string]string{"sha256:2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae": "foo"},
Method: "DELETE",
URL: "/v2/foo/blobs/sha256:2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae",
Code: http.StatusAccepted,
},
{
Description: "blob url with no container",
Method: "GET",
Expand Down

0 comments on commit d3ed408

Please sign in to comment.