RegisterServer.cpp 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209
  1. #include "RegisterServer.h"
  2. #include <iostream>
  3. #include <Klient.h>
  4. #include <Globals.h>
  5. // Inhalt der RegiserServer Klasse aus RegisterServer.h
  6. // Konstruktor
  7. RegisterServer::RegisterServer( InitDatei *zIni )
  8. : Thread()
  9. {
  10. Network::Start( 100 );
  11. std::cout << "RS: Verbindung mit Datenbank wird hergestellt...\n";
  12. db = new RSDatenbank( zIni );
  13. klientAnzahl = 0;
  14. klients = new RCArray< RSKlient >();
  15. empfangen = 0;
  16. gesendet = 0;
  17. fehler = new Text();
  18. ini = zIni->getThis();
  19. id = *zIni->zWert( "ServerId" );
  20. server = new Server();
  21. aServer = new Server();
  22. std::cout << "RS: Starten des Admin Servers...\n";
  23. if( !aServer->verbinde( (unsigned short)TextZuInt( ini->zWert( "AdminServerPort" )->getText(), 10 ), 10 ) )
  24. {
  25. std::cout << "RS: Der Admin Server konnte nicht gestartet werden. Das Programm wird beendet.\n";
  26. exit( 1 );
  27. }
  28. db->setServerStatus( id, 2 );
  29. end = 0;
  30. nichtPausiert = 0;
  31. InitializeCriticalSection( &cs );
  32. update = 0;
  33. ref = 1;
  34. if( zIni->zWert( "Aktiv" )->istGleich( "TRUE" ) )
  35. {
  36. serverStarten();
  37. serverFortsetzen();
  38. }
  39. }
  40. // Destruktor
  41. RegisterServer::~RegisterServer()
  42. {
  43. fehler->release();
  44. server->trenne();
  45. server->release();
  46. aServer->trenne();
  47. aServer->release();
  48. if( klients )
  49. klients->release();
  50. ini->release();
  51. db->release();
  52. DeleteCriticalSection( &cs );
  53. }
  54. // nicht constant
  55. void RegisterServer::runn()
  56. {
  57. while( !end )
  58. {
  59. SKlient *klient;
  60. klient = aServer->getKlient();
  61. if( end && klient )
  62. {
  63. klient->trenne();
  64. klient = klient->release();
  65. Sleep( 1000 );
  66. return;
  67. }
  68. if( !klient )
  69. return;
  70. RSAKlient *clHandle = new RSAKlient( klient, getThis() );
  71. clHandle->start();
  72. }
  73. }
  74. void RegisterServer::thread()
  75. {
  76. while( 1 )
  77. {
  78. SKlient *klient;
  79. klient = server->getKlient();
  80. if( !klient )
  81. break;
  82. Framework::getThreadRegister()->cleanUpClosedThreads();
  83. RSKlient *clHandle = new RSKlient( klient, getThis() );
  84. EnterCriticalSection( &cs );
  85. klients->set( clHandle, klientAnzahl );
  86. klientAnzahl++;
  87. LeaveCriticalSection( &cs );
  88. clHandle->start();
  89. }
  90. }
  91. void RegisterServer::close()
  92. {
  93. db->setServerStatus( id, 1 );
  94. server->trenne();
  95. #ifdef WIN32
  96. warteAufThread( 1000 );
  97. #endif
  98. EnterCriticalSection( &cs );
  99. for( int i = 0; i < klientAnzahl; i++ )
  100. klients->z( i )->absturz();
  101. klients = klients->release();
  102. klientAnzahl = 0;
  103. LeaveCriticalSection( &cs );
  104. ende();
  105. run = 0;
  106. end = 1;
  107. Klient *klient = new Klient();
  108. klient->verbinde( aServer->getPort(), "127.0.0.1" );
  109. Sleep( 500 );
  110. aServer->trenne();
  111. klient->release();
  112. }
  113. bool RegisterServer::serverStarten()
  114. {
  115. if( nichtPausiert )
  116. {
  117. fehler->setText( "Der Server konnte nicht gestartet werden: Der Server läuft bereits." );
  118. return 0;
  119. }
  120. if( server )
  121. server->release();
  122. server = new Server();
  123. if( server->verbinde( (unsigned short)TextZuInt( ini->zWert( "ServerPort" )->getText(), 10 ), 10 ) )
  124. {
  125. nichtPausiert = 1;
  126. start();
  127. return 1;
  128. }
  129. else
  130. {
  131. serverBeenden();
  132. fehler->setText( "Der Server konnte nicht gestartet werden: Eventuell ist der Port in benutzung." );
  133. return 0;
  134. }
  135. }
  136. bool RegisterServer::serverPause()
  137. {
  138. if( !nichtPausiert )
  139. {
  140. fehler->setText( "Der Server konnte nicht pausiert werden: Der Server läuft nicht." );
  141. return 0;
  142. }
  143. if( !db->setServerStatus( id, 2 ) )
  144. {
  145. fehler->setText( "Der Server konnte nicht pausiert werden: " );
  146. fehler->append( db->getLetzterFehler() );
  147. return 0;
  148. }
  149. return 1;
  150. }
  151. bool RegisterServer::serverFortsetzen()
  152. {
  153. if( !nichtPausiert )
  154. {
  155. fehler->setText( "Der Server konnte nicht fortgesetzt werden: Der Server läuft nicht." );
  156. return 0;
  157. }
  158. if( !db->setServerStatus( id, 3 ) )
  159. {
  160. fehler->setText( "Der Server konnte nicht fortgesetzt werden: " );
  161. fehler->append( db->getLetzterFehler() );
  162. return 0;
  163. }
  164. return 1;
  165. }
  166. bool RegisterServer::serverBeenden()
  167. {
  168. if( !nichtPausiert )
  169. {
  170. fehler->setText( "Der Server konnte nicht beendet werden: Der Server läuft nicht." );
  171. return 0;
  172. }
  173. if( db->serverIstNichtPausiert( id ) )
  174. {
  175. fehler->setText( "Der Server konnte nicht beendet werden: Der Server muss erst pausiert werden." );
  176. return 0;
  177. }
  178. nichtPausiert = 0;
  179. ende();
  180. if( server )
  181. server->trenne();
  182. return 1;
  183. }
  184. bool RegisterServer::setMaxKlients( int mc )
  185. {
  186. if( !db->setMaxClients( id, mc ) )
  187. {
  188. fehler->setText( "Die maximale Anzahl der Clients konnte nicht gesetzt werden:\n" );
  189. fehler->append( db->getLetzterFehler() );
  190. return 0;
  191. }
  192. ini->setWert( "MaxClients", Text() += mc );
  193. return 1;
  194. }
  195. bool RegisterServer::absturzKlient( int klientId )
  196. {
  197. bool gefunden = 0;
  198. EnterCriticalSection( &cs );
  199. for( int i = 0; i < klientAnzahl; i++ )
  200. {
  201. if( klients->z( i )->getKlientNummer() == klientId )
  202. {
  203. klients->z( i )->absturz();
  204. klients->remove( i );
  205. klientAnzahl--;
  206. gefunden = 1;
  207. break;
  208. }
  209. }
  210. LeaveCriticalSection( &cs );
  211. return gefunden;
  212. }
  213. bool RegisterServer::removeKlient( RSKlient *zKlient )
  214. {
  215. bool gefunden = 0;
  216. EnterCriticalSection( &cs );
  217. for( int i = 0; i < klientAnzahl; i++ )
  218. {
  219. if( klients->z( i ) == zKlient )
  220. {
  221. klients->remove( i );
  222. klientAnzahl--;
  223. gefunden = 1;
  224. break;
  225. }
  226. }
  227. LeaveCriticalSection( &cs );
  228. return gefunden;
  229. }
  230. void RegisterServer::addGesendet( int bytes )
  231. {
  232. gesendet += bytes;
  233. }
  234. void RegisterServer::addEmpfangen( int bytes )
  235. {
  236. empfangen += bytes;
  237. }
  238. // constant
  239. bool RegisterServer::istAn() const
  240. {
  241. return db->serverIstNichtPausiert( id );
  242. }
  243. Server *RegisterServer::zServer() const
  244. {
  245. return server;
  246. }
  247. RSDatenbank *RegisterServer::zDB() const
  248. {
  249. return db;
  250. }
  251. bool RegisterServer::hatClients() const
  252. {
  253. return klientAnzahl > 0;
  254. }
  255. int RegisterServer::getId() const
  256. {
  257. return id;
  258. }
  259. char *RegisterServer::getLetzterFehler() const
  260. {
  261. return fehler->getText();
  262. }
  263. InitDatei *RegisterServer::zIni() const
  264. {
  265. return ini;
  266. }
  267. // Reference Counting
  268. RegisterServer *RegisterServer::getThis()
  269. {
  270. ref++;
  271. return this;
  272. }
  273. RegisterServer *RegisterServer::release()
  274. {
  275. ref--;
  276. if( !ref )
  277. delete this;
  278. return 0;
  279. }
  280. // Inhalt der RSAKlient Klasse aus RegisterServer.h
  281. // Konstruktor
  282. RSAKlient::RSAKlient( SKlient *klient, RegisterServer *rs )
  283. : Thread()
  284. {
  285. this->klient = klient;
  286. unsigned char key[ 20 ] = { 246, 1, 73, 51, 10, 103, 151, 180, 17, 220, 28, 241, 131, 229, 66, 137, 175, 218, 133, 58 };
  287. klient->setSendeKey( (char*)key, 20 );
  288. klient->setEmpfangKey( (char*)key, 20 );
  289. name = new Text( "" );
  290. passwort = new Text( "" );
  291. adminId = 0;
  292. version = 0;
  293. this->rs = rs;
  294. }
  295. // Destruktor
  296. RSAKlient::~RSAKlient()
  297. {
  298. klient->trenne();
  299. klient->release();
  300. rs->release();
  301. name->release();
  302. passwort->release();
  303. }
  304. // nicht constant
  305. void RSAKlient::thread()
  306. {
  307. while( 1 )
  308. {
  309. char c = 0;
  310. if( !klient->getNachrichtEncrypted( &c, 1 ) )
  311. break;
  312. else
  313. {
  314. bool br = 0;
  315. switch( c )
  316. {
  317. case 1: // Login
  318. if( 1 )
  319. {
  320. klient->sendeEncrypted( "\1", 1 );
  321. char nLen = 0;
  322. klient->getNachrichtEncrypted( &nLen, 1 );
  323. char *n = new char[ nLen + 1 ];
  324. n[ (int)nLen ] = 0;
  325. if( nLen )
  326. klient->getNachrichtEncrypted( n, nLen );
  327. char pLen = 0;
  328. klient->getNachrichtEncrypted( &pLen, 1 );
  329. char *p = new char[ pLen + 1 ];
  330. p[ (int)pLen ] = 0;
  331. if( pLen )
  332. klient->getNachrichtEncrypted( p, pLen );
  333. int adminId = rs->zDB()->istAdministrator( n, p );
  334. if( adminId )
  335. {
  336. klient->sendeEncrypted( "\1", 1 );
  337. name->setText( n );
  338. passwort->setText( p );
  339. this->adminId = adminId;
  340. }
  341. else
  342. errorZuKlient( "Falsche Kombination aus Name und Passwort." );
  343. delete[] n;
  344. delete[] p;
  345. }
  346. break;
  347. case 2: // Logout
  348. adminId = 0;
  349. name->setText( "" );
  350. passwort->setText( "" );
  351. klient->sendeEncrypted( "\1", 1 );
  352. break;
  353. case 3: // Trennen
  354. br = 1;
  355. klient->sendeEncrypted( "\1", 1 );
  356. break;
  357. case 4: // Server starten
  358. if( !adminId )
  359. errorZuKlient( "Du musst dich einloggen." );
  360. else
  361. {
  362. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSStarten ) )
  363. {
  364. if( !rs->serverStarten() )
  365. {
  366. Text *err = new Text();
  367. err->append( rs->getLetzterFehler() );
  368. errorZuKlient( err->getText() );
  369. err->release();
  370. }
  371. else
  372. klient->sendeEncrypted( "\1", 1 );
  373. }
  374. else
  375. errorZuKlient( "Du bist nicht berechtigt den Server zu starten." );
  376. }
  377. break;
  378. case 5: // Server beenden
  379. if( !adminId )
  380. errorZuKlient( "Du musst dich einloggen." );
  381. else
  382. {
  383. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
  384. {
  385. if( rs->serverBeenden() )
  386. klient->sendeEncrypted( "\1", 1 );
  387. else
  388. {
  389. Text *err = new Text();
  390. err->append( rs->getLetzterFehler() );
  391. errorZuKlient( err->getText() );
  392. err->release();
  393. }
  394. }
  395. else
  396. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  397. }
  398. break;
  399. case 6: // Programm Schließen
  400. if( !adminId )
  401. errorZuKlient( "Du musst dich einloggen." );
  402. else
  403. {
  404. bool ok = 0;
  405. if( rs->isRunning() )
  406. {
  407. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
  408. {
  409. if( rs->serverBeenden() )
  410. ok = 1;
  411. else
  412. {
  413. Text *err = new Text();
  414. err->append( rs->getLetzterFehler() );
  415. errorZuKlient( err->getText() );
  416. err->release();
  417. }
  418. }
  419. else
  420. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  421. }
  422. else
  423. ok = 1;
  424. if( ok && rs->hatClients() )
  425. {
  426. errorZuKlient( "Es sind noch Klients Online. Bitte versuche es später erneut." );
  427. break;
  428. }
  429. if( ok )
  430. {
  431. klient->sendeEncrypted( "\1", 1 );
  432. std::cout << "RS: Der Server wird von Benutzer " << adminId << " heruntergefahren.\n";
  433. rs->close();
  434. br = 1;
  435. }
  436. }
  437. break;
  438. case 7: // Progtamm abstürzen
  439. if( !adminId )
  440. errorZuKlient( "Du musst dich einloggen." );
  441. else
  442. {
  443. bool ok = 0;
  444. if( rs->isRunning() )
  445. {
  446. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
  447. {
  448. rs->serverBeenden();
  449. ok = 1;
  450. }
  451. else
  452. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  453. }
  454. else
  455. ok = 1;
  456. if( ok )
  457. {
  458. klient->sendeEncrypted( "\1", 1 );
  459. std::cout << "RS: Der Server wurde von Benutzer " << adminId << " terminiert.\n";
  460. rs->close();
  461. br = 1;
  462. }
  463. }
  464. break;
  465. case 8: // Status Frage
  466. if( 1 )
  467. {
  468. char status = 0;
  469. if( rs->isRunning() )
  470. {
  471. status = 1;
  472. if( rs->istAn() )
  473. status = 2;
  474. }
  475. klient->sendeEncrypted( "\1", 1 );
  476. klient->sendeEncrypted( &status, 1 );
  477. }
  478. break;
  479. case 9: // Server pausieren
  480. if( !adminId )
  481. errorZuKlient( "Du musst dich einloggen." );
  482. else
  483. {
  484. klient->sendeEncrypted( "\1", 1 );
  485. char pause = 0;
  486. klient->getNachrichtEncrypted( &pause, 1 );
  487. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSPausieren ) )
  488. {
  489. bool ok = 0;
  490. if( pause )
  491. ok = rs->serverPause();
  492. else
  493. ok = rs->serverFortsetzen();
  494. if( ok )
  495. klient->sendeEncrypted( "\1", 1 );
  496. else
  497. {
  498. Text *err = new Text();
  499. err->append( rs->getLetzterFehler() );
  500. errorZuKlient( err->getText() );
  501. err->release();
  502. }
  503. }
  504. else
  505. {
  506. if( pause )
  507. errorZuKlient( "Du bist nicht berechtigt den Server zu pausieren." );
  508. else
  509. errorZuKlient( "Du bist nicht berechtigt den Server fortzusetzen." );
  510. }
  511. }
  512. break;
  513. case 0xA: // maximale Anzahl der Clients setzen
  514. if( !adminId )
  515. errorZuKlient( "Du musst dich einloggen." );
  516. else
  517. {
  518. klient->sendeEncrypted( "\1", 1 );
  519. int maxC = 0;
  520. klient->getNachrichtEncrypted( (char*)&maxC, 4 );
  521. if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSMCChange ) )
  522. {
  523. if( rs->setMaxKlients( maxC ) )
  524. klient->sendeEncrypted( "\1", 1 );
  525. else
  526. {
  527. Text *err = new Text();
  528. err->append( rs->getLetzterFehler() );
  529. errorZuKlient( err->getText() );
  530. err->release();
  531. }
  532. }
  533. else
  534. errorZuKlient( "Du bist nicht berechtigt die maximale Anzahl der Clients zu verändern." );
  535. }
  536. break;
  537. case 0xC: // klient absturtz
  538. if( 1 )
  539. {
  540. klient->sendeEncrypted( "\1", 1 );
  541. int klientId = 0;
  542. klient->getNachrichtEncrypted( (char*)&klientId, 4 );
  543. if( klientId && rs->absturzKlient( klientId ) )
  544. klient->sendeEncrypted( "\1", 1 );
  545. else
  546. klient->sendeEncrypted( "\0", 1 );
  547. }
  548. break;
  549. default:
  550. errorZuKlient( "Unbekannte Nachricht!" );
  551. break;
  552. }
  553. if( br )
  554. break;
  555. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  556. rs->addGesendet( klient->getUploadBytes( 1 ) );
  557. }
  558. }
  559. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  560. rs->addGesendet( klient->getUploadBytes( 1 ) );
  561. delete this;
  562. }
  563. void RSAKlient::errorZuKlient( const char *nachricht ) const // sendet eine Fehlernachricht zum Klient
  564. {
  565. klient->sendeEncrypted( "\3", 1 );
  566. char len = (char)textLength( nachricht );
  567. klient->sendeEncrypted( &len, 1 );
  568. klient->sendeEncrypted( nachricht, len );
  569. }
  570. // Inhalt der RSKlasse aus RegisterServer.h
  571. // Konstruktor
  572. RSKlient::RSKlient( SKlient *klient, RegisterServer *rs )
  573. : Thread()
  574. {
  575. this->klient = klient;
  576. unsigned char key[ 20 ] = { 186, 186, 179, 126, 216, 207, 123, 154, 168, 149, 51, 221, 6, 193, 160, 141, 164, 126, 44, 242 };
  577. klient->setSendeKey( (char*)key, 20 );
  578. klient->setEmpfangKey( (char*)key, 20 );
  579. klientNummer = 0;
  580. this->rs = rs;
  581. ref = 1;
  582. }
  583. // Destruktor
  584. RSKlient::~RSKlient()
  585. {
  586. klient->release();
  587. rs->release();
  588. }
  589. // nicht constant
  590. void RSKlient::absturz()
  591. {
  592. ende();
  593. klient->trenne();
  594. rs->zDB()->unregisterKlient( klientNummer, rs->getId() );
  595. }
  596. void RSKlient::thread()
  597. {
  598. while( 1 )
  599. {
  600. char c = 0;
  601. if( !klient->getNachrichtEncrypted( &c, 1 ) )
  602. break;
  603. else
  604. {
  605. bool br = 0;
  606. switch( c )
  607. {
  608. case 1: // Klient identifikation
  609. klient->getNachrichtEncrypted( (char*)&klientNummer, 4 );
  610. if( !rs->zDB()->proveKlient( klientNummer, rs->getId() ) )
  611. {
  612. klientNummer = 0;
  613. errorZuKlient( "Du bist nicht für diesen Server eingetragen" );
  614. }
  615. else
  616. {
  617. Text *key = rs->zDB()->getKlientKey( klientNummer );
  618. if( !key )
  619. errorZuKlient( "Es konnte kein Key ermittelt werden." );
  620. else
  621. {
  622. klient->sendeEncrypted( "\1", 1 );
  623. klient->setEmpfangKey( *key, key->getLength() );
  624. klient->setSendeKey( *key, key->getLength() );
  625. key->release();
  626. }
  627. }
  628. break;
  629. case 2: // Main / Erhaltung Server message
  630. if( 1 )
  631. {
  632. char befehl = 0;
  633. klient->getNachrichtEncrypted( &befehl, 1 );
  634. switch( befehl )
  635. {
  636. case 2: // klient absturtz
  637. if( 1 )
  638. {
  639. int klientId = 0;
  640. klient->getNachrichtEncrypted( (char*)&klientId, 4 );
  641. if( klientId && rs->absturzKlient( klientId ) )
  642. klient->sendeEncrypted( "\1", 1 );
  643. else
  644. klient->sendeEncrypted( "\0", 1 );
  645. }
  646. break;
  647. default:
  648. errorZuKlient( "Befehl nicht bekannt!" );
  649. break;
  650. }
  651. }
  652. break;
  653. case 3: // Verbindungsende
  654. br = 1;
  655. klient->sendeEncrypted( "\1", 1 );
  656. break;
  657. case 4: // unregister Klient
  658. if( !klientNummer )
  659. {
  660. errorZuKlient( "Du bist nicht Identifiziert." );
  661. break;
  662. }
  663. rs->zDB()->unregisterKlient( klientNummer, rs->getId() );
  664. klient->sendeEncrypted( "\1", 1 );
  665. break;
  666. case 5: // Account erstellen
  667. if( 1 )
  668. {
  669. if( !klientNummer )
  670. {
  671. errorZuKlient( "Du bist nicht Identifiziert." );
  672. break;
  673. }
  674. klient->sendeEncrypted( "\1", 1 );
  675. unsigned char len[ 4 ] = { 0, 0, 0, 0 };
  676. klient->getNachrichtEncrypted( (char*)len, 4 );
  677. char *acc_name = new char[ len[ 0 ] + 1 ];
  678. acc_name[ len[ 0 ] ] = 0;
  679. klient->getNachrichtEncrypted( acc_name, len[ 0 ] );
  680. char *acc_pass = new char[ len[ 1 ] + 1 ];
  681. acc_pass[ len[ 1 ] ] = 0;
  682. klient->getNachrichtEncrypted( acc_pass, len[ 1 ] );
  683. char *acc_geheim = new char[ len[ 2 ] + 1 ];
  684. acc_geheim[ len[ 2 ] ] = 0;
  685. klient->getNachrichtEncrypted( acc_geheim, len[ 2 ] );
  686. char *acc_mail = new char[ len[ 3 ] + 1 ];
  687. acc_mail[ len[ 3 ] ] = 0;
  688. klient->getNachrichtEncrypted( acc_mail, len[ 3 ] );
  689. unsigned short acc_geb_jahr = 0;
  690. klient->getNachrichtEncrypted( (char*)&acc_geb_jahr, 2 );
  691. char acc_geb_monat = 0;
  692. klient->getNachrichtEncrypted( &acc_geb_monat, 1 );
  693. char acc_geb_tag = 0;
  694. klient->getNachrichtEncrypted( &acc_geb_tag, 1 );
  695. int pres = rs->zDB()->proveNeuAccount( acc_name, acc_mail );
  696. if( !pres )
  697. {
  698. Text *gebDatum = new Text( "" );
  699. gebDatum->append( (int)acc_geb_jahr );
  700. gebDatum->append( "-" );
  701. gebDatum->append( (int)acc_geb_monat );
  702. gebDatum->append( "-" );
  703. gebDatum->append( (int)acc_geb_tag );
  704. if( !rs->zDB()->neuAccount( acc_name, acc_pass, acc_geheim, acc_mail, gebDatum->getText(), rs->zIni() ) )
  705. {
  706. Text *err = new Text( "Das Datum '" );
  707. err->append( gebDatum->getText() );
  708. err->append( "' ist kein gültiges Datum." );
  709. errorZuKlient( err->getText() );
  710. err->release();
  711. }
  712. else
  713. {
  714. klient->sendeEncrypted( "\1", 1 );
  715. while( 1 )
  716. {
  717. char len = 0;
  718. klient->getNachrichtEncrypted( &len, 1 );
  719. if( !len ) // abbruch
  720. {
  721. rs->zDB()->neuAccountAbbruch( acc_name );
  722. break;
  723. }
  724. if( len == -1 )
  725. break;
  726. char *key = new char[ len + 1 ];
  727. key[ (int)len ] = 0;
  728. klient->getNachrichtEncrypted( key, len );
  729. if( rs->zDB()->aktiviereAccount( acc_name, key ) )
  730. {
  731. klient->sendeEncrypted( "\1", 1 );
  732. delete[]key;
  733. break;
  734. }
  735. else
  736. klient->sendeEncrypted( "\0", 1 );
  737. delete[]key;
  738. }
  739. }
  740. gebDatum->release();
  741. }
  742. else
  743. {
  744. if( pres == 1 )
  745. errorZuKlient( "Der Name wird bereits verwendet." );
  746. else if( pres == 2 )
  747. errorZuKlient( "Die E-Mail Adresse wird bereits verwendet." );
  748. }
  749. delete[]acc_name;
  750. delete[]acc_pass;
  751. delete[]acc_geheim;
  752. delete[]acc_mail;
  753. }
  754. break;
  755. case 6: // Account removen
  756. if( 1 )
  757. {
  758. if( !klientNummer )
  759. {
  760. errorZuKlient( "Du bist nicht Identifiziert." );
  761. break;
  762. }
  763. klient->sendeEncrypted( "\1", 1 );
  764. char len[ 3 ];
  765. klient->getNachrichtEncrypted( len, 3 );
  766. char *acc_name = new char[ len[ 0 ] + 1 ];
  767. acc_name[ (int)len[ 0 ] ] = 0;
  768. klient->getNachrichtEncrypted( acc_name, len[ 0 ] );
  769. char *acc_pass = new char[ len[ 1 ] + 1 ];
  770. acc_pass[ (int)len[ 1 ] ] = 0;
  771. klient->getNachrichtEncrypted( acc_pass, len[ 1 ] );
  772. char *acc_geheim = new char[ len[ 2 ] + 1 ];
  773. acc_geheim[ (int)len[ 2 ] ] = 0;
  774. klient->getNachrichtEncrypted( acc_geheim, len[ 2 ] );
  775. int res = rs->zDB()->removeAccount( acc_name, acc_pass, acc_geheim, rs->zIni() );
  776. if( !res )
  777. {
  778. klient->sendeEncrypted( "\1", 1 );
  779. while( 1 )
  780. {
  781. char len = 0;
  782. klient->getNachrichtEncrypted( &len, 1 );
  783. if( !len )
  784. {
  785. rs->zDB()->removeAccountAbbruch( acc_name );
  786. break;
  787. }
  788. if( len == -1 )
  789. break;
  790. char *key = new char[ len + 1 ];
  791. key[ (int)len ] = 0;
  792. klient->getNachrichtEncrypted( key, len );
  793. if( rs->zDB()->removeConfirmation( acc_name, key ) )
  794. {
  795. klient->sendeEncrypted( "\1", 1 );
  796. delete[]key;
  797. break;
  798. }
  799. else
  800. klient->sendeEncrypted( "\0", 1 );
  801. delete[]key;
  802. }
  803. }
  804. else if( res == 1 )
  805. errorZuKlient( "Der Account wurde nicht gefunden." );
  806. else if( res == 2 )
  807. errorZuKlient( "Falsches Passwort." );
  808. else if( res == 3 )
  809. errorZuKlient( "Falsches Geheimnis." );
  810. delete[]acc_name;
  811. delete[]acc_pass;
  812. delete[]acc_geheim;
  813. }
  814. break;
  815. case 7: // Passwort ändern
  816. if( 1 )
  817. {
  818. if( !klientNummer )
  819. {
  820. errorZuKlient( "Du bist nicht Identifiziert." );
  821. break;
  822. }
  823. klient->sendeEncrypted( "\1", 1 );
  824. unsigned char len[ 4 ];
  825. klient->getNachrichtEncrypted( (char*)len, 4 );
  826. char *accName = new char[ len[ 0 ] + 1 ];
  827. accName[ len[ 0 ] ] = 0;
  828. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  829. char *accPasswort = new char[ len[ 1 ] + 1 ];
  830. accPasswort[ len[ 1 ] ] = 0;
  831. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  832. char *neuPasswort = new char[ len[ 2 ] + 1 ];
  833. neuPasswort[ len[ 2 ] ] = 0;
  834. klient->getNachrichtEncrypted( neuPasswort, len[ 2 ] );
  835. char *accGeheimnis = new char[ len[ 3 ] + 1 ];
  836. accGeheimnis[ len[ 3 ] ] = 0;
  837. klient->getNachrichtEncrypted( accGeheimnis, len[ 3 ] );
  838. int res = rs->zDB()->passwortChange( accName, accPasswort, neuPasswort, accGeheimnis );
  839. if( !res )
  840. klient->sendeEncrypted( "\1", 1 );
  841. else if( res == 1 )
  842. errorZuKlient( "Account nicht gefunden." );
  843. else if( res == 2 )
  844. errorZuKlient( "Falsches Passwort." );
  845. else if( res == 3 )
  846. errorZuKlient( "Falsches Geheimnis." );
  847. delete[]accName;
  848. delete[]accPasswort;
  849. delete[]neuPasswort;
  850. delete[]accGeheimnis;
  851. }
  852. break;
  853. case 8: // E-Mail ändern
  854. if( 1 )
  855. {
  856. if( !klientNummer )
  857. {
  858. errorZuKlient( "Du bist nicht Identifiziert." );
  859. break;
  860. }
  861. klient->sendeEncrypted( "\1", 1 );
  862. unsigned char len[ 4 ];
  863. klient->getNachrichtEncrypted( (char*)len, 4 );
  864. char *accName = new char[ len[ 0 ] + 1 ];
  865. accName[ len[ 0 ] ] = 0;
  866. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  867. char *accPasswort = new char[ len[ 1 ] + 1 ];
  868. accPasswort[ len[ 1 ] ] = 0;
  869. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  870. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  871. accGeheimnis[ len[ 2 ] ] = 0;
  872. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  873. char *neuEMail = new char[ len[ 3 ] + 1 ];
  874. neuEMail[ len[ 3 ] ] = 0;
  875. klient->getNachrichtEncrypted( neuEMail, len[ 3 ] );
  876. int res = rs->zDB()->eMailChange( accName, accPasswort, accGeheimnis, neuEMail );
  877. if( !res )
  878. klient->sendeEncrypted( "\1", 1 );
  879. else if( res == 1 )
  880. errorZuKlient( "Account nicht gefunden." );
  881. else if( res == 2 )
  882. errorZuKlient( "Falsches Passwort." );
  883. else if( res == 3 )
  884. errorZuKlient( "Falsches Geheimnis." );
  885. else if( res == 4 )
  886. errorZuKlient( "Diese E-Mail Addresse wird bereits verwendet." );
  887. delete[]accName;
  888. delete[]accPasswort;
  889. delete[]accGeheimnis;
  890. delete[]neuEMail;
  891. }
  892. break;
  893. case 9: // Geheimnis Ändern
  894. if( 1 )
  895. {
  896. if( !klientNummer )
  897. {
  898. errorZuKlient( "Du bist nicht Identifiziert." );
  899. break;
  900. }
  901. klient->sendeEncrypted( "\1", 1 );
  902. unsigned char len[ 4 ];
  903. klient->getNachrichtEncrypted( (char*)len, 4 );
  904. char *accName = new char[ len[ 0 ] + 1 ];
  905. accName[ len[ 0 ] ] = 0;
  906. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  907. char *accPasswort = new char[ len[ 1 ] + 1 ];
  908. accPasswort[ len[ 1 ] ] = 0;
  909. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  910. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  911. accGeheimnis[ len[ 2 ] ] = 0;
  912. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  913. char *neuGeheimnis = new char[ len[ 3 ] + 1 ];
  914. neuGeheimnis[ len[ 3 ] ] = 0;
  915. klient->getNachrichtEncrypted( neuGeheimnis, len[ 3 ] );
  916. int res = rs->zDB()->geheimnisChange( accName, accPasswort, accGeheimnis, neuGeheimnis );
  917. if( !res )
  918. klient->sendeEncrypted( "\1", 1 );
  919. else if( res == 1 )
  920. errorZuKlient( "Account nicht gefunden." );
  921. else if( res == 2 )
  922. errorZuKlient( "Falsches Passwort." );
  923. else if( res == 3 )
  924. errorZuKlient( "Falsches Geheimnis." );
  925. delete[]accName;
  926. delete[]accPasswort;
  927. delete[]accGeheimnis;
  928. delete[]neuGeheimnis;
  929. }
  930. break;
  931. case 0xA: // Name Vergessen
  932. if( 1 )
  933. {
  934. if( !klientNummer )
  935. {
  936. errorZuKlient( "Du bist nicht Identifiziert." );
  937. break;
  938. }
  939. klient->sendeEncrypted( "\1", 1 );
  940. unsigned char len[ 2 ];
  941. klient->getNachrichtEncrypted( (char*)len, 2 );
  942. char *accPasswort = new char[ len[ 0 ] + 1 ];
  943. accPasswort[ len[ 0 ] ] = 0;
  944. klient->getNachrichtEncrypted( accPasswort, len[ 0 ] );
  945. char *accGeheimnis = new char[ len[ 1 ] + 1 ];
  946. accGeheimnis[ len[ 1 ] ] = 0;
  947. klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
  948. if( rs->zDB()->nameVergessen( accPasswort, accGeheimnis, rs->zIni() ) )
  949. klient->sendeEncrypted( "\1", 1 );
  950. else
  951. errorZuKlient( "Account nicht gefunden." );
  952. delete[]accPasswort;
  953. delete[]accGeheimnis;
  954. }
  955. break;
  956. case 0xB: // Passwort Vergessen
  957. if( 1 )
  958. {
  959. if( !klientNummer )
  960. {
  961. errorZuKlient( "Du bist nicht Identifiziert." );
  962. break;
  963. }
  964. klient->sendeEncrypted( "\1", 1 );
  965. unsigned char len[ 2 ];
  966. klient->getNachrichtEncrypted( (char*)len, 2 );
  967. char *accName = new char[ len[ 0 ] + 1 ];
  968. accName[ len[ 0 ] ] = 0;
  969. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  970. char *accGeheimnis = new char[ len[ 1 ] + 1 ];
  971. accGeheimnis[ len[ 1 ] ] = 0;
  972. klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
  973. if( rs->zDB()->passwortVergessen( accName, accGeheimnis, rs->zIni() ) )
  974. klient->sendeEncrypted( "\1", 1 );
  975. else
  976. errorZuKlient( "Account nicht gefunden." );
  977. delete[]accName;
  978. delete[]accGeheimnis;
  979. }
  980. break;
  981. case 0xC: // Geheimnis Vergessen
  982. if( 1 )
  983. {
  984. if( !klientNummer )
  985. {
  986. errorZuKlient( "Du bist nicht Identifiziert." );
  987. break;
  988. }
  989. klient->sendeEncrypted( "\1", 1 );
  990. unsigned char len[ 2 ];
  991. klient->getNachrichtEncrypted( (char*)len, 2 );
  992. char *accName = new char[ len[ 0 ] + 1 ];
  993. accName[ len[ 0 ] ] = 0;
  994. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  995. char *accPasswort = new char[ len[ 1 ] + 1 ];
  996. accPasswort[ len[ 1 ] ] = 0;
  997. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  998. if( rs->zDB()->geheimnisVergessen( accName, accPasswort, rs->zIni() ) )
  999. klient->sendeEncrypted( "\1", 1 );
  1000. else
  1001. errorZuKlient( "Account nicht gefunden." );
  1002. delete[]accName;
  1003. delete[]accPasswort;
  1004. }
  1005. break;
  1006. case 0xD: // E-Mail Vergessen
  1007. if( 1 )
  1008. {
  1009. if( !klientNummer )
  1010. {
  1011. errorZuKlient( "Du bist nicht Identifiziert." );
  1012. break;
  1013. }
  1014. klient->sendeEncrypted( "\1", 1 );
  1015. unsigned char len[ 3 ];
  1016. klient->getNachrichtEncrypted( (char*)len, 3 );
  1017. char *accName = new char[ len[ 0 ] + 1 ];
  1018. accName[ len[ 0 ] ] = 0;
  1019. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  1020. char *accPasswort = new char[ len[ 1 ] + 1 ];
  1021. accPasswort[ len[ 1 ] ] = 0;
  1022. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  1023. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  1024. accGeheimnis[ len[ 2 ] ] = 0;
  1025. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  1026. Text *eMail = rs->zDB()->eMailVergessen( accName, accPasswort, accGeheimnis );
  1027. if( eMail )
  1028. {
  1029. klient->sendeEncrypted( "\1", 1 );
  1030. unsigned char len = (unsigned char)eMail->getLength();
  1031. klient->sendeEncrypted( (char*)&len, 1 );
  1032. klient->sendeEncrypted( eMail->getText(), len );
  1033. eMail->release();
  1034. }
  1035. else
  1036. errorZuKlient( "Account nicht gefunden." );
  1037. delete[]accName;
  1038. delete[]accPasswort;
  1039. delete[]accGeheimnis;
  1040. }
  1041. break;
  1042. case 0xE: // Account bestätigen
  1043. if( 1 )
  1044. {
  1045. if( !klientNummer )
  1046. {
  1047. errorZuKlient( "Du bist nicht Identifiziert." );
  1048. break;
  1049. }
  1050. klient->sendeEncrypted( "\1", 1 );
  1051. unsigned char len[ 2 ];
  1052. klient->getNachrichtEncrypted( (char*)len, 2 );
  1053. char *accName = new char[ len[ 0 ] + 1 ];
  1054. accName[ len[ 0 ] ] = 0;
  1055. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  1056. char *accPasswort = new char[ len[ 1 ] + 1 ];
  1057. accPasswort[ len[ 1 ] ] = 0;
  1058. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  1059. char byte = rs->zDB()->suchConfirmation( accName, accPasswort );
  1060. if( !byte )
  1061. errorZuKlient( "Bei diesem Account ist keine Bestätigung notwendig." );
  1062. else if( byte == -1 )
  1063. errorZuKlient( "Falsche Kombination von Name und Passwort." );
  1064. else if( byte > 0 )
  1065. {
  1066. klient->sendeEncrypted( &byte, 1 );
  1067. char befehl = 0;
  1068. while( 1 )
  1069. {
  1070. klient->getNachrichtEncrypted( &befehl, 1 );
  1071. if( !befehl )
  1072. {
  1073. if( byte == 1 )
  1074. rs->zDB()->neuAccountAbbruch( accName );
  1075. if( byte == 2 )
  1076. rs->zDB()->removeAccountAbbruch( accName );
  1077. break;
  1078. }
  1079. if( befehl == -1 )
  1080. break;
  1081. if( befehl == -2 )
  1082. {
  1083. if( byte == 1 )
  1084. rs->zDB()->sendeErstellEMail( accName, rs->zIni() );
  1085. if( byte == 2 )
  1086. rs->zDB()->sendeRemoveEMail( accName, rs->zIni() );
  1087. }
  1088. if( befehl > 0 )
  1089. {
  1090. char *key = new char[ befehl + 1 ];
  1091. key[ (int)befehl ] = 0;
  1092. klient->getNachrichtEncrypted( key, befehl );
  1093. if( byte == 1 )
  1094. {
  1095. if( !rs->zDB()->aktiviereAccount( accName, key ) )
  1096. klient->sendeEncrypted( "\0", 1 );
  1097. else
  1098. {
  1099. klient->sendeEncrypted( "\1", 1 );
  1100. delete[]key;
  1101. break;
  1102. }
  1103. }
  1104. if( byte == 2 )
  1105. {
  1106. if( !rs->zDB()->removeConfirmation( accName, key ) )
  1107. klient->sendeEncrypted( "\0", 1 );
  1108. else
  1109. {
  1110. klient->sendeEncrypted( "\1", 1 );
  1111. delete[]key;
  1112. break;
  1113. }
  1114. }
  1115. delete[]key;
  1116. }
  1117. }
  1118. }
  1119. delete[]accName;
  1120. delete[]accPasswort;
  1121. }
  1122. break;
  1123. case 0xF: // ping
  1124. if( 1 )
  1125. {
  1126. if( !klientNummer )
  1127. {
  1128. errorZuKlient( "Du bist nicht Identifiziert." );
  1129. break;
  1130. }
  1131. klient->sendeEncrypted( "\1", 1 );
  1132. }
  1133. break;
  1134. default:
  1135. errorZuKlient( "Unbekannte Nachricht!" );
  1136. break;
  1137. }
  1138. if( br )
  1139. break;
  1140. }
  1141. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  1142. rs->addGesendet( klient->getUploadBytes( 1 ) );
  1143. }
  1144. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  1145. rs->addGesendet( klient->getUploadBytes( 1 ) );
  1146. rs->removeKlient( this ); // delete this
  1147. }
  1148. // constant
  1149. void RSKlient::errorZuKlient( const char *nachricht ) const // sendet eine Fehlernachricht zum Klient
  1150. {
  1151. klient->sendeEncrypted( "\3", 1 );
  1152. char len = (char)textLength( nachricht );
  1153. klient->sendeEncrypted( &len, 1 );
  1154. klient->sendeEncrypted( nachricht, len );
  1155. }
  1156. int RSKlient::getKlientNummer() const // gibt die KlientId zurück
  1157. {
  1158. return klientNummer;
  1159. }
  1160. // Reference Counting
  1161. RSKlient *RSKlient::getThis()
  1162. {
  1163. ref++;
  1164. return this;
  1165. }
  1166. RSKlient *RSKlient::release()
  1167. {
  1168. ref--;
  1169. if( !ref )
  1170. delete this;
  1171. return 0;
  1172. }