51 lines
1.1 KiB
C++
51 lines
1.1 KiB
C++
#include "CryFile.h"
|
|
|
|
#include "CryDevice.h"
|
|
#include "CryOpenFile.h"
|
|
#include "messmer/fspp/fuse/FuseErrnoException.h"
|
|
#include "impl/DirBlob.h"
|
|
|
|
namespace bf = boost::filesystem;
|
|
|
|
//TODO Get rid of this in favor of exception hierarchy
|
|
using fspp::fuse::CHECK_RETVAL;
|
|
using fspp::fuse::FuseErrnoException;
|
|
|
|
using std::unique_ptr;
|
|
using std::make_unique;
|
|
|
|
using blockstore::Key;
|
|
|
|
namespace cryfs {
|
|
|
|
CryFile::CryFile(CryDevice *device, unique_ptr<DirBlob> parent, const Key &key)
|
|
: _device(device),
|
|
_parent(std::move(parent)),
|
|
_key(key) {
|
|
}
|
|
|
|
CryFile::~CryFile() {
|
|
}
|
|
|
|
unique_ptr<fspp::OpenFile> CryFile::open(int flags) const {
|
|
return make_unique<CryOpenFile>(make_unique<FileBlob>(_device->LoadBlob(_key)));
|
|
}
|
|
|
|
void CryFile::stat(struct ::stat *result) const {
|
|
result->st_mode = S_IFREG | S_IRUSR | S_IXUSR | S_IWUSR;
|
|
//TODO Loading the blob for only getting the size is not very performant.
|
|
result->st_size = FileBlob(_device->LoadBlob(_key)).size();
|
|
return;
|
|
throw FuseErrnoException(ENOTSUP);
|
|
}
|
|
|
|
void CryFile::truncate(off_t size) const {
|
|
FileBlob(_device->LoadBlob(_key)).resize(size);
|
|
}
|
|
|
|
void CryFile::unlink() {
|
|
throw FuseErrnoException(ENOTSUP);
|
|
}
|
|
|
|
}
|