summaryrefslogtreecommitdiffabout
path: root/libkdepim
authorzautrix <zautrix>2005-02-24 02:01:08 (UTC)
committer zautrix <zautrix>2005-02-24 02:01:08 (UTC)
commit5af16f69232073d1fa46d2dea3774beaaafb00c5 (patch) (unidiff)
tree0790afdd906df50520ac4415a9d35b95107d4d48 /libkdepim
parent513496c67403deb04339cfc87143ed5554720e32 (diff)
downloadkdepimpi-5af16f69232073d1fa46d2dea3774beaaafb00c5.zip
kdepimpi-5af16f69232073d1fa46d2dea3774beaaafb00c5.tar.gz
kdepimpi-5af16f69232073d1fa46d2dea3774beaaafb00c5.tar.bz2
socket fixes
Diffstat (limited to 'libkdepim') (more/less context) (ignore whitespace changes)
-rw-r--r--libkdepim/ksyncmanager.cpp94
-rw-r--r--libkdepim/ksyncmanager.h7
2 files changed, 74 insertions, 27 deletions
diff --git a/libkdepim/ksyncmanager.cpp b/libkdepim/ksyncmanager.cpp
index d8ca3ba..47d00a4 100644
--- a/libkdepim/ksyncmanager.cpp
+++ b/libkdepim/ksyncmanager.cpp
@@ -1072,7 +1072,17 @@ void KSyncManager::deleteCommandSocket(KCommandSocket*s, int state)
1072 //enum { success, errorW, errorR, quiet }; 1072 //enum { success, errorW, errorR, quiet };
1073 if ( state == KCommandSocket::errorR ||state == KCommandSocket::errorTO ||state == KCommandSocket::errorPW ) { 1073
1074
1075
1076 if ( state == KCommandSocket::errorR ||state == KCommandSocket::errorTO ||state == KCommandSocket::errorPW ||
1077 state == KCommandSocket::errorCA ||state == KCommandSocket::errorFI ||state == KCommandSocket::errorUN ) {
1074 if ( state == KCommandSocket::errorPW ) 1078 if ( state == KCommandSocket::errorPW )
1075 mParent->topLevelWidget()->setCaption( i18n("Wrong password: Receiving remote file failed.") ); 1079 mParent->topLevelWidget()->setCaption( i18n("Wrong password: Receiving remote file failed.") );
1076 else 1080 else if ( state == KCommandSocket::errorR ||state == KCommandSocket::errorTO )
1077 mParent->topLevelWidget()->setCaption( i18n("ERROR: Receiving remote file failed.") ); 1081 mParent->topLevelWidget()->setCaption( i18n("ERROR: Receiving remote file failed.") );
1082 else if ( state == KCommandSocket::errorCA )
1083 mParent->topLevelWidget()->setCaption( i18n("Sync cancelled from remote.") );
1084 else if ( state == KCommandSocket::errorFI )
1085 mParent->topLevelWidget()->setCaption( i18n("File error on remote.") );
1086 else if ( state == KCommandSocket::errorUN )
1087 mParent->topLevelWidget()->setCaption( i18n("Unknown error on remote.") );
1078 delete s; 1088 delete s;
@@ -1134,2 +1144,3 @@ KServerSocket:: KServerSocket ( QString pw, Q_UINT16 port, int backlog, QObject
1134 blockRC = false; 1144 blockRC = false;
1145 mErrorMessage = 0;
1135} 1146}
@@ -1152,3 +1163,7 @@ void KServerSocket::discardClient()
1152{ 1163{
1153 //qDebug(" KServerSocket::discardClient()"); 1164 QTimer::singleShot( 10, this , SLOT ( deleteSocket()));
1165}
1166void KServerSocket::deleteSocket()
1167{
1168 qDebug("KSS::deleteSocket");
1154 if ( mSocket ) { 1169 if ( mSocket ) {
@@ -1157,3 +1172,4 @@ void KServerSocket::discardClient()
1157 } 1172 }
1158 //emit endConnect(); 1173 if ( mErrorMessage )
1174 QTimer::singleShot( 10, this , SLOT ( displayErrorMessage()));
1159} 1175}
@@ -1167,2 +1183,8 @@ void KServerSocket::readClient()
1167 } 1183 }
1184 if ( mErrorMessage ) {
1185 mErrorMessage = 999;
1186 error_connect("ERROR_UN\r\n\r\n");
1187 return;
1188 }
1189 mErrorMessage = 0;
1168 //qDebug("KServerSocket::readClient()"); 1190 //qDebug("KServerSocket::readClient()");
@@ -1185,5 +1207,4 @@ void KServerSocket::readClient()
1185 else { 1207 else {
1186 error_connect(); 1208 mErrorMessage = 1;
1187 KMessageBox::error( 0, i18n("Got send file request\nwith invalid password")); 1209 error_connect("ERROR_PW\r\n\r\n");
1188 //qDebug("password %s, invalid password %s ",mPassWord.latin1(), tokens[1].latin1() );
1189 } 1210 }
@@ -1197,6 +1218,5 @@ void KServerSocket::readClient()
1197 else { 1218 else {
1198 error_connect(); 1219 mErrorMessage = 2;
1220 error_connect("ERROR_PW\r\n\r\n");
1199 end_connect(); 1221 end_connect();
1200 KMessageBox::error( 0, i18n("Got receive file request\nwith invalid password"));
1201 //qDebug("password %s, invalid password %s ",mPassWord.latin1(), tokens[1].latin1() );
1202 } 1222 }
@@ -1209,3 +1229,11 @@ void KServerSocket::readClient()
1209} 1229}
1210void KServerSocket::error_connect() 1230void KServerSocket::displayErrorMessage()
1231{
1232 if ( mErrorMessage == 1 )
1233 KMessageBox::error( 0, i18n("Got send file request\nwith invalid password"));
1234 else if ( mErrorMessage == 2 )
1235 KMessageBox::error( 0, i18n("Got receive file request\nwith invalid password"));
1236 mErrorMessage = 0;
1237}
1238void KServerSocket::error_connect( QString errmess )
1211{ 1239{
@@ -1213,6 +1241,7 @@ void KServerSocket::error_connect()
1213 os.setEncoding( QTextStream::Latin1 ); 1241 os.setEncoding( QTextStream::Latin1 );
1214 os << "ERROR_PW\r\n\r\n"; 1242 os << errmess ;
1215 mSocket->close(); 1243 mSocket->close();
1216 if ( mSocket->state() == QSocket::Idle ) 1244 if ( mSocket->state() == QSocket::Idle ) {
1217 QTimer::singleShot( 10, this , SLOT ( discardClient())); 1245 QTimer::singleShot( 0, this , SLOT ( discardClient()));
1246 }
1218} 1247}
@@ -1238,2 +1267,3 @@ void KServerSocket::send_file()
1238 int secs = QDateTime::currentDateTime().secsTo( KSyncManager::mRequestedSyncEvent ); 1267 int secs = QDateTime::currentDateTime().secsTo( KSyncManager::mRequestedSyncEvent );
1268 secs = 333;
1239 if ( secs < 0 ) 1269 if ( secs < 0 )
@@ -1251,3 +1281,6 @@ void KServerSocket::send_file()
1251 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(0, i18n("The clocks of the syncing\ndevices have a difference\nof more than 5 minutes.\nPlease adjust your clocks.\nYou may get wrong syncing results!\nPlease confirm synchronization!"), i18n("High clock skew!"),i18n("Synchronize!"))) { 1281 if ( KMessageBox::Cancel == KMessageBox::warningContinueCancel(0, i18n("The clocks of the syncing\ndevices have a difference\nof more than 5 minutes.\nPlease adjust your clocks.\nYou may get wrong syncing results!\nPlease confirm synchronization!"), i18n("High clock skew!"),i18n("Synchronize!"))) {
1252 qDebug("KSS::Sync cancelled ,cs"); 1282 qDebug("KSS::Sync cancelled ,cs");
1283 mErrorMessage = 0;
1284 end_connect();
1285 error_connect("ERROR_CA\r\n\r\n");
1253 return ; 1286 return ;
@@ -1280,10 +1313,6 @@ void KServerSocket::send_file()
1280 if (!file.open( IO_ReadOnly ) ) { 1313 if (!file.open( IO_ReadOnly ) ) {
1281 delete mSyncActionDialog; 1314 mErrorMessage = 0;
1282 mSyncActionDialog = 0; 1315 end_connect();
1283 qDebug("KSS::error open sync file: %s ", fileName.latin1()); 1316 error_connect("ERROR_FI\r\n\r\n");
1284 mSocket->close(); 1317 return ;
1285 if ( mSocket->state() == QSocket::Idle )
1286 QTimer::singleShot( 10, this , SLOT ( discardClient()));
1287 return ;
1288
1289 } 1318 }
@@ -1478,4 +1507,19 @@ void KCommandSocket::readFileFromSocket()
1478 mFirstLine = false; 1507 mFirstLine = false;
1479 if ( line.left( 8 ) == "ERROR_PW" ) { 1508 if ( line.left( 6 ) == "ERROR_" ) {
1480 mRetVal = errorPW; 1509 if ( line.left( 8 ) == "ERROR_PW" ) {
1510 mRetVal = errorPW;
1511 deleteSocket();
1512 return ;
1513 }
1514 if ( line.left( 8 ) == "ERROR_CA" ) {
1515 mRetVal = errorCA;
1516 deleteSocket();
1517 return ;
1518 }
1519 if ( line.left( 8 ) == "ERROR_FI" ) {
1520 mRetVal = errorFI;
1521 deleteSocket();
1522 return ;
1523 }
1524 mRetVal = errorUN;
1481 deleteSocket(); 1525 deleteSocket();
diff --git a/libkdepim/ksyncmanager.h b/libkdepim/ksyncmanager.h
index 810a515..bd3ecdc 100644
--- a/libkdepim/ksyncmanager.h
+++ b/libkdepim/ksyncmanager.h
@@ -57,5 +57,8 @@ class KServerSocket : public QServerSocket
57 void discardClient(); 57 void discardClient();
58 void deleteSocket();
58 void readClient(); 59 void readClient();
60 void displayErrorMessage();
59 void readBackFileFromSocket(); 61 void readBackFileFromSocket();
60 private : 62 private :
63 int mErrorMessage;
61 bool blockRC; 64 bool blockRC;
@@ -64,3 +67,3 @@ class KServerSocket : public QServerSocket
64 void end_connect(); 67 void end_connect();
65 void error_connect(); 68 void error_connect( QString );
66 QDialog* mSyncActionDialog; 69 QDialog* mSyncActionDialog;
@@ -77,3 +80,3 @@ class KCommandSocket : public QObject
77 public: 80 public:
78 enum state { successR, errorR, successW, errorW, errorTO, errorPW,quiet }; 81 enum state { successR, errorR, successW, errorW, errorTO, errorPW, errorCA, errorFI, errorUN,quiet };
79 KCommandSocket ( QString password, Q_UINT16 port, QString host, QObject * parent=0, QWidget* cap = 0, const char * name=0 ); 82 KCommandSocket ( QString password, Q_UINT16 port, QString host, QObject * parent=0, QWidget* cap = 0, const char * name=0 );