Customer almost done. need to make ctor that can make Customer from db

This commit is contained in:
MassiveAtoms
2019-06-26 23:32:06 -03:00
parent b377ca043d
commit 77919e4ce0
5 changed files with 76 additions and 32 deletions

View File

@ -20,13 +20,7 @@ enum class Verhicle_type {
};
/*
db repr of Customer
int id (not null, auto increment)
string name (not nulll)
string card_code (not null)
Dit moet nog verandert worden.
card code zou eigenlijk een randomly generated string moeten zijn, die je bv. op een ndf card zou opslaan en zo zou
card code is een randomly generated string moeten zijn, die je bv. op een nfc card zou opslaan en zo zou
authenticaten bij je parking spot. We kunnen dit ipv of samen met een password gebruiken.
clock in en out creeert en compleet een park_time object. Voegt het toe aan een vector.
@ -34,20 +28,31 @@ clock in en out creeert en compleet een park_time object. Voegt het toe aan een
class Customer {
public:
Customer(string name_, Verhicle_type verhicle_, SQLite::Database& db);
Customer(int id_, string name_, string card_code_, Verhicle_type verhicle_,
vector<Park_time> instances); // needed to construct from db
// potentially: add a destructor that calls update_db() before being destroyed
int id;
string name;
string card_code;
void clock_in(int s_id);
void clock_out(int s_id);
void update_db(SQLite::Database& database);
void delete_db(SQLite::Database& database);
// void gen_weekly(); TODO: this
void gen_monthly();
Customer(int id_, string name_, Verhicle_type verhicle_);
void update_db(SQLite::Database& database);
private:
Verhicle_type verhicle;
vector<Park_time> park_instances;
string gen_cardcode();
void save_db(SQLite::Database& database);
int auto_increment_db(SQLite::Database& database);
};
#endif // CUSTOMER_H