Mercurial > hg > orthanc-indexer
view Sources/StorageArea.cpp @ 26:2f410de7715d default tip
added CITATION.cff
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Sat, 06 Apr 2024 17:20:59 +0200 |
parents | ca40236fda57 |
children |
line wrap: on
line source
/** * Indexer plugin for Orthanc * Copyright (C) 2021-2024 Sebastien Jodogne, UCLouvain, Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #include "StorageArea.h" #include "../Resources/Orthanc/Plugins/OrthancPluginCppWrapper.h" #include <Toolbox.h> #include <SystemToolbox.h> #include <OrthancException.h> #include <boost/filesystem.hpp> static boost::filesystem::path GetPathInternal(const std::string& root, const std::string& uuid) { if (!Orthanc::Toolbox::IsUuid(uuid)) { throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); } else { assert(!root.empty()); boost::filesystem::path path = root; path /= std::string(&uuid[0], &uuid[2]); path /= std::string(&uuid[2], &uuid[4]); path /= uuid; path.make_preferred(); return path; } } static void CreateOrthancBuffer(OrthancPluginMemoryBuffer64 *target, const std::string& content) { OrthancPluginErrorCode code = OrthancPluginCreateMemoryBuffer64( OrthancPlugins::GetGlobalContext(), target, content.size()); if (code == OrthancPluginErrorCode_Success) { assert(content.size() == target->size); if (!content.empty()) { memcpy(target->data, content.c_str(), content.size()); } } else { throw Orthanc::OrthancException(static_cast<Orthanc::ErrorCode>(code)); } } void StorageArea::ReadWholeFromPath(OrthancPluginMemoryBuffer64 *target, const std::string& path) { std::string content; Orthanc::SystemToolbox::ReadFile(content, path); CreateOrthancBuffer(target, content); } void StorageArea::ReadRangeFromPath(OrthancPluginMemoryBuffer64 *target, const std::string& path, uint64_t rangeStart) { std::string content; Orthanc::SystemToolbox::ReadFileRange( content, path, rangeStart, rangeStart + target->size, true); if (content.size() != target->size) { throw Orthanc::OrthancException(Orthanc::ErrorCode_CorruptedFile); } else if (!content.empty()) { memcpy(target->data, content.c_str(), content.size()); } } StorageArea::StorageArea(const std::string& root) : root_(root) { if (root_.empty()) { throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); } } void StorageArea::Create(const std::string& uuid, const void *content, int64_t size) { boost::filesystem::path path = GetPathInternal(root_, uuid); if (boost::filesystem::exists(path.parent_path())) { if (!boost::filesystem::is_directory(path.parent_path())) { throw Orthanc::OrthancException(Orthanc::ErrorCode_DirectoryOverFile); } } else { if (!boost::filesystem::create_directories(path.parent_path())) { throw Orthanc::OrthancException(Orthanc::ErrorCode_FileStorageCannotWrite); } } Orthanc::SystemToolbox::WriteFile(content, size, path.string(), false); } void StorageArea::ReadWhole(std::string& target, const std::string& uuid) { Orthanc::SystemToolbox::ReadFile(target, GetPath(uuid)); } void StorageArea::ReadWhole(OrthancPluginMemoryBuffer64 *target, const std::string& uuid) { ReadWholeFromPath(target, GetPath(uuid)); } void StorageArea::ReadRange(OrthancPluginMemoryBuffer64 *target, const std::string& uuid, uint64_t rangeStart) { ReadRangeFromPath(target, GetPath(uuid), rangeStart); } void StorageArea::RemoveAttachment(const std::string& uuid) { boost::filesystem::path path = GetPathInternal(root_, uuid); try { boost::system::error_code err; boost::filesystem::remove(path, err); boost::filesystem::remove(path.parent_path(), err); boost::filesystem::remove(path.parent_path().parent_path(), err); } catch (...) { // Ignore the error } } std::string StorageArea::GetPath(const std::string& uuid) const { return GetPathInternal(root_, uuid).string(); }