2021-01-30 20:16:14 +01:00
|
|
|
package it.cavallium.dbengine.client;
|
|
|
|
|
2021-05-05 17:31:21 +02:00
|
|
|
import io.netty.buffer.ByteBufAllocator;
|
2021-06-26 02:35:33 +02:00
|
|
|
import reactor.core.publisher.Flux;
|
2021-01-30 20:16:14 +01:00
|
|
|
import reactor.core.publisher.Mono;
|
|
|
|
|
|
|
|
public interface CompositeDatabase {
|
|
|
|
|
|
|
|
Mono<Void> close();
|
|
|
|
|
2021-06-26 02:35:33 +02:00
|
|
|
/**
|
|
|
|
* Can return SnapshotException
|
|
|
|
*/
|
|
|
|
Mono<CompositeSnapshot> takeSnapshot();
|
2021-01-30 20:16:14 +01:00
|
|
|
|
2021-06-26 02:35:33 +02:00
|
|
|
/**
|
|
|
|
* Can return SnapshotException
|
|
|
|
*/
|
|
|
|
Mono<Void> releaseSnapshot(CompositeSnapshot snapshot);
|
2021-05-05 17:31:21 +02:00
|
|
|
|
|
|
|
ByteBufAllocator getAllocator();
|
2021-06-26 02:35:33 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Find corrupted items
|
|
|
|
*/
|
|
|
|
Flux<BadBlock> badBlocks();
|
2021-06-27 15:06:48 +02:00
|
|
|
|
|
|
|
Mono<Void> verifyChecksum();
|
2021-01-30 20:16:14 +01:00
|
|
|
}
|