file_db_container.h 2.01 KB
Newer Older
1
/*
2
 * Copyright (C) 2014-2019 CZ.NIC
3 4 5 6 7 8 9 10 11 12 13 14
 *
 * 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
15
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16 17 18 19 20 21 22 23
 *
 * In addition, as a special exception, the copyright holders give
 * permission to link the code of portions of this program with the
 * OpenSSL library under certain conditions as described in each
 * individual source file, and distribute linked combinations including
 * the two.
 */

24
#pragma once
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41

#include <QMap>
#include <QString>

#include "src/sqlite/file_db.h"

/*!
 * @brief Database container.
 */
class FileDbContainer : private QMap<QString, FileDb *> {
public:
	explicit FileDbContainer(const QString &connectionName);
	~FileDbContainer(void);

	/*!
	 * @brief Access/create+open message database set related to item.
	 *
42 43
	 * @param[in] locDir Directory where to search for the file.
	 * @param[in] userName ISDS user name.
44
	 * @param[in] storeLocally True if it should be stored in local storage.
45 46
	 * @return Pointer to database, zero pointer on error.
	 */
47 48
	FileDb *accessFileDb(const QString &locDir, const QString &userName,
	    bool storeLocally);
49 50 51 52 53 54 55 56 57 58 59 60

	/*!
	 * @brief Delete all files related to dbset.
	 *
	 * @param db Deleted database.
	 * @return True on success.
	 */
	bool deleteDb(FileDb *db);

	/*!
	 * @brief Creates the database name from supplied information.
	 *
61
	 * @param[in] userName ISDS user name.
62
	 * @return Database name.
63 64 65 66 67 68
	 */
	static
	QString constructDbFileName(const QString &userName);

	const QString m_connectionName;
};