/* Copyright 2010-2011 Grégory Soutadé This file is part of KissCount. KissCount 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. KissCount 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 KissCount. If not, see . */ #ifndef DATABASE_H #define DATABASE_H #include #include #include #include #include #include #include "model.h" #include "../controller/KissCount.h" #define DATABASE_VERSION 2 #define BDD_FILE "kc.bdd" #define INIT_SCRIPT "init.sql" #define FIX_OP (1 << 0) #define NON_FIX_OP (1 << 1) #define CHECKED_OP (1 << 2) #define NOT_CHECKED_OP (1 << 3) // if (!_db.CheckSyntax(req)) // { // wxString s = req; // std::cout << s.mb_str() << " is invalid !\n" ; // code_if_syntax_fail; // return return_value; // } #define EXECUTE_SQL_UPDATE_WITH_CODE(req, return_value, code_if_fail, code_if_syntax_fail) \ do{ \ try \ { \ _db.ExecuteUpdate(req); \ } \ catch (wxSQLite3Exception e) \ { \ wxMessageBox(_("Update failed !\n") + req, _("Error"), wxICON_ERROR | wxOK); \ std::cerr << __FUNCTION__ << "\n" ; \ std::cerr << req.mb_str() << "\n" ; \ std::cerr << e.GetMessage().mb_str() << "\n" ; \ code_if_fail; \ return return_value; \ } \ } while(0); #define EXECUTE_SQL_QUERY_WITH_CODE(req, res, return_value, code_if_fail, code_if_syntax_fail) \ do{ \ try \ { \ res = _db.ExecuteQuery(req); \ } \ catch (wxSQLite3Exception e) \ { \ wxMessageBox(_("Query failed !\n") + req, _("Error"), wxICON_ERROR | wxOK); \ std::cerr << __FUNCTION__ << "\n" ; \ std::cerr << req.mb_str() << "\n" ; \ std::cerr << e.GetMessage().mb_str() << "\n" ; \ code_if_fail; \ return return_value; \ } \ } while(0); #define EXECUTE_SQL_QUERY(req, res, return_value) EXECUTE_SQL_QUERY_WITH_CODE(req, res, return_value, {}, {}) #define EXECUTE_SQL_UPDATE(req, return_value) EXECUTE_SQL_UPDATE_WITH_CODE(req, return_value, {}, {}) #define ESCAPE_CHARS(s) { \ if (s.Find(wxT("\\\"")) == wxNOT_FOUND) \ s.Replace(wxT("\""), wxT("\\\""), true); \ if (s.Find(wxT("\\\'")) == wxNOT_FOUND) \ s.Replace(wxT("\'"), wxT("\\\'"), true); \ } class KissCount; class User; class Database { public: Database(const char* filename, KissCount* kiss); std::list GetUsers(); bool IsValidUser(const wxString& user, const wxString& password); User* LoadUser(const wxString& name); void LoadYear(User* user, int year); void UpdateOperation(Operation& op); wxString AddOperation(User* user, Operation& op); void DeleteOperation(Operation& op); void DeleteOperations(User* user, int month, int year); bool LoadOperation(User* user, const wxString& id); double MetaAmount(const wxString& id); double MetaPositiveAmount(const wxString& id); double GetAccountAmount(const wxString& id, int month, int year); void SetAccountAmount(int month, int year, const wxString& accountId, double amount); double CalcAccountAmount(const wxString& id, int month, int year, bool* had_values); wxString AddAccount(User* user, Account& ac); void UpdateAccount(Account& ac); void DeleteAccount(User* user, Account& ac, const wxString& replacement); void AddSharedAccount(Account& ac, const wxString& granted); void RemoveSharedAccount(Account& ac, const wxString& granted); wxString AddCategory(User* user, Category& category); void UpdateCategory(Category& category); void DeleteCategory(User* user, Category& category, const wxString& replacement); bool LoadCategory(const wxString& id, const wxString& name, Category& category); std::map > GetAllOperations(User* user); void GenerateMonth(User* user, int monthFrom, int yearFrom, int monthTo, int yearTo); void ChangePassword(User* user, const wxString& password); bool UserExists(const wxString& name); void ChangeName(User* user, const wxString& name); void NewUser(const wxString& name); void UpdatePreference(User* user, const wxString& preference); std::vector* Search(User* user, wxString* description, wxDateTime* dateFrom, wxDateTime* dateTo, wxString* amountFrom, wxString* amountTo, std::vector categories, int types, std::vector accounts, bool wildcards); void GetStats(User* user, const wxString& monthFrom, const wxString& yearFrom, const wxString& monthTo, const wxString& yearTo, std::map > >* accountAmounts, std::map* categories); void GetMonthStats(User* user, const wxString& month, const wxString& year, int nbDays, std::map >* operations, std::map* categories); void KillMe(User* user); bool GetOperation(const wxString& id, Operation* op); std::map getSharedAccountOwners(const wxString& account); wxString getSharedAccountOwner(const wxString& account); std::map* GetNotChecked(User* user, int month, int year); /* Database Update */ void CheckDatabaseVersion(); private: KissCount* _kiss; wxSQLite3Database _db; void CreateDatabase(); wxString HashPassword(const wxString& password); void LinkOrUnlinkOperation(Operation& op); }; #endif