mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-16 11:22:12 +00:00
133 lines
6.4 KiB
C++
133 lines
6.4 KiB
C++
#pragma once
|
|
|
|
#include "Disks/IDisk.h"
|
|
|
|
namespace DB
|
|
{
|
|
|
|
/** Forwards all methods to another disk.
|
|
* Methods can be overridden by descendants.
|
|
*/
|
|
class DiskDecorator : public IDisk
|
|
{
|
|
public:
|
|
explicit DiskDecorator(const DiskPtr & delegate_);
|
|
|
|
DiskTransactionPtr createTransaction() override;
|
|
const String & getName() const override;
|
|
ReservationPtr reserve(UInt64 bytes) override;
|
|
~DiskDecorator() override = default;
|
|
const String & getPath() const override;
|
|
UInt64 getTotalSpace() const override;
|
|
UInt64 getAvailableSpace() const override;
|
|
UInt64 getUnreservedSpace() const override;
|
|
UInt64 getKeepingFreeSpace() const override;
|
|
bool exists(const String & path) const override;
|
|
bool isFile(const String & path) const override;
|
|
bool isDirectory(const String & path) const override;
|
|
size_t getFileSize(const String & path) const override;
|
|
void createDirectory(const String & path) override;
|
|
void createDirectories(const String & path) override;
|
|
void clearDirectory(const String & path) override;
|
|
void moveDirectory(const String & from_path, const String & to_path) override;
|
|
DirectoryIteratorPtr iterateDirectory(const String & path) const override;
|
|
void createFile(const String & path) override;
|
|
void moveFile(const String & from_path, const String & to_path) override;
|
|
void replaceFile(const String & from_path, const String & to_path) override;
|
|
void copy(const String & from_path, const std::shared_ptr<IDisk> & to_disk, const String & to_path) override;
|
|
void copyDirectoryContent(const String & from_dir, const std::shared_ptr<IDisk> & to_disk, const String & to_dir) override;
|
|
void listFiles(const String & path, std::vector<String> & file_names) const override;
|
|
|
|
std::unique_ptr<ReadBufferFromFileBase> readFile(
|
|
const String & path,
|
|
const ReadSettings & settings,
|
|
std::optional<size_t> read_hint,
|
|
std::optional<size_t> file_size) const override;
|
|
|
|
std::unique_ptr<WriteBufferFromFileBase> writeFile(
|
|
const String & path,
|
|
size_t buf_size,
|
|
WriteMode mode,
|
|
const WriteSettings & settings) override;
|
|
|
|
void removeFile(const String & path) override;
|
|
void removeFileIfExists(const String & path) override;
|
|
void removeSharedFileIfExists(const String & path, bool keep_s3) override;
|
|
|
|
void removeDirectory(const String & path) override;
|
|
void removeRecursive(const String & path) override;
|
|
|
|
void removeSharedFile(const String & path, bool keep_s3) override;
|
|
void removeSharedRecursive(const String & path, bool keep_all_batch_data, const NameSet & file_names_remove_metadata_only) override;
|
|
void removeSharedFiles(const RemoveBatchRequest & files, bool keep_all_batch_data, const NameSet & file_names_remove_metadata_only) override;
|
|
|
|
void setLastModified(const String & path, const Poco::Timestamp & timestamp) override;
|
|
time_t getLastChanged(const String & path) const override;
|
|
Poco::Timestamp getLastModified(const String & path) const override;
|
|
void setReadOnly(const String & path) override;
|
|
void createHardLink(const String & src_path, const String & dst_path) override;
|
|
void truncateFile(const String & path, size_t size) override;
|
|
int open(const String & path, mode_t mode) const;
|
|
void close(int fd) const;
|
|
void sync(int fd) const;
|
|
String getUniqueId(const String & path) const override { return delegate->getUniqueId(path); }
|
|
bool checkUniqueId(const String & id) const override { return delegate->checkUniqueId(id); }
|
|
DiskType getType() const override { return delegate->getType(); }
|
|
bool isRemote() const override { return delegate->isRemote(); }
|
|
bool supportZeroCopyReplication() const override { return delegate->supportZeroCopyReplication(); }
|
|
bool supportParallelWrite() const override { return delegate->supportParallelWrite(); }
|
|
void onFreeze(const String & path) override;
|
|
SyncGuardPtr getDirectorySyncGuard(const String & path) const override;
|
|
void shutdown() override;
|
|
void startup(ContextPtr context) override;
|
|
void applyNewSettings(const Poco::Util::AbstractConfiguration & config, ContextPtr context, const String & config_prefix, const DisksMap & map) override;
|
|
|
|
bool supportsCache() const override { return delegate->supportsCache(); }
|
|
String getCacheBasePath() const override { return delegate->getCacheBasePath(); }
|
|
|
|
StoredObjects getStorageObjects(const String & path) const override { return delegate->getStorageObjects(path); }
|
|
DiskObjectStoragePtr createDiskObjectStorage(const String &) override;
|
|
|
|
void getRemotePathsRecursive(const String & path, std::vector<LocalPathWithObjectStoragePaths> & paths_map) override { return delegate->getRemotePathsRecursive(path, paths_map); }
|
|
|
|
MetadataStoragePtr getMetadataStorage() override { return delegate->getMetadataStorage(); }
|
|
|
|
std::unordered_map<String, String> getSerializedMetadata(const std::vector<String> & file_paths) const override { return delegate->getSerializedMetadata(file_paths); }
|
|
|
|
UInt32 getRefCount(const String & path) const override { return delegate->getRefCount(path); }
|
|
|
|
void syncRevision(UInt64 revision) override { delegate->syncRevision(revision); }
|
|
UInt64 getRevision() const override { return delegate->getRevision(); }
|
|
|
|
bool supportsStat() const override { return delegate->supportsStat(); }
|
|
struct stat stat(const String & path) const override { return delegate->stat(path); }
|
|
|
|
bool supportsChmod() const override { return delegate->supportsChmod(); }
|
|
void chmod(const String & path, mode_t mode) override { delegate->chmod(path, mode); }
|
|
|
|
protected:
|
|
Executor & getExecutor() override;
|
|
|
|
DiskPtr delegate;
|
|
};
|
|
|
|
/// TODO: Current reservation mechanism leaks IDisk abstraction details.
|
|
/// This hack is needed to return proper disk pointer (wrapper instead of implementation) from reservation object.
|
|
class ReservationDelegate : public IReservation
|
|
{
|
|
public:
|
|
ReservationDelegate(ReservationPtr delegate_, DiskPtr wrapper_) : delegate(std::move(delegate_)), wrapper(wrapper_) { }
|
|
UInt64 getSize() const override { return delegate->getSize(); }
|
|
UInt64 getUnreservedSpace() const override { return delegate->getUnreservedSpace(); }
|
|
DiskPtr getDisk(size_t) const override { return wrapper; }
|
|
Disks getDisks() const override { return {wrapper}; }
|
|
void update(UInt64 new_size) override { delegate->update(new_size); }
|
|
|
|
private:
|
|
ReservationPtr delegate;
|
|
DiskPtr wrapper;
|
|
};
|
|
|
|
|
|
}
|