RegisterServer.cpp 28 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102
  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. klient->sendeEncrypted( "\1", 1 );
  714. gebDatum->release();
  715. }
  716. else
  717. {
  718. if( pres == 1 )
  719. errorZuKlient( "Der Name wird bereits verwendet." );
  720. else if( pres == 2 )
  721. errorZuKlient( "Die E-Mail Adresse wird bereits verwendet." );
  722. }
  723. delete[]acc_name;
  724. delete[]acc_pass;
  725. delete[]acc_geheim;
  726. delete[]acc_mail;
  727. }
  728. break;
  729. case 6: // Account removen
  730. if( 1 )
  731. {
  732. if( !klientNummer )
  733. {
  734. errorZuKlient( "Du bist nicht Identifiziert." );
  735. break;
  736. }
  737. klient->sendeEncrypted( "\1", 1 );
  738. char len[ 3 ];
  739. klient->getNachrichtEncrypted( len, 3 );
  740. char *acc_name = new char[ len[ 0 ] + 1 ];
  741. acc_name[ (int)len[ 0 ] ] = 0;
  742. klient->getNachrichtEncrypted( acc_name, len[ 0 ] );
  743. char *acc_pass = new char[ len[ 1 ] + 1 ];
  744. acc_pass[ (int)len[ 1 ] ] = 0;
  745. klient->getNachrichtEncrypted( acc_pass, len[ 1 ] );
  746. char *acc_geheim = new char[ len[ 2 ] + 1 ];
  747. acc_geheim[ (int)len[ 2 ] ] = 0;
  748. klient->getNachrichtEncrypted( acc_geheim, len[ 2 ] );
  749. int res = rs->zDB()->removeAccount( acc_name, acc_pass, acc_geheim, rs->zIni() );
  750. if( !res )
  751. {
  752. klient->sendeEncrypted( "\1", 1 );
  753. while( 1 )
  754. {
  755. char len = 0;
  756. klient->getNachrichtEncrypted( &len, 1 );
  757. if( !len )
  758. {
  759. rs->zDB()->removeAccountAbbruch( acc_name );
  760. break;
  761. }
  762. if( len == -1 )
  763. break;
  764. char *key = new char[ len + 1 ];
  765. key[ (int)len ] = 0;
  766. klient->getNachrichtEncrypted( key, len );
  767. if( rs->zDB()->removeConfirmation( acc_name, key ) )
  768. {
  769. klient->sendeEncrypted( "\1", 1 );
  770. delete[]key;
  771. break;
  772. }
  773. else
  774. klient->sendeEncrypted( "\0", 1 );
  775. delete[]key;
  776. }
  777. }
  778. else if( res == 1 )
  779. errorZuKlient( "Der Account wurde nicht gefunden." );
  780. else if( res == 2 )
  781. errorZuKlient( "Falsches Passwort." );
  782. else if( res == 3 )
  783. errorZuKlient( "Falsches Geheimnis." );
  784. delete[]acc_name;
  785. delete[]acc_pass;
  786. delete[]acc_geheim;
  787. }
  788. break;
  789. case 7: // Passwort ändern
  790. if( 1 )
  791. {
  792. if( !klientNummer )
  793. {
  794. errorZuKlient( "Du bist nicht Identifiziert." );
  795. break;
  796. }
  797. klient->sendeEncrypted( "\1", 1 );
  798. unsigned char len[ 4 ];
  799. klient->getNachrichtEncrypted( (char*)len, 4 );
  800. char *accName = new char[ len[ 0 ] + 1 ];
  801. accName[ len[ 0 ] ] = 0;
  802. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  803. char *accPasswort = new char[ len[ 1 ] + 1 ];
  804. accPasswort[ len[ 1 ] ] = 0;
  805. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  806. char *neuPasswort = new char[ len[ 2 ] + 1 ];
  807. neuPasswort[ len[ 2 ] ] = 0;
  808. klient->getNachrichtEncrypted( neuPasswort, len[ 2 ] );
  809. char *accGeheimnis = new char[ len[ 3 ] + 1 ];
  810. accGeheimnis[ len[ 3 ] ] = 0;
  811. klient->getNachrichtEncrypted( accGeheimnis, len[ 3 ] );
  812. int res = rs->zDB()->passwortChange( accName, accPasswort, neuPasswort, accGeheimnis );
  813. if( !res )
  814. klient->sendeEncrypted( "\1", 1 );
  815. else if( res == 1 )
  816. errorZuKlient( "Account nicht gefunden." );
  817. else if( res == 2 )
  818. errorZuKlient( "Falsches Passwort." );
  819. else if( res == 3 )
  820. errorZuKlient( "Falsches Geheimnis." );
  821. delete[]accName;
  822. delete[]accPasswort;
  823. delete[]neuPasswort;
  824. delete[]accGeheimnis;
  825. }
  826. break;
  827. case 8: // E-Mail ändern
  828. if( 1 )
  829. {
  830. if( !klientNummer )
  831. {
  832. errorZuKlient( "Du bist nicht Identifiziert." );
  833. break;
  834. }
  835. klient->sendeEncrypted( "\1", 1 );
  836. unsigned char len[ 4 ];
  837. klient->getNachrichtEncrypted( (char*)len, 4 );
  838. char *accName = new char[ len[ 0 ] + 1 ];
  839. accName[ len[ 0 ] ] = 0;
  840. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  841. char *accPasswort = new char[ len[ 1 ] + 1 ];
  842. accPasswort[ len[ 1 ] ] = 0;
  843. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  844. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  845. accGeheimnis[ len[ 2 ] ] = 0;
  846. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  847. char *neuEMail = new char[ len[ 3 ] + 1 ];
  848. neuEMail[ len[ 3 ] ] = 0;
  849. klient->getNachrichtEncrypted( neuEMail, len[ 3 ] );
  850. int res = rs->zDB()->eMailChange( accName, accPasswort, accGeheimnis, neuEMail );
  851. if( !res )
  852. klient->sendeEncrypted( "\1", 1 );
  853. else if( res == 1 )
  854. errorZuKlient( "Account nicht gefunden." );
  855. else if( res == 2 )
  856. errorZuKlient( "Falsches Passwort." );
  857. else if( res == 3 )
  858. errorZuKlient( "Falsches Geheimnis." );
  859. else if( res == 4 )
  860. errorZuKlient( "Diese E-Mail Addresse wird bereits verwendet." );
  861. delete[]accName;
  862. delete[]accPasswort;
  863. delete[]accGeheimnis;
  864. delete[]neuEMail;
  865. }
  866. break;
  867. case 9: // Geheimnis Ändern
  868. if( 1 )
  869. {
  870. if( !klientNummer )
  871. {
  872. errorZuKlient( "Du bist nicht Identifiziert." );
  873. break;
  874. }
  875. klient->sendeEncrypted( "\1", 1 );
  876. unsigned char len[ 4 ];
  877. klient->getNachrichtEncrypted( (char*)len, 4 );
  878. char *accName = new char[ len[ 0 ] + 1 ];
  879. accName[ len[ 0 ] ] = 0;
  880. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  881. char *accPasswort = new char[ len[ 1 ] + 1 ];
  882. accPasswort[ len[ 1 ] ] = 0;
  883. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  884. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  885. accGeheimnis[ len[ 2 ] ] = 0;
  886. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  887. char *neuGeheimnis = new char[ len[ 3 ] + 1 ];
  888. neuGeheimnis[ len[ 3 ] ] = 0;
  889. klient->getNachrichtEncrypted( neuGeheimnis, len[ 3 ] );
  890. int res = rs->zDB()->geheimnisChange( accName, accPasswort, accGeheimnis, neuGeheimnis );
  891. if( !res )
  892. klient->sendeEncrypted( "\1", 1 );
  893. else if( res == 1 )
  894. errorZuKlient( "Account nicht gefunden." );
  895. else if( res == 2 )
  896. errorZuKlient( "Falsches Passwort." );
  897. else if( res == 3 )
  898. errorZuKlient( "Falsches Geheimnis." );
  899. delete[]accName;
  900. delete[]accPasswort;
  901. delete[]accGeheimnis;
  902. delete[]neuGeheimnis;
  903. }
  904. break;
  905. case 0xA: // Name Vergessen
  906. if( 1 )
  907. {
  908. if( !klientNummer )
  909. {
  910. errorZuKlient( "Du bist nicht Identifiziert." );
  911. break;
  912. }
  913. klient->sendeEncrypted( "\1", 1 );
  914. unsigned char len[ 2 ];
  915. klient->getNachrichtEncrypted( (char*)len, 2 );
  916. char *accPasswort = new char[ len[ 0 ] + 1 ];
  917. accPasswort[ len[ 0 ] ] = 0;
  918. klient->getNachrichtEncrypted( accPasswort, len[ 0 ] );
  919. char *accGeheimnis = new char[ len[ 1 ] + 1 ];
  920. accGeheimnis[ len[ 1 ] ] = 0;
  921. klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
  922. if( rs->zDB()->nameVergessen( accPasswort, accGeheimnis, rs->zIni() ) )
  923. klient->sendeEncrypted( "\1", 1 );
  924. else
  925. errorZuKlient( "Account nicht gefunden." );
  926. delete[]accPasswort;
  927. delete[]accGeheimnis;
  928. }
  929. break;
  930. case 0xB: // Passwort Vergessen
  931. if( 1 )
  932. {
  933. if( !klientNummer )
  934. {
  935. errorZuKlient( "Du bist nicht Identifiziert." );
  936. break;
  937. }
  938. klient->sendeEncrypted( "\1", 1 );
  939. unsigned char len[ 2 ];
  940. klient->getNachrichtEncrypted( (char*)len, 2 );
  941. char *accName = new char[ len[ 0 ] + 1 ];
  942. accName[ len[ 0 ] ] = 0;
  943. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  944. char *accGeheimnis = new char[ len[ 1 ] + 1 ];
  945. accGeheimnis[ len[ 1 ] ] = 0;
  946. klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
  947. if( rs->zDB()->passwortVergessen( accName, accGeheimnis, rs->zIni() ) )
  948. klient->sendeEncrypted( "\1", 1 );
  949. else
  950. errorZuKlient( "Account nicht gefunden." );
  951. delete[]accName;
  952. delete[]accGeheimnis;
  953. }
  954. break;
  955. case 0xC: // Geheimnis Vergessen
  956. if( 1 )
  957. {
  958. if( !klientNummer )
  959. {
  960. errorZuKlient( "Du bist nicht Identifiziert." );
  961. break;
  962. }
  963. klient->sendeEncrypted( "\1", 1 );
  964. unsigned char len[ 2 ];
  965. klient->getNachrichtEncrypted( (char*)len, 2 );
  966. char *accName = new char[ len[ 0 ] + 1 ];
  967. accName[ len[ 0 ] ] = 0;
  968. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  969. char *accPasswort = new char[ len[ 1 ] + 1 ];
  970. accPasswort[ len[ 1 ] ] = 0;
  971. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  972. if( rs->zDB()->geheimnisVergessen( accName, accPasswort, rs->zIni() ) )
  973. klient->sendeEncrypted( "\1", 1 );
  974. else
  975. errorZuKlient( "Account nicht gefunden." );
  976. delete[]accName;
  977. delete[]accPasswort;
  978. }
  979. break;
  980. case 0xD: // E-Mail Vergessen
  981. if( 1 )
  982. {
  983. if( !klientNummer )
  984. {
  985. errorZuKlient( "Du bist nicht Identifiziert." );
  986. break;
  987. }
  988. klient->sendeEncrypted( "\1", 1 );
  989. unsigned char len[ 3 ];
  990. klient->getNachrichtEncrypted( (char*)len, 3 );
  991. char *accName = new char[ len[ 0 ] + 1 ];
  992. accName[ len[ 0 ] ] = 0;
  993. klient->getNachrichtEncrypted( accName, len[ 0 ] );
  994. char *accPasswort = new char[ len[ 1 ] + 1 ];
  995. accPasswort[ len[ 1 ] ] = 0;
  996. klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
  997. char *accGeheimnis = new char[ len[ 2 ] + 1 ];
  998. accGeheimnis[ len[ 2 ] ] = 0;
  999. klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
  1000. Text *eMail = rs->zDB()->eMailVergessen( accName, accPasswort, accGeheimnis );
  1001. if( eMail )
  1002. {
  1003. klient->sendeEncrypted( "\1", 1 );
  1004. unsigned char len = (unsigned char)eMail->getLength();
  1005. klient->sendeEncrypted( (char*)&len, 1 );
  1006. klient->sendeEncrypted( eMail->getText(), len );
  1007. eMail->release();
  1008. }
  1009. else
  1010. errorZuKlient( "Account nicht gefunden." );
  1011. delete[]accName;
  1012. delete[]accPasswort;
  1013. delete[]accGeheimnis;
  1014. }
  1015. break;
  1016. case 0xF: // ping
  1017. if( 1 )
  1018. {
  1019. if( !klientNummer )
  1020. {
  1021. errorZuKlient( "Du bist nicht Identifiziert." );
  1022. break;
  1023. }
  1024. klient->sendeEncrypted( "\1", 1 );
  1025. }
  1026. break;
  1027. default:
  1028. errorZuKlient( "Unbekannte Nachricht!" );
  1029. break;
  1030. }
  1031. if( br )
  1032. break;
  1033. }
  1034. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  1035. rs->addGesendet( klient->getUploadBytes( 1 ) );
  1036. }
  1037. rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
  1038. rs->addGesendet( klient->getUploadBytes( 1 ) );
  1039. rs->removeKlient( this ); // delete this
  1040. }
  1041. // constant
  1042. void RSKlient::errorZuKlient( const char *nachricht ) const // sendet eine Fehlernachricht zum Klient
  1043. {
  1044. klient->sendeEncrypted( "\3", 1 );
  1045. char len = (char)textLength( nachricht );
  1046. klient->sendeEncrypted( &len, 1 );
  1047. klient->sendeEncrypted( nachricht, len );
  1048. }
  1049. int RSKlient::getKlientNummer() const // gibt die KlientId zurück
  1050. {
  1051. return klientNummer;
  1052. }
  1053. // Reference Counting
  1054. RSKlient *RSKlient::getThis()
  1055. {
  1056. ref++;
  1057. return this;
  1058. }
  1059. RSKlient *RSKlient::release()
  1060. {
  1061. ref--;
  1062. if( !ref )
  1063. delete this;
  1064. return 0;
  1065. }