source: network-game/server/DataAccess.cpp@ e98426d

Last change on this file since e98426d was 95d7add, checked in by Dmitry Portnoy <dmp1488@…>, 11 years ago

more rebust error handling in the data-access code, specifically in cases where the initial database connection failes

  • Property mode set to 100644
File size: 4.8 KB
RevLine 
[36082e8]1#include "DataAccess.h"
2
3#include <iostream>
[59061f6]4#include <sstream>
[b128109]5#include <cstdlib>
[b72ed16]6#include <crypt.h>
[36082e8]7
8using namespace std;
9
10DataAccess::DataAccess()
11{
[59061f6]12 mysql_init(&mysql);
13 connection = mysql_real_connect(&mysql, "localhost", "pythonAdmin", "pyMaster09*", "pythondb", 0, 0, 0);
14
15 if (connection == NULL) {
16 cout << mysql_error(&mysql) << endl;
17 }else
18 cout << "Connection successful" << endl;
[36082e8]19}
20
21DataAccess::~DataAccess()
22{
[59061f6]23 mysql_close(connection);
24 mysql_close(&mysql);
[36082e8]25}
26
[521c88b]27int DataAccess::insertPlayer(string username, string password, Player::PlayerClass playerClass)
[59061f6]28{
29 ostringstream oss;
30
[b128109]31 string salt = "$1$";
32 int random;
33 char chr;
34 for(int i=0; i<8; i++)
35 {
36 random = rand() % 62;
37 if (random < 26)
38 chr = (char)('a'+random);
39 else if (random < 52)
40 chr = (char)('A'+random-26);
41 else
42 chr = (char)('0'+random-52);
43 salt += chr;
44 }
45 salt += '$';
46
47 string encrypted(crypt(password.c_str(), salt.c_str()));
48
[521c88b]49 oss << "'" << username << "', '" << encrypted << "', " << playerClass;
[59061f6]50
[521c88b]51 return insert("users", "name, password, class", oss.str());
[59061f6]52}
53
[b128109]54int DataAccess::updatePlayer(string username, string password)
55{
56 ostringstream values, where;
57
58 values << "password='" << password << "'";
59
60 where << "name='" << username << "'";
61
62 return update("users", values.str(), where.str());
63}
64
[59061f6]65Player *DataAccess::getPlayer(string username)
[36082e8]66{
67 MYSQL_RES *result;
68 MYSQL_ROW row;
[59061f6]69 Player *p;
70 ostringstream oss;
[36082e8]71
[59061f6]72 oss << "name='" << username << "'";
[36082e8]73
[59061f6]74 result = select("users", oss.str().c_str());
[36082e8]75
[41ad8ed]76 cout << "Got result" << endl;
77
[59061f6]78 if (result == NULL) {
[41ad8ed]79 cout << "Error occured" << endl;
[59061f6]80 cout << mysql_error(connection) << endl;
81 return NULL;
82 }
83
[60017fc]84 if ( ( row = mysql_fetch_row(result)) != NULL ) {
85 cout << "Creating a new player" << endl;
[59061f6]86 p = new Player(string(row[1]), string(row[2]));
[7ca5d21]87 if (row[3] == NULL) {
88 p->setClass(Player::CLASS_NONE);
89 cout << "Class from db was NULL" << endl;
90 }else {
91 p->setClass((Player::PlayerClass)atoi(row[3]));
92 cout << "Class from db: " << atoi(row[3]) << endl;
93 }
[521c88b]94 cout << "Player class: " << p->playerClass << endl;
[c76134b]95 cout << "Created new player" << endl;
[60017fc]96 }else {
[41ad8ed]97 cout << "Returned no results for some reason" << endl;
[59061f6]98 p = NULL;
[41ad8ed]99 }
[36082e8]100
[59061f6]101 mysql_free_result(result);
[36082e8]102
[59061f6]103 return p;
104}
105
[b128109]106// need to make sure this list is freed
107// since we need to create a DataAccess class
108// when calling these functions,
109// we could free this list in the destructor
110list<Player*>* DataAccess::getPlayers()
[59061f6]111{
112 MYSQL_RES *result;
113 MYSQL_ROW row;
114 ostringstream oss;
115
116 result = select("users", "");
117
118 if (result == NULL) {
[36082e8]119 cout << mysql_error(connection) << endl;
[b128109]120 return NULL;
[36082e8]121 }
122
[b128109]123 list<Player*>* lstPlayers = new list<Player*>();
[36082e8]124 while ( ( row = mysql_fetch_row(result)) != NULL ) {
125 cout << row[0] << ", " << row[1] << ", " << row[2] << endl;
[b128109]126 lstPlayers->push_back(new Player(row[1], row[2]));
[36082e8]127 }
128
129 mysql_free_result(result);
130
[b128109]131 return lstPlayers;
132}
133
134bool DataAccess::verifyPassword(string password, string encrypted)
135{
136 string test(crypt(password.c_str(), encrypted.c_str()));
137
138 return encrypted.compare(test) == 0;
139}
140
141int DataAccess::insert(string table, string columns, string values)
142{
143 int query_state;
144 ostringstream oss;
145
[95d7add]146 if (connection == NULL) {
147 cout << "Error: non database connection exists" << endl;
148 return -1;
149 }
150
[b128109]151 oss << "INSERT into " << table << " (" << columns << ") VALUES (" << values << ")";
152 cout << "query: " << oss.str() << endl;
153
154 query_state = mysql_query(connection, oss.str().c_str());
155
156 if (query_state != 0) {
157 cout << mysql_error(connection) << endl;
158 return 1;
159 }
160
[59061f6]161 return 0;
162}
163
[b128109]164int DataAccess::update(string table, string values, string where)
[59061f6]165{
166 int query_state;
167 ostringstream oss;
168
[95d7add]169 if (connection == NULL) {
170 cout << "Error: non database connection exists" << endl;
171 return -1;
172 }
173
[b128109]174 oss << "UPDATE " << table << " SET " << values << " WHERE " << where;
[59061f6]175 cout << "query: " << oss.str() << endl;
176
177 query_state = mysql_query(connection, oss.str().c_str());
178
179 if (query_state != 0) {
180 cout << mysql_error(connection) << endl;
181 return 1;
182 }
[36082e8]183
184 return 0;
185}
[59061f6]186
187MYSQL_RES *DataAccess::select(string table, string filter)
188{
189 int query_state;
190 ostringstream oss;
191
[95d7add]192 if (connection == NULL) {
193 cout << "Error: non database connection exists" << endl;
194 return NULL;
195 }
196
[59061f6]197 oss << "SELECT * FROM " << table;
198 if (!filter.empty())
199 oss << " WHERE " << filter;
200
201 query_state = mysql_query(connection, oss.str().c_str());
202
203 if (query_state != 0) {
204 cout << mysql_error(connection) << endl;
205 return NULL;
206 }
207
208 return mysql_store_result(connection);
209}
Note: See TracBrowser for help on using the repository browser.