Page MenuHomePhabricator

[services][blob] Implement Delete blob HTTP handler
ClosedPublic

Authored by bartek on Apr 17 2023, 6:09 AM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 17, 11:14 PM
Unknown Object (File)
Thu, Jan 9, 1:56 AM
Unknown Object (File)
Wed, Jan 8, 12:28 PM
Unknown Object (File)
Wed, Jan 8, 12:24 PM
Unknown Object (File)
Wed, Jan 8, 11:47 AM
Unknown Object (File)
Tue, Jan 7, 7:04 PM
Unknown Object (File)
Thu, Jan 2, 7:45 AM
Unknown Object (File)
Sat, Dec 28, 10:19 PM
Subscribers

Details

Summary

Resolves ENG-3524

THis diff implements the DELETE /blob/{holder} endpoint which revokes a blob holder. If last holder is revoked, the blob is deleted. This behavior is the same as for Remove blob RPC.

Depends on D7465

Test Plan

Created a blob with a few holders and called this endpoint to remove them one by one.
Calling GET before returns HTTP 200, after deleting returns HTTP 404 as expected.

Diff Detail

Repository
rCOMM Comm
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

bartek held this revision as a draft.
bartek published this revision for review.Apr 18 2023, 12:07 AM
services/blob/src/http/handlers/blob.rs
118

For debugging, this might be nice. Will probably need to borrow / clone &blob_hash earlier.

If this always expected to be empty, we should probably emit the error.

tomek added inline comments.
services/blob/src/http/handlers/blob.rs
96–111

It is theoretically possible for someone to add a new holder between these operations. This is an edge case and fixing it won't be easy.

This revision is now accepted and ready to land.Apr 19 2023, 2:03 AM
services/blob/src/http/handlers/blob.rs
96–111

Yes, unfortunately there is a possibility.

118

Good idea for the debug! here.

If this always expected to be empty, we should probably emit the error.

No, if it's not empty, it means there are still references to the S3 object so we delete the reference (holder) only and not the object itself

Add debug log when S3 object is not deleted