Datenbank.cpp 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366
  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. {
  8. datenbank = new Datenbank( zIni->zWert( "DBBenutzer" )->getText(), zIni->zWert( "DBPasswort" )->getText(),
  9. zIni->zWert( "DBName" )->getText(), zIni->zWert( "DBIP" )->getText(),
  10. (unsigned short)TextZuInt( zIni->zWert( "DBPort" )->getText(), 10 ) );
  11. if( !datenbank->istOk() )
  12. {
  13. std::cout << "KS: Die Verbindung zur Datenbank konnte nicht hergestellt werden.\nDas Programm wird beendet.";
  14. exit( 1 );
  15. }
  16. InitializeCriticalSection( &cs );
  17. ref = 1;
  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( (char*)n );
  52. befehl->append( "' AND passwort = md5( '" );
  53. Text p( passwort );
  54. p.ersetzen( "'", "''" );
  55. befehl->append( (char*)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. int KSDatenbank::getAdminPort( int id )
  161. {
  162. Text *befehl = new Text( "SELECT admin_port 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. int ret = TextZuInt( res.values[ 0 ].getText(), 10 );
  180. res.destroy();
  181. return ret;
  182. }
  183. bool KSDatenbank::serverIstNichtPausiert( int id )
  184. {
  185. Text *befehl = new Text( "SELECT server_status_id FROM server WHERE id = " );
  186. befehl->append( id );
  187. lock();
  188. if( !datenbank->befehl( befehl->getText() ) )
  189. {
  190. unlock();
  191. befehl->release();
  192. return 0;
  193. }
  194. Result res = datenbank->getResult();
  195. unlock();
  196. befehl->release();
  197. if( !res.zeilenAnzahl )
  198. {
  199. res.destroy();
  200. return 0;
  201. }
  202. bool ret = (int)res.values[ 0 ] == 3;
  203. res.destroy();
  204. return ret;
  205. }
  206. bool KSDatenbank::proveKarte( int id, int sNum )
  207. {
  208. Text befehl = "SELECT id FROM karte WHERE id = ";
  209. befehl += id;
  210. befehl += " AND server_karten_id = ";
  211. befehl += sNum;
  212. lock();
  213. if( !datenbank->befehl( befehl ) )
  214. {
  215. unlock();
  216. return 0;
  217. }
  218. bool ret = datenbank->getZeilenAnzahl() != 0;
  219. unlock();
  220. return ret;
  221. }
  222. int KSDatenbank::getUpdateKarte( int serverId )
  223. {
  224. Text befehl = "SELECT id FROM karte WHERE erlaubt = FALSE AND server_karten_id = ";
  225. befehl += serverId;
  226. lock();
  227. if( !datenbank->befehl( befehl ) )
  228. {
  229. unlock();
  230. return 0;
  231. }
  232. Result r = datenbank->getResult();
  233. unlock();
  234. for( int i = 0; i < r.zeilenAnzahl; i++ )
  235. {
  236. int karte = r.values[ i ];
  237. befehl = "SELECT karte_update_warten( ";
  238. befehl += karte;
  239. befehl += " )";
  240. lock();
  241. if( !datenbank->befehl( befehl ) )
  242. {
  243. unlock();
  244. continue;
  245. }
  246. Result res = datenbank->getResult();
  247. unlock();
  248. if( !res.zeilenAnzahl )
  249. {
  250. res.destroy();
  251. continue;
  252. }
  253. if( res.values[ 0 ].istGleich( "f" ) )
  254. {
  255. res.destroy();
  256. r.destroy();
  257. return karte;
  258. }
  259. res.destroy();
  260. }
  261. r.destroy();
  262. return 0;
  263. }
  264. bool KSDatenbank::endUpdateKarte( int karteId )
  265. {
  266. Text befehl = "SELECT karte_update_ende( ";
  267. befehl += karteId;
  268. befehl += " )";
  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. bool ret = r.values[ 0 ].istGleich( "t" );
  283. r.destroy();
  284. return ret;
  285. }
  286. bool KSDatenbank::getEditorServerPortIp( int karteId, int *port, Text *ip )
  287. {
  288. if( !port || !ip )
  289. return 0;
  290. 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 = ";
  291. befehl += karteId;
  292. lock();
  293. if( !datenbank->befehl( befehl ) )
  294. {
  295. unlock();
  296. return 0;
  297. }
  298. Result r = datenbank->getResult();
  299. unlock();
  300. if( !r.zeilenAnzahl )
  301. {
  302. r.destroy();
  303. return 0;
  304. }
  305. *port = r.values[ 0 ];
  306. ip->setText( r.values[ 1 ] );
  307. r.destroy();
  308. return 1;
  309. }
  310. bool KSDatenbank::setKarteSpielerAnzahl( int karteId, int sAnz )
  311. {
  312. Text befehl = "UPDATE karte SET max_spieler = ";
  313. befehl += sAnz;
  314. befehl += " WHERE id = ";
  315. befehl += karteId;
  316. lock();
  317. if( !datenbank->befehl( befehl ) )
  318. {
  319. unlock();
  320. return 0;
  321. }
  322. int anz = datenbank->getZeilenAnzahl();
  323. unlock();
  324. if( !anz )
  325. return 0;
  326. return 1;
  327. }
  328. // constant
  329. Text *KSDatenbank::getLetzterFehler() const
  330. {
  331. return datenbank->getLetzterFehler();
  332. }
  333. // Reference Counting
  334. KSDatenbank *KSDatenbank::getThis()
  335. {
  336. ref++;
  337. return this;
  338. }
  339. KSDatenbank *KSDatenbank::release()
  340. {
  341. ref--;
  342. if( !ref )
  343. delete this;
  344. return 0;
  345. }