RegisterServer.cpp 38 KB

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