/*
*openPilotLog - A FOSS Pilot Logbook Application
*Copyright (C) 2020-2022 Felix Turowsky
*
*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 .
*/
#ifndef DBSETUP_H
#define DBSETUP_H
#include
#include
#include
#define DATABASE_REVISION 17
const auto TEMPLATE_URL = QStringLiteral("https://raw.githubusercontent.com/fiffty-50/openpilotlog/develop/assets/database/templates/");
/*!
* \brief The DataBaseSetup class is responsible for the inital setup of the database when
* the application is first launched. It creates the database in the specified default
* location and creates all required tables and views. It can also be used to reset the
* database currently used
*/
class DataBaseSetup
{
public:
static void debug();
static bool createDatabase();
static bool downloadTemplates();
static bool backupOldData();
static bool fillTemplates();
static bool importDefaultData(bool use_local_data);
static bool resetToDefault();
static bool commitData(QVector from_csv, const QString &table_name);
/*!
* \brief commitDataJson Commits data read from a JSON array to the database.
* \param json_arr
* \param table_name The table that will be written to
*/
static bool commitDataJson(const QJsonArray &json_arr, const QString &table_name);
private:
static bool createSchemata(const QStringList &statements);
};
#endif // DBSETUP_H