Skip to content
This repository has been archived by the owner on Nov 14, 2024. It is now read-only.

Commit

Permalink
[ASTS] feat(bucket-retrieval): Sweep timestamp manager (#7184)
Browse files Browse the repository at this point in the history
  • Loading branch information
mdaudali authored Jul 13, 2024
1 parent 13f201a commit 5dfda51
Showing 1 changed file with 46 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
/*
* (c) Copyright 2024 Palantir Technologies Inc. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package com.palantir.atlasdb.sweep.asts;

import com.palantir.atlasdb.sweep.Sweeper;
import com.palantir.atlasdb.sweep.queue.ShardAndStrategy;
import com.palantir.atlasdb.sweep.queue.ShardProgress;
import com.palantir.atlasdb.sweep.queue.SpecialTimestampsSupplier;

public final class DefaultShardedSweepTimestampManager implements ShardedSweepTimestampManager {
private final SpecialTimestampsSupplier specialTimestampsSupplier;
private final ShardProgress shardProgress;

private DefaultShardedSweepTimestampManager(
SpecialTimestampsSupplier specialTimestampsSupplier, ShardProgress shardProgress) {
this.specialTimestampsSupplier = specialTimestampsSupplier;
this.shardProgress = shardProgress;
}

public static ShardedSweepTimestampManager create(
SpecialTimestampsSupplier specialTimestampsSupplier, ShardProgress progress) {
return new DefaultShardedSweepTimestampManager(specialTimestampsSupplier, progress);
}

@Override
public SweepTimestamps getSweepTimestamps(ShardAndStrategy shardAndStrategy) {
return SweepTimestamps.builder()
.sweepTimestamp(Sweeper.of(shardAndStrategy).getSweepTimestamp(specialTimestampsSupplier))
.lastSweptTimestamp(shardProgress.getLastSweptTimestamp(shardAndStrategy))
.build();
}
}

0 comments on commit 5dfda51

Please sign in to comment.