-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabasemanager.cpp
More file actions
107 lines (82 loc) · 3.18 KB
/
databasemanager.cpp
File metadata and controls
107 lines (82 loc) · 3.18 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#include "databasemanager.h"
#include <QSqlQuery>
#include <QSqlError>
#include <QDebug>
#include <QCryptographicHash>
DatabaseManager::DatabaseManager(QObject *parent) : QObject(parent) {
db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("users.db");
if (!db.open()) {
qWarning() << "Database connection failed:" << db.lastError().text();
} else {
qDebug() << "Connected to database!";
// Create the users table if it doesn't exist
QSqlQuery query;
if (!query.exec("CREATE TABLE IF NOT EXISTS users ("
"id INTEGER PRIMARY KEY AUTOINCREMENT, "
"username TEXT UNIQUE, "
"password TEXT, "
"email TEXT UNIQUE)")) {
qWarning() << "Failed to create users table:" << query.lastError().text();
}
}
}
DatabaseManager::~DatabaseManager() {
if (db.isOpen()) {
db.close();
}
}
bool DatabaseManager::validateUser(const QString &username, const QString &password) {
QSqlQuery query(db);
// Hash the entered password
QString hashedPassword = QString::fromUtf8(QCryptographicHash::hash(password.toUtf8(), QCryptographicHash::Sha256).toHex());
query.prepare("SELECT COUNT(*) FROM users WHERE username = ? AND password = ?");
query.addBindValue(username);
query.addBindValue(hashedPassword);
if (!query.exec() || !query.next()) {
qWarning() << "Failed to validate user:" << query.lastError().text();
return false;
}
return query.value(0).toInt() > 0;
}
bool DatabaseManager::storeUser(const QString &username, const QString &password, const QString &email) {
QSqlQuery query(db);
// Check if username or email already exists
query.prepare("SELECT COUNT(*) FROM users WHERE username = ? OR email = ?");
query.addBindValue(username);
query.addBindValue(email);
if (!query.exec() || !query.next()) {
qWarning() << "Failed to check for duplicate user:" << query.lastError().text();
return false;
}
if (query.value(0).toInt() > 0) {
qDebug() << "Username or email already exists!";
return false;
}
// Hash the password before storing it
QString hashedPassword = QString::fromUtf8(QCryptographicHash::hash(password.toUtf8(), QCryptographicHash::Sha256).toHex());
// Insert the new user
query.prepare("INSERT INTO users (username, password, email) VALUES (?, ?, ?)");
query.addBindValue(username);
query.addBindValue(hashedPassword);
query.addBindValue(email);
if (!query.exec()) {
qWarning() << "Failed to insert user:" << query.lastError().text();
return false;
}
qDebug() << "User registered successfully!";
return true;
}
QString DatabaseManager::getUsername() {
QSqlQuery query(db);
// Fetch username (example query)
query.prepare("SELECT username FROM users WHERE id = 1"); // Adjust query as needed
if (!query.exec()) {
qWarning() << "Failed to fetch username:" << query.lastError().text();
return "Unknown";
}
if (query.next()) {
return query.value(0).toString(); // Return the username
}
return "Unknown";
}