123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209 |
- #include "RegisterServer.h"
- #include <iostream>
- #include <Klient.h>
- #include <Globals.h>
- // Inhalt der RegiserServer Klasse aus RegisterServer.h
- // Konstruktor
- RegisterServer::RegisterServer( InitDatei *zIni )
- : Thread()
- {
- Network::Start( 100 );
- std::cout << "RS: Verbindung mit Datenbank wird hergestellt...\n";
- db = new RSDatenbank( zIni );
- klientAnzahl = 0;
- klients = new RCArray< RSKlient >();
- empfangen = 0;
- gesendet = 0;
- fehler = new Text();
- ini = zIni->getThis();
- id = *zIni->zWert( "ServerId" );
- server = new Server();
- aServer = new Server();
- std::cout << "RS: Starten des Admin Servers...\n";
- if( !aServer->verbinde( (unsigned short)TextZuInt( ini->zWert( "AdminServerPort" )->getText(), 10 ), 10 ) )
- {
- std::cout << "RS: Der Admin Server konnte nicht gestartet werden. Das Programm wird beendet.\n";
- exit( 1 );
- }
- db->setServerStatus( id, 2 );
- end = 0;
- nichtPausiert = 0;
- InitializeCriticalSection( &cs );
- update = 0;
- ref = 1;
- if( zIni->zWert( "Aktiv" )->istGleich( "TRUE" ) )
- {
- serverStarten();
- serverFortsetzen();
- }
- }
- // Destruktor
- RegisterServer::~RegisterServer()
- {
- fehler->release();
- server->trenne();
- server->release();
- aServer->trenne();
- aServer->release();
- if( klients )
- klients->release();
- ini->release();
- db->release();
- DeleteCriticalSection( &cs );
- }
- // nicht constant
- void RegisterServer::runn()
- {
- while( !end )
- {
- SKlient *klient;
- klient = aServer->getKlient();
- if( end && klient )
- {
- klient->trenne();
- klient = klient->release();
- Sleep( 1000 );
- return;
- }
- if( !klient )
- return;
- RSAKlient *clHandle = new RSAKlient( klient, getThis() );
- clHandle->start();
- }
- }
- void RegisterServer::thread()
- {
- while( 1 )
- {
- SKlient *klient;
- klient = server->getKlient();
- if( !klient )
- break;
- Framework::getThreadRegister()->cleanUpClosedThreads();
- RSKlient *clHandle = new RSKlient( klient, getThis() );
- EnterCriticalSection( &cs );
- klients->set( clHandle, klientAnzahl );
- klientAnzahl++;
- LeaveCriticalSection( &cs );
- clHandle->start();
- }
- }
- void RegisterServer::close()
- {
- db->setServerStatus( id, 1 );
- server->trenne();
- #ifdef WIN32
- warteAufThread( 1000 );
- #endif
- EnterCriticalSection( &cs );
- for( int i = 0; i < klientAnzahl; i++ )
- klients->z( i )->absturz();
- klients = klients->release();
- klientAnzahl = 0;
- LeaveCriticalSection( &cs );
- ende();
- run = 0;
- end = 1;
- Klient *klient = new Klient();
- klient->verbinde( aServer->getPort(), "127.0.0.1" );
- Sleep( 500 );
- aServer->trenne();
- klient->release();
- }
- bool RegisterServer::serverStarten()
- {
- if( nichtPausiert )
- {
- fehler->setText( "Der Server konnte nicht gestartet werden: Der Server läuft bereits." );
- return 0;
- }
- if( server )
- server->release();
- server = new Server();
- if( server->verbinde( (unsigned short)TextZuInt( ini->zWert( "ServerPort" )->getText(), 10 ), 10 ) )
- {
- nichtPausiert = 1;
- start();
- return 1;
- }
- else
- {
- serverBeenden();
- fehler->setText( "Der Server konnte nicht gestartet werden: Eventuell ist der Port in benutzung." );
- return 0;
- }
- }
- bool RegisterServer::serverPause()
- {
- if( !nichtPausiert )
- {
- fehler->setText( "Der Server konnte nicht pausiert werden: Der Server läuft nicht." );
- return 0;
- }
- if( !db->setServerStatus( id, 2 ) )
- {
- fehler->setText( "Der Server konnte nicht pausiert werden: " );
- fehler->append( db->getLetzterFehler() );
- return 0;
- }
- return 1;
- }
- bool RegisterServer::serverFortsetzen()
- {
- if( !nichtPausiert )
- {
- fehler->setText( "Der Server konnte nicht fortgesetzt werden: Der Server läuft nicht." );
- return 0;
- }
- if( !db->setServerStatus( id, 3 ) )
- {
- fehler->setText( "Der Server konnte nicht fortgesetzt werden: " );
- fehler->append( db->getLetzterFehler() );
- return 0;
- }
- return 1;
- }
- bool RegisterServer::serverBeenden()
- {
- if( !nichtPausiert )
- {
- fehler->setText( "Der Server konnte nicht beendet werden: Der Server läuft nicht." );
- return 0;
- }
- if( db->serverIstNichtPausiert( id ) )
- {
- fehler->setText( "Der Server konnte nicht beendet werden: Der Server muss erst pausiert werden." );
- return 0;
- }
- nichtPausiert = 0;
- ende();
- if( server )
- server->trenne();
- return 1;
- }
- bool RegisterServer::setMaxKlients( int mc )
- {
- if( !db->setMaxClients( id, mc ) )
- {
- fehler->setText( "Die maximale Anzahl der Clients konnte nicht gesetzt werden:\n" );
- fehler->append( db->getLetzterFehler() );
- return 0;
- }
- ini->setWert( "MaxClients", Text() += mc );
- return 1;
- }
- bool RegisterServer::absturzKlient( int klientId )
- {
- bool gefunden = 0;
- EnterCriticalSection( &cs );
- for( int i = 0; i < klientAnzahl; i++ )
- {
- if( klients->z( i )->getKlientNummer() == klientId )
- {
- klients->z( i )->absturz();
- klients->remove( i );
- klientAnzahl--;
- gefunden = 1;
- break;
- }
- }
- LeaveCriticalSection( &cs );
- return gefunden;
- }
- bool RegisterServer::removeKlient( RSKlient *zKlient )
- {
- bool gefunden = 0;
- EnterCriticalSection( &cs );
- for( int i = 0; i < klientAnzahl; i++ )
- {
- if( klients->z( i ) == zKlient )
- {
- klients->remove( i );
- klientAnzahl--;
- gefunden = 1;
- break;
- }
- }
- LeaveCriticalSection( &cs );
- return gefunden;
- }
- void RegisterServer::addGesendet( int bytes )
- {
- gesendet += bytes;
- }
- void RegisterServer::addEmpfangen( int bytes )
- {
- empfangen += bytes;
- }
- // constant
- bool RegisterServer::istAn() const
- {
- return db->serverIstNichtPausiert( id );
- }
- Server *RegisterServer::zServer() const
- {
- return server;
- }
- RSDatenbank *RegisterServer::zDB() const
- {
- return db;
- }
- bool RegisterServer::hatClients() const
- {
- return klientAnzahl > 0;
- }
- int RegisterServer::getId() const
- {
- return id;
- }
- char *RegisterServer::getLetzterFehler() const
- {
- return fehler->getText();
- }
- InitDatei *RegisterServer::zIni() const
- {
- return ini;
- }
- // Reference Counting
- RegisterServer *RegisterServer::getThis()
- {
- ref++;
- return this;
- }
- RegisterServer *RegisterServer::release()
- {
- ref--;
- if( !ref )
- delete this;
- return 0;
- }
- // Inhalt der RSAKlient Klasse aus RegisterServer.h
- // Konstruktor
- RSAKlient::RSAKlient( SKlient *klient, RegisterServer *rs )
- : Thread()
- {
- this->klient = klient;
- unsigned char key[ 20 ] = { 246, 1, 73, 51, 10, 103, 151, 180, 17, 220, 28, 241, 131, 229, 66, 137, 175, 218, 133, 58 };
- klient->setSendeKey( (char*)key, 20 );
- klient->setEmpfangKey( (char*)key, 20 );
- name = new Text( "" );
- passwort = new Text( "" );
- adminId = 0;
- version = 0;
- this->rs = rs;
- }
- // Destruktor
- RSAKlient::~RSAKlient()
- {
- klient->trenne();
- klient->release();
- rs->release();
- name->release();
- passwort->release();
- }
- // nicht constant
- void RSAKlient::thread()
- {
- while( 1 )
- {
- char c = 0;
- if( !klient->getNachrichtEncrypted( &c, 1 ) )
- break;
- else
- {
- bool br = 0;
- switch( c )
- {
- case 1: // Login
- if( 1 )
- {
- klient->sendeEncrypted( "\1", 1 );
- char nLen = 0;
- klient->getNachrichtEncrypted( &nLen, 1 );
- char *n = new char[ nLen + 1 ];
- n[ (int)nLen ] = 0;
- if( nLen )
- klient->getNachrichtEncrypted( n, nLen );
- char pLen = 0;
- klient->getNachrichtEncrypted( &pLen, 1 );
- char *p = new char[ pLen + 1 ];
- p[ (int)pLen ] = 0;
- if( pLen )
- klient->getNachrichtEncrypted( p, pLen );
- int adminId = rs->zDB()->istAdministrator( n, p );
- if( adminId )
- {
- klient->sendeEncrypted( "\1", 1 );
- name->setText( n );
- passwort->setText( p );
- this->adminId = adminId;
- }
- else
- errorZuKlient( "Falsche Kombination aus Name und Passwort." );
- delete[] n;
- delete[] p;
- }
- break;
- case 2: // Logout
- adminId = 0;
- name->setText( "" );
- passwort->setText( "" );
- klient->sendeEncrypted( "\1", 1 );
- break;
- case 3: // Trennen
- br = 1;
- klient->sendeEncrypted( "\1", 1 );
- break;
- case 4: // Server starten
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSStarten ) )
- {
- if( !rs->serverStarten() )
- {
- Text *err = new Text();
- err->append( rs->getLetzterFehler() );
- errorZuKlient( err->getText() );
- err->release();
- }
- else
- klient->sendeEncrypted( "\1", 1 );
- }
- else
- errorZuKlient( "Du bist nicht berechtigt den Server zu starten." );
- }
- break;
- case 5: // Server beenden
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
- {
- if( rs->serverBeenden() )
- klient->sendeEncrypted( "\1", 1 );
- else
- {
- Text *err = new Text();
- err->append( rs->getLetzterFehler() );
- errorZuKlient( err->getText() );
- err->release();
- }
- }
- else
- errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
- }
- break;
- case 6: // Programm Schließen
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- bool ok = 0;
- if( rs->isRunning() )
- {
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
- {
- if( rs->serverBeenden() )
- ok = 1;
- else
- {
- Text *err = new Text();
- err->append( rs->getLetzterFehler() );
- errorZuKlient( err->getText() );
- err->release();
- }
- }
- else
- errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
- }
- else
- ok = 1;
- if( ok && rs->hatClients() )
- {
- errorZuKlient( "Es sind noch Klients Online. Bitte versuche es später erneut." );
- break;
- }
- if( ok )
- {
- klient->sendeEncrypted( "\1", 1 );
- std::cout << "RS: Der Server wird von Benutzer " << adminId << " heruntergefahren.\n";
- rs->close();
- br = 1;
- }
- }
- break;
- case 7: // Progtamm abstürzen
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- bool ok = 0;
- if( rs->isRunning() )
- {
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSBeenden ) )
- {
- rs->serverBeenden();
- ok = 1;
- }
- else
- errorZuKlient( "Du bist nicht berechtigt den Server zu beenden." );
- }
- else
- ok = 1;
- if( ok )
- {
- klient->sendeEncrypted( "\1", 1 );
- std::cout << "RS: Der Server wurde von Benutzer " << adminId << " terminiert.\n";
- rs->close();
- br = 1;
- }
- }
- break;
- case 8: // Status Frage
- if( 1 )
- {
- char status = 0;
- if( rs->isRunning() )
- {
- status = 1;
- if( rs->istAn() )
- status = 2;
- }
- klient->sendeEncrypted( "\1", 1 );
- klient->sendeEncrypted( &status, 1 );
- }
- break;
- case 9: // Server pausieren
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- char pause = 0;
- klient->getNachrichtEncrypted( &pause, 1 );
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSPausieren ) )
- {
- bool ok = 0;
- if( pause )
- ok = rs->serverPause();
- else
- ok = rs->serverFortsetzen();
- if( ok )
- klient->sendeEncrypted( "\1", 1 );
- else
- {
- Text *err = new Text();
- err->append( rs->getLetzterFehler() );
- errorZuKlient( err->getText() );
- err->release();
- }
- }
- else
- {
- if( pause )
- errorZuKlient( "Du bist nicht berechtigt den Server zu pausieren." );
- else
- errorZuKlient( "Du bist nicht berechtigt den Server fortzusetzen." );
- }
- }
- break;
- case 0xA: // maximale Anzahl der Clients setzen
- if( !adminId )
- errorZuKlient( "Du musst dich einloggen." );
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- int maxC = 0;
- klient->getNachrichtEncrypted( (char*)&maxC, 4 );
- if( rs->zDB()->adminHatRecht( adminId, Admin_Recht::RSMCChange ) )
- {
- if( rs->setMaxKlients( maxC ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- {
- Text *err = new Text();
- err->append( rs->getLetzterFehler() );
- errorZuKlient( err->getText() );
- err->release();
- }
- }
- else
- errorZuKlient( "Du bist nicht berechtigt die maximale Anzahl der Clients zu verändern." );
- }
- break;
- case 0xC: // klient absturtz
- if( 1 )
- {
- klient->sendeEncrypted( "\1", 1 );
- int klientId = 0;
- klient->getNachrichtEncrypted( (char*)&klientId, 4 );
- if( klientId && rs->absturzKlient( klientId ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- klient->sendeEncrypted( "\0", 1 );
- }
- break;
- default:
- errorZuKlient( "Unbekannte Nachricht!" );
- break;
- }
- if( br )
- break;
- rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
- rs->addGesendet( klient->getUploadBytes( 1 ) );
- }
- }
- rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
- rs->addGesendet( klient->getUploadBytes( 1 ) );
- delete this;
- }
- void RSAKlient::errorZuKlient( const char *nachricht ) const // sendet eine Fehlernachricht zum Klient
- {
- klient->sendeEncrypted( "\3", 1 );
- char len = (char)textLength( nachricht );
- klient->sendeEncrypted( &len, 1 );
- klient->sendeEncrypted( nachricht, len );
- }
- // Inhalt der RSKlasse aus RegisterServer.h
- // Konstruktor
- RSKlient::RSKlient( SKlient *klient, RegisterServer *rs )
- : Thread()
- {
- this->klient = klient;
- unsigned char key[ 20 ] = { 186, 186, 179, 126, 216, 207, 123, 154, 168, 149, 51, 221, 6, 193, 160, 141, 164, 126, 44, 242 };
- klient->setSendeKey( (char*)key, 20 );
- klient->setEmpfangKey( (char*)key, 20 );
- klientNummer = 0;
- this->rs = rs;
- ref = 1;
- }
- // Destruktor
- RSKlient::~RSKlient()
- {
- klient->release();
- rs->release();
- }
- // nicht constant
- void RSKlient::absturz()
- {
- ende();
- klient->trenne();
- rs->zDB()->unregisterKlient( klientNummer, rs->getId() );
- }
- void RSKlient::thread()
- {
- while( 1 )
- {
- char c = 0;
- if( !klient->getNachrichtEncrypted( &c, 1 ) )
- break;
- else
- {
- bool br = 0;
- switch( c )
- {
- case 1: // Klient identifikation
- klient->getNachrichtEncrypted( (char*)&klientNummer, 4 );
- if( !rs->zDB()->proveKlient( klientNummer, rs->getId() ) )
- {
- klientNummer = 0;
- errorZuKlient( "Du bist nicht für diesen Server eingetragen" );
- }
- else
- {
- Text *key = rs->zDB()->getKlientKey( klientNummer );
- if( !key )
- errorZuKlient( "Es konnte kein Key ermittelt werden." );
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- klient->setEmpfangKey( *key, key->getLength() );
- klient->setSendeKey( *key, key->getLength() );
- key->release();
- }
- }
- break;
- case 2: // Main / Erhaltung Server message
- if( 1 )
- {
- char befehl = 0;
- klient->getNachrichtEncrypted( &befehl, 1 );
- switch( befehl )
- {
- case 2: // klient absturtz
- if( 1 )
- {
- int klientId = 0;
- klient->getNachrichtEncrypted( (char*)&klientId, 4 );
- if( klientId && rs->absturzKlient( klientId ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- klient->sendeEncrypted( "\0", 1 );
- }
- break;
- default:
- errorZuKlient( "Befehl nicht bekannt!" );
- break;
- }
- }
- break;
- case 3: // Verbindungsende
- br = 1;
- klient->sendeEncrypted( "\1", 1 );
- break;
- case 4: // unregister Klient
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- rs->zDB()->unregisterKlient( klientNummer, rs->getId() );
- klient->sendeEncrypted( "\1", 1 );
- break;
- case 5: // Account erstellen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 4 ] = { 0, 0, 0, 0 };
- klient->getNachrichtEncrypted( (char*)len, 4 );
- char *acc_name = new char[ len[ 0 ] + 1 ];
- acc_name[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( acc_name, len[ 0 ] );
- char *acc_pass = new char[ len[ 1 ] + 1 ];
- acc_pass[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( acc_pass, len[ 1 ] );
- char *acc_geheim = new char[ len[ 2 ] + 1 ];
- acc_geheim[ len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( acc_geheim, len[ 2 ] );
- char *acc_mail = new char[ len[ 3 ] + 1 ];
- acc_mail[ len[ 3 ] ] = 0;
- klient->getNachrichtEncrypted( acc_mail, len[ 3 ] );
- unsigned short acc_geb_jahr = 0;
- klient->getNachrichtEncrypted( (char*)&acc_geb_jahr, 2 );
- char acc_geb_monat = 0;
- klient->getNachrichtEncrypted( &acc_geb_monat, 1 );
- char acc_geb_tag = 0;
- klient->getNachrichtEncrypted( &acc_geb_tag, 1 );
- int pres = rs->zDB()->proveNeuAccount( acc_name, acc_mail );
- if( !pres )
- {
- Text *gebDatum = new Text( "" );
- gebDatum->append( (int)acc_geb_jahr );
- gebDatum->append( "-" );
- gebDatum->append( (int)acc_geb_monat );
- gebDatum->append( "-" );
- gebDatum->append( (int)acc_geb_tag );
- if( !rs->zDB()->neuAccount( acc_name, acc_pass, acc_geheim, acc_mail, gebDatum->getText(), rs->zIni() ) )
- {
- Text *err = new Text( "Das Datum '" );
- err->append( gebDatum->getText() );
- err->append( "' ist kein gültiges Datum." );
- errorZuKlient( err->getText() );
- err->release();
- }
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- while( 1 )
- {
- char len = 0;
- klient->getNachrichtEncrypted( &len, 1 );
- if( !len ) // abbruch
- {
- rs->zDB()->neuAccountAbbruch( acc_name );
- break;
- }
- if( len == -1 )
- break;
- char *key = new char[ len + 1 ];
- key[ (int)len ] = 0;
- klient->getNachrichtEncrypted( key, len );
- if( rs->zDB()->aktiviereAccount( acc_name, key ) )
- {
- klient->sendeEncrypted( "\1", 1 );
- delete[]key;
- break;
- }
- else
- klient->sendeEncrypted( "\0", 1 );
- delete[]key;
- }
- }
- gebDatum->release();
- }
- else
- {
- if( pres == 1 )
- errorZuKlient( "Der Name wird bereits verwendet." );
- else if( pres == 2 )
- errorZuKlient( "Die E-Mail Adresse wird bereits verwendet." );
- }
- delete[]acc_name;
- delete[]acc_pass;
- delete[]acc_geheim;
- delete[]acc_mail;
- }
- break;
- case 6: // Account removen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- char len[ 3 ];
- klient->getNachrichtEncrypted( len, 3 );
- char *acc_name = new char[ len[ 0 ] + 1 ];
- acc_name[ (int)len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( acc_name, len[ 0 ] );
- char *acc_pass = new char[ len[ 1 ] + 1 ];
- acc_pass[ (int)len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( acc_pass, len[ 1 ] );
- char *acc_geheim = new char[ len[ 2 ] + 1 ];
- acc_geheim[ (int)len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( acc_geheim, len[ 2 ] );
- int res = rs->zDB()->removeAccount( acc_name, acc_pass, acc_geheim, rs->zIni() );
- if( !res )
- {
- klient->sendeEncrypted( "\1", 1 );
- while( 1 )
- {
- char len = 0;
- klient->getNachrichtEncrypted( &len, 1 );
- if( !len )
- {
- rs->zDB()->removeAccountAbbruch( acc_name );
- break;
- }
- if( len == -1 )
- break;
- char *key = new char[ len + 1 ];
- key[ (int)len ] = 0;
- klient->getNachrichtEncrypted( key, len );
- if( rs->zDB()->removeConfirmation( acc_name, key ) )
- {
- klient->sendeEncrypted( "\1", 1 );
- delete[]key;
- break;
- }
- else
- klient->sendeEncrypted( "\0", 1 );
- delete[]key;
- }
- }
- else if( res == 1 )
- errorZuKlient( "Der Account wurde nicht gefunden." );
- else if( res == 2 )
- errorZuKlient( "Falsches Passwort." );
- else if( res == 3 )
- errorZuKlient( "Falsches Geheimnis." );
- delete[]acc_name;
- delete[]acc_pass;
- delete[]acc_geheim;
- }
- break;
- case 7: // Passwort ändern
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 4 ];
- klient->getNachrichtEncrypted( (char*)len, 4 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- char *neuPasswort = new char[ len[ 2 ] + 1 ];
- neuPasswort[ len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( neuPasswort, len[ 2 ] );
- char *accGeheimnis = new char[ len[ 3 ] + 1 ];
- accGeheimnis[ len[ 3 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 3 ] );
- int res = rs->zDB()->passwortChange( accName, accPasswort, neuPasswort, accGeheimnis );
- if( !res )
- klient->sendeEncrypted( "\1", 1 );
- else if( res == 1 )
- errorZuKlient( "Account nicht gefunden." );
- else if( res == 2 )
- errorZuKlient( "Falsches Passwort." );
- else if( res == 3 )
- errorZuKlient( "Falsches Geheimnis." );
- delete[]accName;
- delete[]accPasswort;
- delete[]neuPasswort;
- delete[]accGeheimnis;
- }
- break;
- case 8: // E-Mail ändern
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 4 ];
- klient->getNachrichtEncrypted( (char*)len, 4 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- char *accGeheimnis = new char[ len[ 2 ] + 1 ];
- accGeheimnis[ len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
- char *neuEMail = new char[ len[ 3 ] + 1 ];
- neuEMail[ len[ 3 ] ] = 0;
- klient->getNachrichtEncrypted( neuEMail, len[ 3 ] );
- int res = rs->zDB()->eMailChange( accName, accPasswort, accGeheimnis, neuEMail );
- if( !res )
- klient->sendeEncrypted( "\1", 1 );
- else if( res == 1 )
- errorZuKlient( "Account nicht gefunden." );
- else if( res == 2 )
- errorZuKlient( "Falsches Passwort." );
- else if( res == 3 )
- errorZuKlient( "Falsches Geheimnis." );
- else if( res == 4 )
- errorZuKlient( "Diese E-Mail Addresse wird bereits verwendet." );
- delete[]accName;
- delete[]accPasswort;
- delete[]accGeheimnis;
- delete[]neuEMail;
- }
- break;
- case 9: // Geheimnis Ändern
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 4 ];
- klient->getNachrichtEncrypted( (char*)len, 4 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- char *accGeheimnis = new char[ len[ 2 ] + 1 ];
- accGeheimnis[ len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
- char *neuGeheimnis = new char[ len[ 3 ] + 1 ];
- neuGeheimnis[ len[ 3 ] ] = 0;
- klient->getNachrichtEncrypted( neuGeheimnis, len[ 3 ] );
- int res = rs->zDB()->geheimnisChange( accName, accPasswort, accGeheimnis, neuGeheimnis );
- if( !res )
- klient->sendeEncrypted( "\1", 1 );
- else if( res == 1 )
- errorZuKlient( "Account nicht gefunden." );
- else if( res == 2 )
- errorZuKlient( "Falsches Passwort." );
- else if( res == 3 )
- errorZuKlient( "Falsches Geheimnis." );
- delete[]accName;
- delete[]accPasswort;
- delete[]accGeheimnis;
- delete[]neuGeheimnis;
- }
- break;
- case 0xA: // Name Vergessen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 2 ];
- klient->getNachrichtEncrypted( (char*)len, 2 );
- char *accPasswort = new char[ len[ 0 ] + 1 ];
- accPasswort[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 0 ] );
- char *accGeheimnis = new char[ len[ 1 ] + 1 ];
- accGeheimnis[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
- if( rs->zDB()->nameVergessen( accPasswort, accGeheimnis, rs->zIni() ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- errorZuKlient( "Account nicht gefunden." );
- delete[]accPasswort;
- delete[]accGeheimnis;
- }
- break;
- case 0xB: // Passwort Vergessen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 2 ];
- klient->getNachrichtEncrypted( (char*)len, 2 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accGeheimnis = new char[ len[ 1 ] + 1 ];
- accGeheimnis[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 1 ] );
- if( rs->zDB()->passwortVergessen( accName, accGeheimnis, rs->zIni() ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- errorZuKlient( "Account nicht gefunden." );
- delete[]accName;
- delete[]accGeheimnis;
- }
- break;
- case 0xC: // Geheimnis Vergessen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 2 ];
- klient->getNachrichtEncrypted( (char*)len, 2 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- if( rs->zDB()->geheimnisVergessen( accName, accPasswort, rs->zIni() ) )
- klient->sendeEncrypted( "\1", 1 );
- else
- errorZuKlient( "Account nicht gefunden." );
- delete[]accName;
- delete[]accPasswort;
- }
- break;
- case 0xD: // E-Mail Vergessen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 3 ];
- klient->getNachrichtEncrypted( (char*)len, 3 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- char *accGeheimnis = new char[ len[ 2 ] + 1 ];
- accGeheimnis[ len[ 2 ] ] = 0;
- klient->getNachrichtEncrypted( accGeheimnis, len[ 2 ] );
- Text *eMail = rs->zDB()->eMailVergessen( accName, accPasswort, accGeheimnis );
- if( eMail )
- {
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len = (unsigned char)eMail->getLength();
- klient->sendeEncrypted( (char*)&len, 1 );
- klient->sendeEncrypted( eMail->getText(), len );
- eMail->release();
- }
- else
- errorZuKlient( "Account nicht gefunden." );
- delete[]accName;
- delete[]accPasswort;
- delete[]accGeheimnis;
- }
- break;
- case 0xE: // Account bestätigen
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- unsigned char len[ 2 ];
- klient->getNachrichtEncrypted( (char*)len, 2 );
- char *accName = new char[ len[ 0 ] + 1 ];
- accName[ len[ 0 ] ] = 0;
- klient->getNachrichtEncrypted( accName, len[ 0 ] );
- char *accPasswort = new char[ len[ 1 ] + 1 ];
- accPasswort[ len[ 1 ] ] = 0;
- klient->getNachrichtEncrypted( accPasswort, len[ 1 ] );
- char byte = rs->zDB()->suchConfirmation( accName, accPasswort );
- if( !byte )
- errorZuKlient( "Bei diesem Account ist keine Bestätigung notwendig." );
- else if( byte == -1 )
- errorZuKlient( "Falsche Kombination von Name und Passwort." );
- else if( byte > 0 )
- {
- klient->sendeEncrypted( &byte, 1 );
- char befehl = 0;
- while( 1 )
- {
- klient->getNachrichtEncrypted( &befehl, 1 );
- if( !befehl )
- {
- if( byte == 1 )
- rs->zDB()->neuAccountAbbruch( accName );
- if( byte == 2 )
- rs->zDB()->removeAccountAbbruch( accName );
- break;
- }
- if( befehl == -1 )
- break;
- if( befehl == -2 )
- {
- if( byte == 1 )
- rs->zDB()->sendeErstellEMail( accName, rs->zIni() );
- if( byte == 2 )
- rs->zDB()->sendeRemoveEMail( accName, rs->zIni() );
- }
- if( befehl > 0 )
- {
- char *key = new char[ befehl + 1 ];
- key[ (int)befehl ] = 0;
- klient->getNachrichtEncrypted( key, befehl );
- if( byte == 1 )
- {
- if( !rs->zDB()->aktiviereAccount( accName, key ) )
- klient->sendeEncrypted( "\0", 1 );
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- delete[]key;
- break;
- }
- }
- if( byte == 2 )
- {
- if( !rs->zDB()->removeConfirmation( accName, key ) )
- klient->sendeEncrypted( "\0", 1 );
- else
- {
- klient->sendeEncrypted( "\1", 1 );
- delete[]key;
- break;
- }
- }
- delete[]key;
- }
- }
- }
- delete[]accName;
- delete[]accPasswort;
- }
- break;
- case 0xF: // ping
- if( 1 )
- {
- if( !klientNummer )
- {
- errorZuKlient( "Du bist nicht Identifiziert." );
- break;
- }
- klient->sendeEncrypted( "\1", 1 );
- }
- break;
- default:
- errorZuKlient( "Unbekannte Nachricht!" );
- break;
- }
- if( br )
- break;
- }
- rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
- rs->addGesendet( klient->getUploadBytes( 1 ) );
- }
- rs->addEmpfangen( klient->getDownloadBytes( 1 ) );
- rs->addGesendet( klient->getUploadBytes( 1 ) );
- rs->removeKlient( this ); // delete this
- }
- // constant
- void RSKlient::errorZuKlient( const char *nachricht ) const // sendet eine Fehlernachricht zum Klient
- {
- klient->sendeEncrypted( "\3", 1 );
- char len = (char)textLength( nachricht );
- klient->sendeEncrypted( &len, 1 );
- klient->sendeEncrypted( nachricht, len );
- }
- int RSKlient::getKlientNummer() const // gibt die KlientId zurück
- {
- return klientNummer;
- }
- // Reference Counting
- RSKlient *RSKlient::getThis()
- {
- ref++;
- return this;
- }
- RSKlient *RSKlient::release()
- {
- ref--;
- if( !ref )
- delete this;
- return 0;
- }
|