NewsK.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. #include "../KSGKlient.h"
  2. #include "../KSGServer.h"
  3. #include <Datei.h>
  4. #include "../Keys.h"
  5. // Inhalt der NewsKlients Klasse aus KSGKlient.h
  6. // Konstruktor
  7. NewsKlient::NewsKlient()
  8. {
  9. verbunden = 0;
  10. klient = 0;
  11. fehler = new Text( "" );
  12. klientId = getKlientId();
  13. ref = 1;
  14. }
  15. // Destruktor
  16. NewsKlient::~NewsKlient()
  17. {
  18. cs.lock();
  19. if( klient )
  20. {
  21. char serverReturn = 0;
  22. if( verbunden )
  23. {
  24. klient->sendeEncrypted( "\4", 1 );
  25. klient->getNachrichtEncrypted( &serverReturn, 1 );
  26. if( serverReturn == 3 )
  27. {
  28. char län = 0;
  29. klient->getNachrichtEncrypted( &län, 1 );
  30. char *nachricht = new char[ län + 1 ];
  31. nachricht[ län ] = 0;
  32. klient->getNachrichtEncrypted( nachricht, län );
  33. delete[]nachricht;
  34. }
  35. klient->sendeEncrypted( "\3", 1 );
  36. klient->getNachrichtEncrypted( &serverReturn, 1 );
  37. klient->trenne();
  38. }
  39. else
  40. {
  41. int keyLen = 0;
  42. char *key = 0;
  43. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::SENDEN );
  44. klient->setSendeKey( key, keyLen );
  45. delete[] key;
  46. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::EMPFANGEN );
  47. klient->setEmpfangKey( key, keyLen );
  48. delete[] key;
  49. klient->verbinde( klient->getServerPort(), klient->getServerIp() );
  50. klient->sendeEncrypted( "\1", 1 );
  51. klient->sendeEncrypted( (char*)&klientId, 4 );
  52. klient->getNachrichtEncrypted( &serverReturn, 1 );
  53. if( serverReturn == 3 )
  54. {
  55. char län = 0;
  56. klient->getNachrichtEncrypted( &län, 1 );
  57. char *nachricht = new char[ län + 1 ];
  58. nachricht[ län ] = 0;
  59. klient->getNachrichtEncrypted( nachricht, län );
  60. delete[]nachricht;
  61. }
  62. else
  63. {
  64. char *sl = 0;
  65. char slLän = getSchlüssel( &sl );
  66. klient->setSendeKey( sl, slLän );
  67. klient->setEmpfangKey( sl, slLän );
  68. delete[] sl;
  69. klient->sendeEncrypted( "\4", 1 );
  70. klient->getNachrichtEncrypted( &serverReturn, 1 );
  71. if( serverReturn == 3 )
  72. {
  73. char län = 0;
  74. klient->getNachrichtEncrypted( &län, 1 );
  75. char *nachricht = new char[ län + 1 ];
  76. nachricht[ län ] = 0;
  77. klient->getNachrichtEncrypted( nachricht, län );
  78. delete[]nachricht;
  79. }
  80. }
  81. klient->sendeEncrypted( "\3", 1 );
  82. klient->getNachrichtEncrypted( &serverReturn, 1 );
  83. klient->trenne();
  84. }
  85. klient = klient->release();
  86. }
  87. fehler = fehler->release();
  88. cs.unlock();
  89. }
  90. // nicht constant
  91. bool NewsKlient::verbinde() // verbindet ich mit dem News Server
  92. {
  93. cs.lock();
  94. if( verbunden )
  95. {
  96. cs.unlock();
  97. return 1;
  98. }
  99. if( !klient )
  100. {
  101. char *msIp = getMainServerIp();
  102. unsigned short msPort = getMainServerPort();
  103. klient = new Klient();
  104. int keyLen = 0;
  105. char *key = 0;
  106. Keys::getServerKey( &key, keyLen, Keys::MAIN, Keys::SENDEN );
  107. klient->setSendeKey( key, keyLen );
  108. delete[] key;
  109. Keys::getServerKey( &key, keyLen, Keys::MAIN, Keys::EMPFANGEN );
  110. klient->setEmpfangKey( key, keyLen );
  111. delete[] key;
  112. if( !klient->verbinde( msPort, msIp ) )
  113. {
  114. fehler->setText( "Fehler beim verbinden mit dem Main Server. Bitte versuche es Später erneut." );
  115. klient = klient->release();
  116. delete[]msIp;
  117. cs.unlock();
  118. return 0;
  119. }
  120. delete[]msIp;
  121. klient->sende( "\0", 1 ); // Verschlüsselung aktivieren
  122. klient->sendeEncrypted( "\1", 1 );
  123. klient->sendeEncrypted( (char*)&klientId, 4 );
  124. char serverReturn = 0;
  125. klient->getNachrichtEncrypted( &serverReturn, 1 );
  126. if( serverReturn == 3 )
  127. {
  128. char län = 0;
  129. klient->getNachrichtEncrypted( &län, 1 );
  130. char *nachricht = new char[ län + 1 ];
  131. nachricht[ län ] = 0;
  132. klient->getNachrichtEncrypted( nachricht, län );
  133. fehler->setText( nachricht );
  134. delete[]nachricht;
  135. klient->sendeEncrypted( "\3", 1 );
  136. klient->getNachrichtEncrypted( &serverReturn, 1 );
  137. klient->trenne();
  138. klient = klient->release();
  139. cs.unlock();
  140. return 0;
  141. }
  142. char *sl = 0;
  143. char slLän = getSchlüssel( &sl );
  144. klient->setSendeKey( sl, slLän );
  145. klient->setEmpfangKey( sl, slLän );
  146. delete[] sl;
  147. klient->sendeEncrypted( "\6\x9", 2 );
  148. char byte = 0;
  149. klient->getNachrichtEncrypted( &byte, 1 );
  150. if( byte == 2 )
  151. {
  152. unsigned char lsIp[ 4 ];
  153. klient->getNachrichtEncrypted( (char *)lsIp, 4 );
  154. unsigned short lsPort = 0;
  155. klient->getNachrichtEncrypted( (char*)&lsPort, 2 );
  156. klient->sendeEncrypted( "\3", 1 );
  157. klient->getNachrichtEncrypted( &serverReturn, 1 );
  158. klient->trenne();
  159. Text *lsIpT = new Text( "" );
  160. lsIpT->append( (int)lsIp[ 0 ] );
  161. lsIpT->append( "." );
  162. lsIpT->append( (int)lsIp[ 1 ] );
  163. lsIpT->append( "." );
  164. lsIpT->append( (int)lsIp[ 2 ] );
  165. lsIpT->append( "." );
  166. lsIpT->append( (int)lsIp[ 3 ] );
  167. int keyLen = 0;
  168. char *key = 0;
  169. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::SENDEN );
  170. klient->setSendeKey( key, keyLen );
  171. delete[] key;
  172. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::EMPFANGEN );
  173. klient->setEmpfangKey( key, keyLen );
  174. delete[] key;
  175. klient->verbinde( lsPort, lsIpT->getText() );
  176. lsIpT = lsIpT->release();
  177. klient->sendeEncrypted( "\3", 1 );
  178. klient->getNachrichtEncrypted( &serverReturn, 1 );
  179. klient->trenne();
  180. }
  181. if( byte == 3 )
  182. {
  183. klient->getNachrichtEncrypted( &byte, 1 );
  184. char *f = new char[ byte + 1 ];
  185. f[ byte ] = 0;
  186. klient->getNachrichtEncrypted( f, byte );
  187. fehler->setText( f );
  188. delete[]f;
  189. klient->sendeEncrypted( "\3", 1 );
  190. klient->getNachrichtEncrypted( &serverReturn, 1 );
  191. klient->trenne();
  192. klient = klient->release();
  193. cs.unlock();
  194. return 0;
  195. }
  196. }
  197. int keyLen = 0;
  198. char *key = 0;
  199. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::SENDEN );
  200. klient->setSendeKey( key, keyLen );
  201. delete[] key;
  202. Keys::getServerKey( &key, keyLen, Keys::NEWS, Keys::EMPFANGEN );
  203. klient->setEmpfangKey( key, keyLen );
  204. delete[] key;
  205. if( klient->verbinde( klient->getServerPort(), klient->getServerIp() ) )
  206. {
  207. if( klient->sendeEncrypted( "\1", 1 ) )
  208. {
  209. klient->sendeEncrypted( (char*)&klientId, 4 );
  210. char serverReturn = 0;
  211. klient->getNachrichtEncrypted( &serverReturn, 1 );
  212. if( serverReturn == 3 )
  213. {
  214. char byte = 0;
  215. klient->getNachrichtEncrypted( &byte, 1 );
  216. char *f = new char[ byte + 1 ];
  217. f[ byte ] = 0;
  218. klient->getNachrichtEncrypted( f, byte );
  219. fehler->setText( f );
  220. delete[]f;
  221. klient->sendeEncrypted( "\3", 1 );
  222. klient->getNachrichtEncrypted( &serverReturn, 1 );
  223. klient->trenne();
  224. cs.unlock();
  225. return 0;
  226. }
  227. char *sl = 0;
  228. char slLän = getSchlüssel( &sl );
  229. klient->setSendeKey( sl, slLän );
  230. klient->setEmpfangKey( sl, slLän );
  231. delete[] sl;
  232. verbunden = 1;
  233. cs.unlock();
  234. return 1;
  235. }
  236. else
  237. {
  238. fehler->setText( "Der dir zugewiesene News Server hat die Verbindung abgebrochen. Bitte versuche es Später erneut." );
  239. klient = klient->release();
  240. }
  241. }
  242. else
  243. {
  244. fehler->setText( "Der dir zugewiesene News Server antwortet nicht. Bitte versuche es Später erneut." );
  245. klient = klient->release();
  246. }
  247. cs.unlock();
  248. return 0;
  249. }
  250. bool NewsKlient::ladeSeite( char *name )
  251. {
  252. cs.lock();
  253. if( !verbunden )
  254. verbinde();
  255. if( !verbunden )
  256. {
  257. cs.unlock();
  258. return 0;
  259. }
  260. klient->sendeEncrypted( "\5", 1 );
  261. char ret = 0;
  262. klient->getNachrichtEncrypted( &ret, 1 );
  263. if( ret == 1 )
  264. {
  265. char län = (char)textLength( name );
  266. klient->sendeEncrypted( &län, 1 );
  267. klient->sendeEncrypted( name, län );
  268. klient->getNachrichtEncrypted( &ret, 1 );
  269. if( ret == 1 )
  270. {
  271. Text *pfad = new Text( "data/tmp/news/" );
  272. pfad->append( name );
  273. if( DateiExistiert( pfad->getThis() ) )
  274. DateiRemove( pfad->getThis() );
  275. pfad->append( "/" );
  276. int dAnz = 0;
  277. klient->getNachrichtEncrypted( (char*)&dAnz, 4 );
  278. for( int i = 0; i < dAnz; i++ )
  279. {
  280. char nLän = 0;
  281. klient->getNachrichtEncrypted( &nLän, 1 );
  282. char *dName = new char[ nLän + 1 ];
  283. dName[ nLän ] = 0;
  284. klient->getNachrichtEncrypted( dName, nLän );
  285. Text *pf = new Text( pfad->getText() );
  286. pf->append( dName );
  287. delete[] dName;
  288. Datei *d = new Datei();
  289. d->setDatei( pf );
  290. d->erstellen();
  291. d->open( Datei::Style::schreiben );
  292. __int64 dGr = 0;
  293. klient->getNachrichtEncrypted( (char*)&dGr, 8 );
  294. char buffer[ 2048 ];
  295. while( dGr > 0 )
  296. {
  297. int län = dGr > 2048 ? 2048 : (int)dGr;
  298. klient->getNachricht( buffer, län );
  299. d->schreibe( buffer, län );
  300. dGr -= län;
  301. }
  302. d->close();
  303. d->release();
  304. }
  305. pfad->release();
  306. }
  307. }
  308. if( ret == 3 )
  309. {
  310. klient->getNachrichtEncrypted( &ret, 1 );
  311. if( ret )
  312. {
  313. char *tmp = new char[ ret ];
  314. klient->getNachrichtEncrypted( tmp, ret );
  315. delete[] tmp;
  316. }
  317. cs.unlock();
  318. return 0;
  319. }
  320. cs.unlock();
  321. return 1;
  322. }
  323. bool NewsKlient::keepAlive() // Erhält die Verbindung aufrecht
  324. {
  325. if( !verbunden )
  326. return 0;
  327. char res = 0;
  328. if( !cs.tryLock() )
  329. return 1;
  330. klient->sendeEncrypted( "\x6", 1 );
  331. klient->getNachrichtEncrypted( &res, 1 );
  332. cs.unlock();
  333. if( res != 1 )
  334. trenne();
  335. return res == 1;
  336. }
  337. bool NewsKlient::trenne() // trennt sich von dem News Server
  338. {
  339. if( !verbunden )
  340. return 1;
  341. cs.lock();
  342. klient->sendeEncrypted( "\3", 1 );
  343. char serverReturn = 0;
  344. klient->getNachrichtEncrypted( &serverReturn, 1 );
  345. klient->trenne();
  346. verbunden = 0;
  347. cs.unlock();
  348. return 1;
  349. }
  350. // constant
  351. bool NewsKlient::istVerbunden() const // prüft, ob mit News Server verbunden
  352. {
  353. return verbunden;
  354. }
  355. char *NewsKlient::getLetzterFehler() const // gibt den Letzten Fehlertext zuück
  356. {
  357. return fehler->getText();
  358. }
  359. // Reference Counting
  360. NewsKlient *NewsKlient::getThis()
  361. {
  362. ref++;
  363. return this;
  364. }
  365. NewsKlient *NewsKlient::release()
  366. {
  367. ref--;
  368. if( !ref )
  369. delete this;
  370. return 0;
  371. }