RegisterServer.cpp 26 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 = (int)*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. const 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. }