NewsServer.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772
  1. #include "NewsServer.h"
  2. #include <iostream>
  3. #include <Klient.h>
  4. #include <Globals.h>
  5. // Inhalt der NewsServer Klasse aus NewsServer.h
  6. // Konstruktor
  7. NewsServer::NewsServer( InitDatei* zIni )
  8. : Thread()
  9. {
  10. Network::Start( 100 );
  11. std::cout << "IS: Verbindung mit Datenbank wird hergestellt...\n";
  12. db = new NSDatenbank( zIni );
  13. klients = new RCArray< NSKlient >();
  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 << "IS: Starten des Admin Servers...\n";
  25. if( !aServer->verbinde( (unsigned short)TextZuInt( ini->zWert( "AdminServerPort" )->getText(), 10 ), 10 ) )
  26. {
  27. std::cout << "IS: 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. if( zIni->zWert( "Aktiv" )->istGleich( "TRUE" ) )
  35. {
  36. serverStarten();
  37. serverFortsetzen();
  38. }
  39. }
  40. // Destruktor
  41. NewsServer::~NewsServer()
  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 NewsServer::runn()
  56. {
  57. while( !end && aServer->isConnected() )
  58. {
  59. SSLSKlient* klient;
  60. klient = aServer->getKlient();
  61. if( end && klient )
  62. {
  63. klient->trenne();
  64. klient = (SSLSKlient*)klient->release();
  65. Sleep( 1000 );
  66. return;
  67. }
  68. if( !klient )
  69. continue;
  70. NSAKlient* clHandle = new NSAKlient( klient, dynamic_cast<NewsServer*>(getThis()) );
  71. clHandle->start();
  72. }
  73. }
  74. void NewsServer::thread()
  75. {
  76. while( server->isConnected() )
  77. {
  78. SKlient* klient;
  79. klient = server->getKlient();
  80. if( !klient )
  81. continue;
  82. Framework::getThreadRegister()->cleanUpClosedThreads();
  83. NSKlient* clHandle = new NSKlient( klient, dynamic_cast<NewsServer*>(getThis()) );
  84. EnterCriticalSection( &cs );
  85. klients->add( clHandle );
  86. LeaveCriticalSection( &cs );
  87. clHandle->start();
  88. }
  89. }
  90. void NewsServer::close()
  91. {
  92. db->setServerStatus( id, 1 );
  93. server->trenne();
  94. #ifdef WIN32
  95. warteAufThread( 1000 );
  96. #endif
  97. EnterCriticalSection( &cs );
  98. for( int i = 0; i < klients->getEintragAnzahl(); i++ )
  99. klients->z( i )->absturz();
  100. klients = (RCArray<NSKlient>*)klients->release();
  101. LeaveCriticalSection( &cs );
  102. ende();
  103. run = 0;
  104. end = 1;
  105. Klient* klient = new Klient();
  106. klient->verbinde( aServer->getPort(), "127.0.0.1" );
  107. Sleep( 500 );
  108. aServer->trenne();
  109. klient->release();
  110. }
  111. bool NewsServer::serverStarten()
  112. {
  113. if( nichtPausiert )
  114. {
  115. fehler->setText( "Der Server konnte nicht gestartet werden: Der Server läuft bereits." );
  116. return 0;
  117. }
  118. if( server )
  119. server->release();
  120. server = new Server();
  121. if( server->verbinde( (unsigned short)TextZuInt( ini->zWert( "ServerPort" )->getText(), 10 ), 10 ) )
  122. {
  123. nichtPausiert = 1;
  124. start();
  125. return 1;
  126. }
  127. else
  128. {
  129. serverBeenden();
  130. fehler->setText( "Der Server konnte nicht gestartet werden: Eventuell ist der Port in benutzung." );
  131. return 0;
  132. }
  133. }
  134. bool NewsServer::serverPause()
  135. {
  136. if( !nichtPausiert )
  137. {
  138. fehler->setText( "Der Server konnte nicht pausiert werden: Der Server läuft nicht." );
  139. return 0;
  140. }
  141. if( !db->setServerStatus( id, 2 ) )
  142. {
  143. fehler->setText( "Der Server konnte nicht pausiert werden: " );
  144. fehler->append( db->getLetzterFehler() );
  145. return 0;
  146. }
  147. return 1;
  148. }
  149. bool NewsServer::serverFortsetzen()
  150. {
  151. if( !nichtPausiert )
  152. {
  153. fehler->setText( "Der Server konnte nicht fortgesetzt werden: Der Server läuft nicht." );
  154. return 0;
  155. }
  156. if( !db->setServerStatus( id, 3 ) )
  157. {
  158. fehler->setText( "Der Server konnte nicht fortgesetzt werden: " );
  159. fehler->append( db->getLetzterFehler() );
  160. return 0;
  161. }
  162. return 1;
  163. }
  164. bool NewsServer::serverBeenden()
  165. {
  166. if( !nichtPausiert )
  167. {
  168. fehler->setText( "Der Server konnte nicht beendet werden: Der Server läuft nicht." );
  169. return 0;
  170. }
  171. if( db->serverIstNichtPausiert( id ) )
  172. {
  173. fehler->setText( "Der Server konnte nicht beendet werden: Der Server muss erst pausiert werden." );
  174. return 0;
  175. }
  176. nichtPausiert = 0;
  177. ende();
  178. if( server )
  179. server->trenne();
  180. return 1;
  181. }
  182. bool NewsServer::setMaxKlients( int mc )
  183. {
  184. if( !db->setMaxClients( id, mc ) )
  185. {
  186. fehler->setText( "Die maximale Anzahl der Clients konnte nicht gesetzt werden:\n" );
  187. fehler->append( db->getLetzterFehler() );
  188. return 0;
  189. }
  190. ini->setWert( "MaxClients", Text() += mc );
  191. return 1;
  192. }
  193. bool NewsServer::absturzKlient( int klientId )
  194. {
  195. bool gefunden = 0;
  196. EnterCriticalSection( &cs );
  197. for( int i = 0; i < klients->getEintragAnzahl(); i++ )
  198. {
  199. if( klients->z( i )->getKlientNummer() == klientId )
  200. {
  201. klients->z( i )->absturz();
  202. klients->remove( i );
  203. gefunden = 1;
  204. break;
  205. }
  206. }
  207. LeaveCriticalSection( &cs );
  208. return gefunden;
  209. }
  210. bool NewsServer::removeKlient( NSKlient* zKlient )
  211. {
  212. bool gefunden = 0;
  213. EnterCriticalSection( &cs );
  214. for( int i = 0; i < klients->getEintragAnzahl(); i++ )
  215. {
  216. if( klients->z( i ) == zKlient )
  217. {
  218. klients->remove( i );
  219. gefunden = 1;
  220. break;
  221. }
  222. }
  223. LeaveCriticalSection( &cs );
  224. return gefunden;
  225. }
  226. void NewsServer::addGesendet( int bytes )
  227. {
  228. gesendet += bytes;
  229. }
  230. void NewsServer::addEmpfangen( int bytes )
  231. {
  232. empfangen += bytes;
  233. }
  234. // constant
  235. bool NewsServer::istAn() const
  236. {
  237. return db->serverIstNichtPausiert( id );
  238. }
  239. Server* NewsServer::zServer() const
  240. {
  241. return server;
  242. }
  243. NSDatenbank* NewsServer::zDB() const
  244. {
  245. return db;
  246. }
  247. bool NewsServer::hatClients() const
  248. {
  249. return klients->hat( 0 );
  250. }
  251. int NewsServer::getId() const
  252. {
  253. return id;
  254. }
  255. char* NewsServer::getLetzterFehler() const
  256. {
  257. return fehler->getText();
  258. }
  259. // Inhalt der NSAKlient Klasse aus NewsServer.h
  260. // Konstruktor
  261. NSAKlient::NSAKlient( SSLSKlient* klient, NewsServer* ns )
  262. : Thread()
  263. {
  264. this->klient = klient;
  265. name = new Text( "" );
  266. passwort = new Text( "" );
  267. adminId = 0;
  268. this->ns = ns;
  269. }
  270. // Destruktor
  271. NSAKlient::~NSAKlient()
  272. {
  273. klient->trenne();
  274. klient->release();
  275. ns->release();
  276. name->release();
  277. passwort->release();
  278. }
  279. // nicht constant
  280. void NSAKlient::thread()
  281. {
  282. while( 1 )
  283. {
  284. char c = 0;
  285. if( !klient->getNachricht( &c, 1 ) )
  286. break;
  287. else
  288. {
  289. bool br = 0;
  290. switch( c )
  291. {
  292. case 1: // Login
  293. if( 1 )
  294. {
  295. klient->sende( "\1", 1 );
  296. unsigned char nLen = 0;
  297. klient->getNachricht( (char*)&nLen, 1 );
  298. char* n = new char[ nLen + 1 ];
  299. n[ (int)nLen ] = 0;
  300. if( nLen )
  301. klient->getNachricht( n, nLen );
  302. unsigned char pLen = 0;
  303. klient->getNachricht( (char*)&pLen, 1 );
  304. char* p = new char[ pLen + 1 ];
  305. p[ (int)pLen ] = 0;
  306. if( pLen )
  307. klient->getNachricht( p, pLen );
  308. int adminId = ns->zDB()->istAdministrator( n, p );
  309. if( adminId )
  310. {
  311. klient->sende( "\1", 1 );
  312. name->setText( n );
  313. passwort->setText( p );
  314. this->adminId = adminId;
  315. }
  316. else
  317. errorZuKlient( "Falsche Kombination aus Name und Passwort." );
  318. delete[] n;
  319. delete[] p;
  320. }
  321. break;
  322. case 2: // Logout
  323. adminId = 0;
  324. name->setText( "" );
  325. passwort->setText( "" );
  326. klient->sende( "\1", 1 );
  327. break;
  328. case 3: // Trennen
  329. br = 1;
  330. klient->sende( "\1", 1 );
  331. break;
  332. case 4: // Server starten
  333. if( !adminId )
  334. errorZuKlient( "Du musst dich einloggen." );
  335. else
  336. {
  337. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSStarten ) )
  338. {
  339. if( !ns->serverStarten() )
  340. {
  341. Text* err = new Text();
  342. err->append( ns->getLetzterFehler() );
  343. errorZuKlient( err->getText() );
  344. err->release();
  345. }
  346. else
  347. klient->sende( "\1", 1 );
  348. }
  349. else
  350. errorZuKlient( "Du bist nicht berechtigt den Server zu starten." );
  351. }
  352. break;
  353. case 5: // Server beenden
  354. if( !adminId )
  355. errorZuKlient( "Du musst dich einloggen." );
  356. else
  357. {
  358. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSBeenden ) )
  359. {
  360. if( ns->serverBeenden() )
  361. klient->sende( "\1", 1 );
  362. else
  363. {
  364. Text* err = new Text();
  365. err->append( ns->getLetzterFehler() );
  366. errorZuKlient( err->getText() );
  367. err->release();
  368. }
  369. }
  370. else
  371. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  372. }
  373. break;
  374. case 6: // Programm Schließen
  375. if( !adminId )
  376. errorZuKlient( "Du musst dich einloggen." );
  377. else
  378. {
  379. bool ok = 0;
  380. if( ns->isRunning() )
  381. {
  382. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSBeenden ) )
  383. {
  384. if( ns->serverBeenden() )
  385. ok = 1;
  386. else
  387. {
  388. Text* err = new Text();
  389. err->append( ns->getLetzterFehler() );
  390. errorZuKlient( err->getText() );
  391. err->release();
  392. }
  393. }
  394. else
  395. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  396. }
  397. else
  398. ok = 1;
  399. if( ok && ns->hatClients() )
  400. {
  401. errorZuKlient( "Es sind noch Klients Online. Bitte versuche es später erneut." );
  402. break;
  403. }
  404. if( ok )
  405. {
  406. klient->sende( "\1", 1 );
  407. std::cout << "NS: Der Server wird von Benutzer " << adminId << " heruntergefahren.\n";
  408. ns->close();
  409. br = 1;
  410. }
  411. }
  412. break;
  413. case 7: // Programm abstürzen
  414. if( !adminId )
  415. errorZuKlient( "Du musst dich einloggen." );
  416. else
  417. {
  418. bool ok = 0;
  419. if( ns->isRunning() )
  420. {
  421. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSBeenden ) )
  422. {
  423. ns->serverBeenden();
  424. ok = 1;
  425. }
  426. else
  427. errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
  428. }
  429. else
  430. ok = 1;
  431. if( ok )
  432. {
  433. klient->sende( "\1", 1 );
  434. std::cout << "NS: Der Server wurde von Benutzer " << adminId << " terminiert.\n";
  435. ns->close();
  436. br = 1;
  437. }
  438. }
  439. break;
  440. case 8: // Status Frage
  441. if( 1 )
  442. {
  443. char status = 0;
  444. if( ns->isRunning() )
  445. {
  446. status = 1;
  447. if( ns->istAn() )
  448. status = 2;
  449. }
  450. klient->sende( "\1", 1 );
  451. klient->sende( &status, 1 );
  452. }
  453. break;
  454. case 9: // Server pausieren
  455. if( !adminId )
  456. errorZuKlient( "Du musst dich einloggen." );
  457. else
  458. {
  459. klient->sende( "\1", 1 );
  460. char pause = 0;
  461. klient->getNachricht( &pause, 1 );
  462. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSPausieren ) )
  463. {
  464. bool ok = 0;
  465. if( pause )
  466. ok = ns->serverPause();
  467. else
  468. ok = ns->serverFortsetzen();
  469. if( ok )
  470. klient->sende( "\1", 1 );
  471. else
  472. {
  473. Text* err = new Text();
  474. err->append( ns->getLetzterFehler() );
  475. errorZuKlient( err->getText() );
  476. err->release();
  477. }
  478. }
  479. else
  480. {
  481. if( pause )
  482. errorZuKlient( "Du bist nicht berechtigt den Server zu pausieren." );
  483. else
  484. errorZuKlient( "Du bist nicht berechtigt den Server fortzusetzen." );
  485. }
  486. }
  487. break;
  488. case 0xA: // maximale Anzahl der Clients setzen
  489. if( !adminId )
  490. errorZuKlient( "Du musst dich einloggen." );
  491. else
  492. {
  493. klient->sende( "\1", 1 );
  494. int maxC = 0;
  495. klient->getNachricht( (char*)&maxC, 4 );
  496. if( ns->zDB()->adminHatRecht( adminId, Admin_Recht::NSMCChange ) )
  497. {
  498. if( ns->setMaxKlients( maxC ) )
  499. klient->sende( "\1", 1 );
  500. else
  501. {
  502. Text* err = new Text();
  503. err->append( ns->getLetzterFehler() );
  504. errorZuKlient( err->getText() );
  505. err->release();
  506. }
  507. }
  508. else
  509. errorZuKlient( "Du bist nicht berechtigt die maximale Anzahl der Clients zu verändern." );
  510. }
  511. break;
  512. case 0xC: // klient absturtz
  513. if( 1 )
  514. {
  515. klient->sende( "\1", 1 );
  516. int klientId = 0;
  517. klient->getNachricht( (char*)&klientId, 4 );
  518. if( klientId && ns->absturzKlient( klientId ) )
  519. klient->sende( "\1", 1 );
  520. else
  521. klient->sende( "\0", 1 );
  522. }
  523. break;
  524. default:
  525. errorZuKlient( "Unbekannte Nachricht!" );
  526. break;
  527. }
  528. if( br )
  529. break;
  530. ns->addEmpfangen( klient->getDownloadBytes( 1 ) );
  531. ns->addGesendet( klient->getUploadBytes( 1 ) );
  532. }
  533. }
  534. ns->addEmpfangen( klient->getDownloadBytes( 1 ) );
  535. ns->addGesendet( klient->getUploadBytes( 1 ) );
  536. delete this;
  537. }
  538. void NSAKlient::errorZuKlient( const char* nachricht ) const // sendet eine Fehlernachricht zum Klient
  539. {
  540. klient->sende( "\3", 1 );
  541. char len = (char)textLength( nachricht );
  542. klient->sende( &len, 1 );
  543. klient->sende( nachricht, len );
  544. }
  545. // Inhalt der NSKlient aus NewsServer.h
  546. // Konstruktor
  547. NSKlient::NSKlient( SKlient* klient, NewsServer* ns )
  548. : Thread()
  549. {
  550. this->klient = klient;
  551. unsigned char key[ 20 ] = { 4, 150, 243, 145, 204, 71, 253, 88, 4, 51, 189, 207, 189, 248, 231, 40, 106, 7, 182, 5 };
  552. klient->setSendeKey( (char*)key, 20 );
  553. klient->setEmpfangKey( (char*)key, 20 );
  554. klientNummer = 0;
  555. this->ns = ns;
  556. }
  557. // Destruktor
  558. NSKlient::~NSKlient()
  559. {
  560. klient->release();
  561. ns->release();
  562. }
  563. // nicht constant
  564. void NSKlient::absturz()
  565. {
  566. ende();
  567. klient->trenne();
  568. ns->zDB()->unregisterKlient( klientNummer, ns->getId() );
  569. }
  570. void NSKlient::thread()
  571. {
  572. while( 1 )
  573. {
  574. char c = 0;
  575. if( !klient->getNachrichtEncrypted( &c, 1 ) )
  576. break;
  577. else
  578. {
  579. bool br = 0;
  580. switch( c )
  581. {
  582. case 1: // Klient identifikation
  583. klient->getNachrichtEncrypted( (char*)&klientNummer, 4 );
  584. if( !ns->zDB()->proveKlient( klientNummer, ns->getId() ) )
  585. {
  586. klientNummer = 0;
  587. errorZuKlient( "Du bist nicht für diesen Server eingetragen" );
  588. }
  589. else
  590. {
  591. Text* key = ns->zDB()->getKlientKey( klientNummer );
  592. if( !key )
  593. errorZuKlient( "Es konnte kein Key ermittelt werden." );
  594. else
  595. {
  596. klient->sendeEncrypted( "\1", 1 );
  597. klient->setEmpfangKey( *key, key->getLength() );
  598. klient->setSendeKey( *key, key->getLength() );
  599. key->release();
  600. }
  601. }
  602. break;
  603. case 2: // Main / Erhaltung Server message
  604. if( 1 )
  605. {
  606. char befehl = 0;
  607. klient->getNachrichtEncrypted( &befehl, 1 );
  608. switch( befehl )
  609. {
  610. case 2: // klient absturtz
  611. if( 1 )
  612. {
  613. int klientId = 0;
  614. klient->getNachrichtEncrypted( (char*)&klientId, 4 );
  615. if( klientId && ns->absturzKlient( klientId ) )
  616. klient->sendeEncrypted( "\1", 1 );
  617. else
  618. klient->sendeEncrypted( "\0", 1 );
  619. }
  620. break;
  621. default:
  622. errorZuKlient( "Befehl nicht bekannt!" );
  623. break;
  624. }
  625. }
  626. break;
  627. case 3: // Verbindungsende
  628. br = 1;
  629. klient->sendeEncrypted( "\1", 1 );
  630. break;
  631. case 4: // unregister Klient
  632. if( !klientNummer )
  633. {
  634. errorZuKlient( "Du bist nicht Identifiziert." );
  635. break;
  636. }
  637. ns->zDB()->unregisterKlient( klientNummer, ns->getId() );
  638. klient->sendeEncrypted( "\1", 1 );
  639. break;
  640. case 5: // frage nach Seite
  641. if( klientNummer )
  642. {
  643. klient->sendeEncrypted( "\1", 1 );
  644. unsigned char len = 0;
  645. klient->getNachrichtEncrypted( (char*)&len, 1 );
  646. char* n = new char[ len + 1 ];
  647. n[ (int)len ] = 0;
  648. klient->getNachrichtEncrypted( n, len );
  649. Text* pfad = new Text( "../news/" );
  650. pfad->append( n );
  651. delete[] n;
  652. if( !DateiExistiert( pfad->getText() ) )
  653. {
  654. errorZuKlient( "Die Seite ist nicht vorhanden." );
  655. pfad->release();
  656. break;
  657. }
  658. klient->sendeEncrypted( "\1", 1 );
  659. Datei* dat = new Datei();
  660. dat->setDatei( pfad );
  661. RCArray< Text >* list = dat->getDateiListe();
  662. int dAnz = list->getEintragAnzahl();
  663. for( int i = 0; i < dAnz; i++ )
  664. {
  665. if( DateiIstVerzeichnis( list->get( i ) ) || list->z( i )->istGleich( "." ) || list->z( i )->istGleich( ".." ) )
  666. {
  667. list->remove( i );
  668. dAnz--;
  669. i--;
  670. }
  671. }
  672. klient->sendeEncrypted( (char*)&dAnz, 4 );
  673. for( int i = 0; i < dAnz; i++ )
  674. {
  675. Text* pf = new Text( dat->zPfad()->getText() );
  676. pf->append( "/" );
  677. pf->append( list->z( i )->getText() );
  678. Datei* d = new Datei();
  679. d->setDatei( pf );
  680. d->open( Datei::Style::lesen );
  681. char nl = (char)list->z( i )->getLength();
  682. klient->sendeEncrypted( &nl, 1 );
  683. klient->sendeEncrypted( list->z( i )->getText(), nl );
  684. __int64 gr = d->getSize();
  685. klient->sendeEncrypted( (char*)&gr, 8 );
  686. char* bytes = new char[ 2048 ];
  687. while( gr > 0 )
  688. {
  689. int len = gr > 2048 ? 2048 : (int)gr;
  690. d->lese( bytes, len );
  691. klient->sende( bytes, len );
  692. gr -= len;
  693. }
  694. delete[] bytes;
  695. d->close();
  696. d->release();
  697. }
  698. list->release();
  699. dat->release();
  700. }
  701. else
  702. errorZuKlient( "Du bist nicht Identifiziert." );
  703. break;
  704. case 0x6: // ping
  705. if( 1 )
  706. {
  707. if( !klientNummer )
  708. {
  709. errorZuKlient( "Du bist nicht Identifiziert." );
  710. break;
  711. }
  712. klient->sendeEncrypted( "\1", 1 );
  713. }
  714. break;
  715. default:
  716. errorZuKlient( "Unbekannte Nachricht!" );
  717. break;
  718. }
  719. if( br )
  720. break;
  721. ns->addEmpfangen( klient->getDownloadBytes( 1 ) );
  722. ns->addGesendet( klient->getUploadBytes( 1 ) );
  723. }
  724. }
  725. ns->addEmpfangen( klient->getDownloadBytes( 1 ) );
  726. ns->addGesendet( klient->getUploadBytes( 1 ) );
  727. ns->removeKlient( this ); // delete this
  728. }
  729. // constant
  730. void NSKlient::errorZuKlient( const char* nachricht ) const // sendet eine Fehlernachricht zum Klient
  731. {
  732. klient->sendeEncrypted( "\3", 1 );
  733. char len = (char)textLength( nachricht );
  734. klient->sendeEncrypted( &len, 1 );
  735. klient->sendeEncrypted( nachricht, len );
  736. }
  737. int NSKlient::getKlientNummer() const // gibt die KlientId zurück
  738. {
  739. return klientNummer;
  740. }