/* Copyright 2010 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 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) 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); wxString AddAccount(User* user, Account& ac); void UpdateAccount(Account& ac); void DeleteAccount(User* user, Account& ac); 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); 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); private: KissCount* _kiss; wxSQLite3Database _db; void CreateDatabase(); wxString HashPassword(const wxString& password); void LinkOrUnlinkOperation(Operation& op); }; #endif