Datenbank.cpp 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. #include "Datenbank.h"
  2. #include <iostream>
  3. #include <Zeit.h>
  4. // Inhalt der LSDatenbank Klasse aus Datenbank.h
  5. // Konstruktor
  6. KSDatenbank::KSDatenbank(InitDatei* zIni)
  7. : ReferenceCounter()
  8. {
  9. datenbank = new Datenbank(zIni->zWert("DBBenutzer")->getText(), zIni->zWert("DBPasswort")->getText(),
  10. zIni->zWert("DBName")->getText(), zIni->zWert("DBIP")->getText(),
  11. (unsigned short)TextZuInt(zIni->zWert("DBPort")->getText(), 10));
  12. if (!datenbank->istOk())
  13. {
  14. std::cout << "KS: Die Verbindung zur Datenbank konnte nicht hergestellt werden.\nDas Programm wird beendet.";
  15. exit(1);
  16. }
  17. InitializeCriticalSection(&cs);
  18. Text befehl = "SELECT port, admin_port FROM server WHERE id = ";
  19. befehl += zIni->zWert("ServerId")->getText();
  20. lock();
  21. datenbank->befehl(befehl);
  22. Result res = datenbank->getResult();
  23. unlock();
  24. if (res.zeilenAnzahl == 1)
  25. {
  26. zIni->addWert("ServerPort", res.values[0]);
  27. zIni->addWert("AdminServerPort", res.values[1]);
  28. }
  29. res.destroy();
  30. }
  31. // Destruktor
  32. KSDatenbank::~KSDatenbank()
  33. {
  34. datenbank->release();
  35. DeleteCriticalSection(&cs);
  36. }
  37. // nicht constant
  38. void KSDatenbank::lock()
  39. {
  40. EnterCriticalSection(&cs);
  41. }
  42. void KSDatenbank::unlock()
  43. {
  44. LeaveCriticalSection(&cs);
  45. }
  46. int KSDatenbank::istAdministrator(const char* name, const char* passwort)
  47. {
  48. Text* befehl = new Text("SELECT id FROM benutzer WHERE name = '");
  49. Text n(name);
  50. n.ersetzen("'", "''");
  51. befehl->append(n);
  52. befehl->append("' AND passwort = md5( '");
  53. Text p(passwort);
  54. p.ersetzen("'", "''");
  55. befehl->append(p);
  56. befehl->append("' )");
  57. lock();
  58. datenbank->befehl(befehl->getText());
  59. Result res = datenbank->getResult();
  60. unlock();
  61. befehl->release();
  62. int ret = 0;
  63. if (res.zeilenAnzahl > 0)
  64. ret = TextZuInt(res.values[0].getText(), 10);
  65. res.destroy();
  66. return ret;
  67. }
  68. bool KSDatenbank::adminHatRecht(int id, int recht)
  69. {
  70. Text* befehl = new Text("SELECT * FROM benutzer_rechte WHERE benutzer_id = ");
  71. befehl->append(id);
  72. befehl->append(" AND rechte_id = ");
  73. befehl->append(recht);
  74. lock();
  75. datenbank->befehl(befehl->getText());
  76. int ret = datenbank->getZeilenAnzahl();
  77. unlock();
  78. befehl->release();
  79. return ret != 0;
  80. }
  81. bool KSDatenbank::proveKlient(int num, int sNum)
  82. {
  83. Text* befehl = new Text("SELECT * FROM server_client WHERE server_id = ");
  84. befehl->append(sNum);
  85. befehl->append(" AND client_id = ");
  86. befehl->append(num);
  87. lock();
  88. datenbank->befehl(befehl->getText());
  89. int ret = datenbank->getZeilenAnzahl();
  90. unlock();
  91. befehl->release();
  92. return ret == 1;
  93. }
  94. Text* KSDatenbank::getKlientKey(int cId)
  95. {
  96. lock();
  97. if (!datenbank->befehl(Text("SELECT schluessel FROM client WHERE id = ") += cId))
  98. {
  99. unlock();
  100. return 0;
  101. }
  102. Result res = datenbank->getResult();
  103. unlock();
  104. if (!res.zeilenAnzahl)
  105. {
  106. res.destroy();
  107. return 0;
  108. }
  109. Text* ret = new Text(res.values[0].getText());
  110. res.destroy();
  111. return ret;
  112. }
  113. void KSDatenbank::unregisterKlient(int num, int sNum)
  114. {
  115. Text* befehl = new Text("DELETE FROM server_client WHERE client_id = ");
  116. befehl->append(num);
  117. befehl->append(" AND server_id = ");
  118. befehl->append(sNum);
  119. lock();
  120. datenbank->befehl(befehl->getText());
  121. unlock();
  122. befehl->release();
  123. }
  124. bool KSDatenbank::setServerStatus(int id, int status)
  125. {
  126. Text* befehl = new Text("UPDATE server SET server_status_id = ");
  127. *befehl += status;
  128. *befehl += "WHERE id = ";
  129. *befehl += id;
  130. lock();
  131. if (!datenbank->befehl(befehl->getText()))
  132. {
  133. unlock();
  134. befehl->release();
  135. return 0;
  136. }
  137. bool ret = datenbank->getZeilenAnzahl() != 0;
  138. unlock();
  139. befehl->release();
  140. return ret;
  141. }
  142. bool KSDatenbank::setMaxKarten(int id, int maxK)
  143. {
  144. Text* befehl = new Text("UPDATE server SET max_tasks = ");
  145. befehl->append(maxK);
  146. befehl->append(" WHERE id = ");
  147. befehl->append(id);
  148. lock();
  149. if (!datenbank->befehl(befehl->getText()))
  150. {
  151. unlock();
  152. befehl->release();
  153. return 0;
  154. }
  155. bool ret = datenbank->getZeilenAnzahl() > 0;
  156. unlock();
  157. befehl->release();
  158. return ret;
  159. }
  160. bool KSDatenbank::serverIstNichtPausiert(int id)
  161. {
  162. Text* befehl = new Text("SELECT server_status_id FROM server WHERE id = ");
  163. befehl->append(id);
  164. lock();
  165. if (!datenbank->befehl(befehl->getText()))
  166. {
  167. unlock();
  168. befehl->release();
  169. return 0;
  170. }
  171. Result res = datenbank->getResult();
  172. unlock();
  173. befehl->release();
  174. if (!res.zeilenAnzahl)
  175. {
  176. res.destroy();
  177. return 0;
  178. }
  179. bool ret = (int)res.values[0] == 3;
  180. res.destroy();
  181. return ret;
  182. }
  183. bool KSDatenbank::proveKarte(int id, int sNum)
  184. {
  185. Text befehl = "SELECT id FROM karte WHERE id = ";
  186. befehl += id;
  187. befehl += " AND server_karten_id = ";
  188. befehl += sNum;
  189. lock();
  190. if (!datenbank->befehl(befehl))
  191. {
  192. unlock();
  193. return 0;
  194. }
  195. bool ret = datenbank->getZeilenAnzahl() != 0;
  196. unlock();
  197. return ret;
  198. }
  199. int KSDatenbank::getUpdateKarte(int serverId)
  200. {
  201. Text befehl = "SELECT id FROM karte WHERE erlaubt = FALSE AND server_karten_id = ";
  202. befehl += serverId;
  203. lock();
  204. if (!datenbank->befehl(befehl))
  205. {
  206. unlock();
  207. return 0;
  208. }
  209. Result r = datenbank->getResult();
  210. unlock();
  211. for (int i = 0; i < r.zeilenAnzahl; i++)
  212. {
  213. int karte = (int)r.values[i];
  214. befehl = "SELECT karte_update_warten( ";
  215. befehl += karte;
  216. befehl += " )";
  217. lock();
  218. if (!datenbank->befehl(befehl))
  219. {
  220. unlock();
  221. continue;
  222. }
  223. Result res = datenbank->getResult();
  224. unlock();
  225. if (!res.zeilenAnzahl)
  226. {
  227. res.destroy();
  228. continue;
  229. }
  230. if (res.values[0].istGleich("f"))
  231. {
  232. res.destroy();
  233. r.destroy();
  234. return karte;
  235. }
  236. res.destroy();
  237. }
  238. r.destroy();
  239. return 0;
  240. }
  241. bool KSDatenbank::endUpdateKarte(int karteId)
  242. {
  243. Text befehl = "SELECT karte_update_ende( ";
  244. befehl += karteId;
  245. befehl += " )";
  246. lock();
  247. if (!datenbank->befehl(befehl))
  248. {
  249. unlock();
  250. return 0;
  251. }
  252. Result r = datenbank->getResult();
  253. unlock();
  254. if (!r.zeilenAnzahl)
  255. {
  256. r.destroy();
  257. return 0;
  258. }
  259. bool ret = r.values[0].istGleich("t");
  260. r.destroy();
  261. return ret;
  262. }
  263. bool KSDatenbank::getEditorServerPortIp(int karteId, int* port, Text* ip)
  264. {
  265. if (!port || !ip)
  266. return 0;
  267. Text befehl = "SELECT a.port, a.ip FROM server a, karte b WHERE a.server_typ_name = 'editor' AND a.id = b.server_editor_id AND b.id = ";
  268. befehl += karteId;
  269. lock();
  270. if (!datenbank->befehl(befehl))
  271. {
  272. unlock();
  273. return 0;
  274. }
  275. Result r = datenbank->getResult();
  276. unlock();
  277. if (!r.zeilenAnzahl)
  278. {
  279. r.destroy();
  280. return 0;
  281. }
  282. *port = (int)r.values[0];
  283. ip->setText(r.values[1]);
  284. r.destroy();
  285. return 1;
  286. }
  287. bool KSDatenbank::setKarteSpielerAnzahl(int karteId, int sAnz)
  288. {
  289. Text befehl = "UPDATE karte SET max_spieler = ";
  290. befehl += sAnz;
  291. befehl += " WHERE id = ";
  292. befehl += karteId;
  293. lock();
  294. if (!datenbank->befehl(befehl))
  295. {
  296. unlock();
  297. return 0;
  298. }
  299. int anz = datenbank->getZeilenAnzahl();
  300. unlock();
  301. if (!anz)
  302. return 0;
  303. return 1;
  304. }
  305. // constant
  306. Text* KSDatenbank::getLetzterFehler() const
  307. {
  308. return datenbank->getLetzterFehler();
  309. }