Page MenuHomePhabricator

[blob] Add struct for representing unchecked blobs
ClosedPublic

Authored by bartek on Oct 4 2023, 3:02 AM.
Tags
None
Referenced Files
F3848338: D9350.diff
Tue, Jan 21, 3:20 AM
Unknown Object (File)
Wed, Jan 15, 10:15 AM
Unknown Object (File)
Sat, Jan 11, 7:05 PM
Unknown Object (File)
Sat, Jan 11, 12:33 AM
Unknown Object (File)
Thu, Dec 26, 6:54 PM
Unknown Object (File)
Thu, Dec 26, 6:54 PM
Unknown Object (File)
Thu, Dec 26, 6:54 PM
Unknown Object (File)
Thu, Dec 26, 6:54 PM
Subscribers

Details

Summary

Added a struct for representing unchecked items in database. It greatly simplifies the cleanup job.
It is used in the next two diffs

Depends on D9349

Test Plan

Code compiles, implementation is tested in the next two diffs.

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.Oct 4 2023, 3:20 AM
tomek added 1 blocking reviewer(s): michal.
michal added inline comments.
services/blob/src/service.rs
232–235

From looking at the later code it seems like we could just have:

struct UncheckedItem {
  has_hash: bool,
  holders: Vec<String>,
};

but it's fine the way it is now.

If dynamodb allowed deletion with just partition key we could even just have has_holders: bool...

277

Can you add a comment (or a type alias) that explains what a String is in this case?

This revision is now accepted and ready to land.Oct 10 2023, 6:09 AM
services/blob/src/service.rs
232–235

Theoretically yes, at some point I even considered that. However, I wanted each UncheckedItem to be independent: to contain full information about blob, regardless if it's inside or outside a map-like collection.

Address feedback: Add type alias for blob hash, use ref instead of cloning.