Mercurial > hg > orthanc
view OrthancServer/Sources/Database/ResourcesContent.h @ 5729:bdbaccc06e98
Fix extremely rare error when 2 threads are trying to create the same folder in the File Storage at the same time
author | Alain Mazy <am@orthanc.team> |
---|---|
date | Fri, 26 Jul 2024 16:29:10 +0200 |
parents | f7adfb22e20e |
children |
line wrap: on
line source
/** * Orthanc - A Lightweight, RESTful DICOM Store * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017-2023 Osimis S.A., Belgium * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM 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/>. **/ #pragma once #include "../../../OrthancFramework/Sources/DicomFormat/DicomMap.h" #include "../ServerEnumerations.h" #include <boost/noncopyable.hpp> #include <list> namespace Orthanc { namespace Compatibility { class ISetResourcesContent; } class ResourcesContent : public boost::noncopyable { public: class TagValue { private: int64_t resourceId_; bool isIdentifier_; DicomTag tag_; std::string value_; public: TagValue(int64_t resourceId, bool isIdentifier, const DicomTag& tag, const std::string& value) : resourceId_(resourceId), isIdentifier_(isIdentifier), tag_(tag), value_(value) { } int64_t GetResourceId() const { return resourceId_; } bool IsIdentifier() const { return isIdentifier_; } const DicomTag& GetTag() const { return tag_; } const std::string& GetValue() const { return value_; } }; class Metadata { private: int64_t resourceId_; MetadataType type_; std::string value_; public: Metadata(int64_t resourceId, MetadataType type, const std::string& value) : resourceId_(resourceId), type_(type), value_(value) { } int64_t GetResourceId() const { return resourceId_; } MetadataType GetType() const { return type_; } const std::string& GetValue() const { return value_; } }; typedef std::list<TagValue> ListTags; typedef std::list<Metadata> ListMetadata; private: bool isNewResource_; ListTags tags_; ListMetadata metadata_; public: explicit ResourcesContent(bool isNewResource) : isNewResource_(isNewResource) { } void AddMainDicomTag(int64_t resourceId, const DicomTag& tag, const std::string& value) { tags_.push_back(TagValue(resourceId, false, tag, value)); } void AddIdentifierTag(int64_t resourceId, const DicomTag& tag, const std::string& value) { tags_.push_back(TagValue(resourceId, true, tag, value)); } void AddMetadata(int64_t resourceId, MetadataType metadata, const std::string& value); void AddResource(int64_t resource, ResourceType level, const DicomMap& dicomSummary); // WARNING: The database should be locked with a transaction! void Store(Compatibility::ISetResourcesContent& target) const; const ListTags& GetListTags() const { return tags_; } const ListMetadata& GetListMetadata() const { return metadata_; } }; }