Mercurial > hg > orthanc-databases
view PostgreSQL/Plugins/PostgreSQLIndex.h @ 144:740d9829f52e
handling of errors if MySQL user cannot CREATE TRIGGER
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 12 Mar 2020 12:10:52 +0100 |
parents | 0b3e9ee53c46 |
children | 3236894320d6 |
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-2020 Osimis S.A., Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #pragma once #include "../../Framework/Plugins/IndexBackend.h" #include "../../Framework/PostgreSQL/PostgreSQLParameters.h" namespace OrthancDatabases { class PostgreSQLIndex : public IndexBackend { private: class Factory : public IDatabaseFactory { private: PostgreSQLIndex& that_; public: Factory(PostgreSQLIndex& that) : that_(that) { } virtual Dialect GetDialect() const { return Dialect_PostgreSQL; } virtual IDatabase* Open() { return that_.OpenInternal(); } virtual void GetConnectionRetriesParameters(unsigned int& maxConnectionRetries, unsigned int& connectionRetryInterval) { maxConnectionRetries = that_.parameters_.GetMaxConnectionRetries(); connectionRetryInterval = that_.parameters_.GetConnectionRetryInterval(); } }; OrthancPluginContext* context_; PostgreSQLParameters parameters_; bool clearAll_; IDatabase* OpenInternal(); public: PostgreSQLIndex(const PostgreSQLParameters& parameters); void SetOrthancPluginContext(OrthancPluginContext* context) { context_ = context; } void SetClearAll(bool clear) { clearAll_ = clear; } virtual int64_t CreateResource(const char* publicId, OrthancPluginResourceType type) ORTHANC_OVERRIDE; virtual uint64_t GetTotalCompressedSize() ORTHANC_OVERRIDE; virtual uint64_t GetTotalUncompressedSize() ORTHANC_OVERRIDE; virtual bool HasCreateInstance() const ORTHANC_OVERRIDE { return true; } #if ORTHANC_PLUGINS_HAS_DATABASE_CONSTRAINT == 1 virtual void CreateInstance(OrthancPluginCreateInstanceResult& result, const char* hashPatient, const char* hashStudy, const char* hashSeries, const char* hashInstance) ORTHANC_OVERRIDE; #endif virtual uint64_t GetResourceCount(OrthancPluginResourceType resourceType) ORTHANC_OVERRIDE; virtual int64_t GetLastChangeIndex() ORTHANC_OVERRIDE; virtual void TagMostRecentPatient(int64_t patient) ORTHANC_OVERRIDE; }; }