19 |
|
|
20 |
|
return link.substr(0, link.rfind('/')) + '/' + atom; |
21 |
|
} |
22 |
+ |
|
23 |
+ |
ext::String Buddy::getDisplay(const Database& database) const |
24 |
+ |
{ |
25 |
+ |
ext::Handle<dbi::Driver> driver(dbi::GetDriver(database.driver)); |
26 |
+ |
ext::Handle<dbi::Connection> db(driver->Connect(database.host, |
27 |
+ |
database.user, database.password, database.db)); |
28 |
+ |
ext::Handle<dbi::ResultSet> display(db->Execute("SELECT display " |
29 |
+ |
"FROM displays WHERE id='" + lexical_cast<ext::String>(id) + "'")); |
30 |
+ |
|
31 |
+ |
if (display->MoveNext()) return display->GetString("display"); |
32 |
+ |
else return login; |
33 |
+ |
} |
34 |
+ |
|
35 |
+ |
void Buddy::setDisplay(const ext::String& display, const Database& database) const |
36 |
+ |
{ |
37 |
+ |
ext::Handle<dbi::Driver> driver(dbi::GetDriver(database.driver)); |
38 |
+ |
ext::Handle<dbi::Connection> db(driver->Connect(database.host, |
39 |
+ |
database.user, database.password, database.db)); |
40 |
+ |
ext::Handle<dbi::ResultSet> update(db->Execute("SELECT * FROM displays " |
41 |
+ |
"WHERE id = '" + lexical_cast<ext::String>(id) + "'")); |
42 |
+ |
|
43 |
+ |
if (update->MoveNext()) db->Execute("UPDATE displays SET display='" |
44 |
+ |
+ display + "' WHERE id='" + lexical_cast<ext::String>(id) + "'"); |
45 |
+ |
else db->Execute("INSERT INTO displays (display, id) VALUES ('" + display |
46 |
+ |
+ "', '" + lexical_cast<ext::String>(id) + "')"); |
47 |
+ |
} |