author | zautrix <zautrix> | 2004-10-04 10:05:42 (UTC) |
---|---|---|
committer | zautrix <zautrix> | 2004-10-04 10:05:42 (UTC) |
commit | 743f44c45534a6e1df17ddc7b5f3c62b73921455 (patch) (unidiff) | |
tree | 83795806d28b2614639082e944558a470f039daf | |
parent | aaea91151fe9a747e9eddfb8ba7d5896744faf30 (diff) | |
download | kdepimpi-743f44c45534a6e1df17ddc7b5f3c62b73921455.zip kdepimpi-743f44c45534a6e1df17ddc7b5f3c62b73921455.tar.gz kdepimpi-743f44c45534a6e1df17ddc7b5f3c62b73921455.tar.bz2 |
sync fixes
-rw-r--r-- | korganizer/mainwindow.cpp | 181 | ||||
-rw-r--r-- | korganizer/mainwindow.h | 14 |
2 files changed, 124 insertions, 71 deletions
diff --git a/korganizer/mainwindow.cpp b/korganizer/mainwindow.cpp index 7bf33d3..8e2f956 100644 --- a/korganizer/mainwindow.cpp +++ b/korganizer/mainwindow.cpp | |||
@@ -72,3 +72,5 @@ MainWindow::MainWindow( QWidget *parent, const char *name, QString msg) : | |||
72 | { | 72 | { |
73 | 73 | mPassWordPiSync = "abc"; | |
74 | mTimerCommandSocket = new QTimer ( this ); | ||
75 | connect( mTimerCommandSocket, SIGNAL ( timeout () ), this, SLOT ( deleteCommandSocket() ) ); | ||
74 | #ifdef DESKTOP_VERSION | 76 | #ifdef DESKTOP_VERSION |
@@ -1891,2 +1893,3 @@ void MainWindow::enableQuick() | |||
1891 | { | 1893 | { |
1894 | QString passWordPiSync = "bhdrvmk"; | ||
1892 | QString retfile = ""; | 1895 | QString retfile = ""; |
@@ -1901,4 +1904,10 @@ void MainWindow::enableQuick() | |||
1901 | lay.addWidget( &lab); | 1904 | lay.addWidget( &lab); |
1905 | |||
1906 | QLineEdit lepw ( &dia ); | ||
1907 | lepw.setText( "abc" ); | ||
1908 | QLabel label2 ( i18n("Password to enable\naccess from remote:"), &dia ); | ||
1909 | lay.addWidget( &label2); | ||
1910 | lay.addWidget( &lepw); | ||
1902 | dia.setFixedSize( 230,80 ); | 1911 | dia.setFixedSize( 230,80 ); |
1903 | dia.setCaption( i18n("Enter port for Easy-Pi-Sync") ); | 1912 | dia.setCaption( i18n("Enter port for Pi-Sync") ); |
1904 | QPushButton pb ( "OK", &dia); | 1913 | QPushButton pb ( "OK", &dia); |
@@ -1913,2 +1922,3 @@ void MainWindow::enableQuick() | |||
1913 | dia.hide(); | 1922 | dia.hide(); |
1923 | passWordPiSync = lepw.text(); | ||
1914 | qApp->processEvents(); | 1924 | qApp->processEvents(); |
@@ -1918,3 +1928,3 @@ void MainWindow::enableQuick() | |||
1918 | if ( ! ok ) { | 1928 | if ( ! ok ) { |
1919 | qDebug("no valid port "); | 1929 | KMessageBox::information( this, i18n("No valid port")); |
1920 | return; | 1930 | return; |
@@ -1922,3 +1932,3 @@ void MainWindow::enableQuick() | |||
1922 | qDebug("port %d ", port); | 1932 | qDebug("port %d ", port); |
1923 | mServerSocket = new KServerSocket ( port ,1 ); | 1933 | mServerSocket = new KServerSocket ( passWordPiSync, port ,1 ); |
1924 | qDebug("connected "); | 1934 | qDebug("connected "); |
@@ -1948,5 +1958,5 @@ void MainWindow::sendFile(QSocket* socket) | |||
1948 | mSyncActionDialog->show(); | 1958 | mSyncActionDialog->show(); |
1949 | qApp->processEvents(); | ||
1950 | qDebug("saving ... "); | 1959 | qDebug("saving ... "); |
1951 | save(); | 1960 | save(); |
1961 | qApp->processEvents(); | ||
1952 | QString fileName = defaultFileName(); | 1962 | QString fileName = defaultFileName(); |
@@ -1980,6 +1990,30 @@ void MainWindow::getFile(QSocket* socket) | |||
1980 | 1990 | ||
1991 | piTime.start(); | ||
1992 | piSocket = socket; | ||
1993 | piFileString = ""; | ||
1994 | QTimer::singleShot( 1, this , SLOT (readBackFileFromSocket( ) )); | ||
1995 | |||
1996 | |||
1997 | } | ||
1998 | void MainWindow::readBackFileFromSocket() | ||
1999 | { | ||
2000 | qDebug("readBackFileFromSocket() %d ", piTime.elapsed ()); | ||
2001 | while ( piSocket->canReadLine () ) { | ||
2002 | piTime.restart(); | ||
2003 | QString line = piSocket->readLine (); | ||
2004 | piFileString += line; | ||
2005 | qDebug("readline: %s ", line.latin1()); | ||
2006 | setCaption( i18n("Received %1 bytes").arg( piFileString.length() ) ); | ||
2007 | |||
2008 | } | ||
2009 | if ( piTime.elapsed () < 3000 ) { | ||
2010 | // wait for more | ||
2011 | qDebug("waitformore "); | ||
2012 | QTimer::singleShot( 100, this , SLOT (readBackFileFromSocket( ) )); | ||
2013 | return; | ||
2014 | } | ||
1981 | QString fileName = defaultFileName(); | 2015 | QString fileName = defaultFileName(); |
1982 | QFile file( fileName ); | 2016 | QFile file ( fileName ); |
1983 | if (!file.open( IO_WriteOnly ) ) { | 2017 | if (!file.open( IO_WriteOnly ) ) { |
1984 | setCaption( i18n("Error open file") ); | 2018 | setCaption( i18n("Error open file for writing!") ); |
1985 | delete mSyncActionDialog; | 2019 | delete mSyncActionDialog; |
@@ -1987,2 +2021,3 @@ void MainWindow::getFile(QSocket* socket) | |||
1987 | qDebug("error open cal file "); | 2021 | qDebug("error open cal file "); |
2022 | piFileString = ""; | ||
1988 | return ; | 2023 | return ; |
@@ -1992,49 +2027,9 @@ void MainWindow::getFile(QSocket* socket) | |||
1992 | mView->setLoadedFileVersion(QDateTime::currentDateTime().addSecs( -1)); | 2027 | mView->setLoadedFileVersion(QDateTime::currentDateTime().addSecs( -1)); |
1993 | QTextStream ts( &file ); | 2028 | QTextStream ts ( &file ); |
1994 | ts.setCodec( QTextCodec::codecForName("utf8") ); | 2029 | ts.setCodec( QTextCodec::codecForName("utf8") ); |
1995 | bool first = true; | 2030 | qDebug("finish "); |
1996 | while ( socket->canReadLine () || first ) { | 2031 | setCaption( i18n("Writing file to disk...") ); |
1997 | first = false; | 2032 | ts << piFileString; |
1998 | while ( socket->canReadLine () ) { | ||
1999 | qDebug("avail %d ", socket->bytesAvailable () ); | ||
2000 | ts << socket->readLine (); | ||
2001 | } | ||
2002 | QTime ti; | ||
2003 | ti.start(); | ||
2004 | while ( ti.elapsed () < 5000 && !socket->canReadLine () ) { | ||
2005 | qDebug("waiting1a %d %d ",ti.elapsed (), socket->bytesAvailable () ); | ||
2006 | //qApp->processEvents(); | ||
2007 | qDebug("waiting1b %d ",ti.elapsed () ); | ||
2008 | if ( !socket->canReadLine () ) { | ||
2009 | qDebug("waiting1c %d ",ti.elapsed () ); | ||
2010 | #ifndef _WIN32_ | ||
2011 | usleep( 100000); | ||
2012 | #endif | ||
2013 | } | ||
2014 | //socket->waitForMore ( 100 ); | ||
2015 | } | ||
2016 | ts << socket->readLine (); | ||
2017 | #if 0 | ||
2018 | #ifdef DESKTOP_VERSION | ||
2019 | socket->waitForMore ( 5000 ); | ||
2020 | #else | ||
2021 | // socket->waitForMore ( 5000 ); | ||
2022 | // seems to be broken in qt2 | ||
2023 | bool stop = false; | ||
2024 | QTime ti; | ||
2025 | ti.start(); | ||
2026 | while ( ti.elapsed < 5000 && !stop ) { | ||
2027 | qApp->processEvents(); | ||
2028 | if ( socket->canReadLine () ) | ||
2029 | stop = true ; | ||
2030 | else { | ||
2031 | usleep( 100000 ); | ||
2032 | |||
2033 | } | ||
2034 | } | ||
2035 | #endif | ||
2036 | #endif | ||
2037 | } | ||
2038 | setCaption( i18n("File received - reloading calendar...") ); | 2033 | setCaption( i18n("File received - reloading calendar...") ); |
2039 | socket->close(); | 2034 | piSocket->close(); |
2040 | file.close(); | 2035 | file.close(); |
@@ -2042,8 +2037,9 @@ void MainWindow::getFile(QSocket* socket) | |||
2042 | mView->openCalendar( defaultFileName() ); | 2037 | mView->openCalendar( defaultFileName() ); |
2043 | setCaption( i18n("Easy-Pi-Sync successful!") ); | 2038 | setCaption( i18n("Pi-Sync successful!") ); |
2044 | delete mSyncActionDialog; | 2039 | delete mSyncActionDialog; |
2045 | mSyncActionDialog = 0; | 2040 | mSyncActionDialog = 0; |
2041 | piFileString = ""; | ||
2046 | 2042 | ||
2047 | 2043 | ||
2048 | } | 2044 | } |
2049 | void MainWindow::endConnect() | 2045 | void MainWindow::endConnect() |
@@ -2056,2 +2052,3 @@ void MainWindow::performQuick() | |||
2056 | { | 2052 | { |
2053 | |||
2057 | setCaption( i18n("Please input connection settings") ); | 2054 | setCaption( i18n("Please input connection settings") ); |
@@ -2072,4 +2069,11 @@ void MainWindow::performQuick() | |||
2072 | lay.addWidget( &lab2); | 2069 | lay.addWidget( &lab2); |
2070 | |||
2071 | QLineEdit lepw ( &dia ); | ||
2072 | lepw.setText( mPassWordPiSync ); | ||
2073 | QLabel label3 ( i18n("Password to enable\naccess to remote:"), &dia ); | ||
2074 | lay.addWidget( &label3); | ||
2075 | lay.addWidget( &lepw); | ||
2076 | |||
2073 | dia.setFixedSize( 230,200 ); | 2077 | dia.setFixedSize( 230,200 ); |
2074 | dia.setCaption( i18n("Enter port for Easy-Pi-Sync ") ); | 2078 | dia.setCaption( i18n("Enter port for Pi-Sync ") ); |
2075 | QPushButton pb ( "OK", &dia); | 2079 | QPushButton pb ( "OK", &dia); |
@@ -2083,2 +2087,3 @@ void MainWindow::performQuick() | |||
2083 | } | 2087 | } |
2088 | mPassWordPiSync = lepw.text(); | ||
2084 | dia.hide(); | 2089 | dia.hide(); |
@@ -2105,2 +2110,3 @@ void MainWindow::performQuickQuick() | |||
2105 | connect( mCommandSocket, SIGNAL(readyRead()), this, SLOT(readFileFromSocket()) ); | 2110 | connect( mCommandSocket, SIGNAL(readyRead()), this, SLOT(readFileFromSocket()) ); |
2111 | connect( mCommandSocket, SIGNAL(delayedCloseFinished ()), this, SLOT(deleteCommandSocket()) ); | ||
2106 | } | 2112 | } |
@@ -2110,10 +2116,33 @@ void MainWindow::performQuickQuick() | |||
2110 | os.setEncoding( QTextStream::UnicodeUTF8 ); | 2116 | os.setEncoding( QTextStream::UnicodeUTF8 ); |
2111 | os << "GET\r\n"; | 2117 | os << "GET " << mPassWordPiSync << "\r\n"; |
2112 | setCaption( i18n("Sending request for remote file ...") ); | 2118 | setCaption( i18n("Sending request for remote file ...") ); |
2119 | mTimerCommandSocket->start( 15000 ); | ||
2113 | 2120 | ||
2114 | } | 2121 | } |
2122 | void MainWindow::deleteCommandSocket() | ||
2123 | { | ||
2124 | if ( !mCommandSocket) | ||
2125 | return; | ||
2126 | if ( mTimerCommandSocket->isActive () ) { | ||
2127 | KMessageBox::information( 0, i18n("ERROR:\nConnection to remote host timed out ")); | ||
2128 | mTimerCommandSocket->stop(); | ||
2129 | } | ||
2130 | qDebug("MainWindow::deletemCommandSocket() "); | ||
2131 | delete mCommandSocket; | ||
2132 | mCommandSocket = 0; | ||
2133 | } | ||
2134 | void MainWindow::deleteCommandSocketFinish() | ||
2135 | { | ||
2136 | if ( ! mCommandSocketFinish) | ||
2137 | return; | ||
2138 | //KMessageBox::information( 0, i18n("MainWindow::deleteCommandSocketFinish() ")); | ||
2139 | qDebug("MainWindow::deletemCommandSocketFinish() "); | ||
2140 | delete mCommandSocketFinish; | ||
2141 | mCommandSocketFinish = 0; | ||
2142 | } | ||
2115 | void MainWindow::readFileFromSocket() | 2143 | void MainWindow::readFileFromSocket() |
2116 | { | 2144 | { |
2145 | mTimerCommandSocket->stop(); | ||
2117 | setCaption( i18n("Receiving remote file ...") ); | 2146 | setCaption( i18n("Receiving remote file ...") ); |
2118 | qDebug("MainWindow::readFileFromSocket() "); | 2147 | qDebug("MainWindow::readFileFromSocket() "); |
2119 | QString fileName; | 2148 | QString fileName; |
@@ -2154,2 +2183,4 @@ void MainWindow::readFileFromSocket() | |||
2154 | mCommandSocket->close(); | 2183 | mCommandSocket->close(); |
2184 | if ( mCommandSocket->state() == QSocket::Idle ) | ||
2185 | deleteCommandSocket(); | ||
2155 | // pending: deleting after signal SIGNAL(delayedCloseFinished()) | 2186 | // pending: deleting after signal SIGNAL(delayedCloseFinished()) |
@@ -2173,3 +2204,3 @@ void MainWindow::readFileFromSocket() | |||
2173 | KOPrefs::instance()->mShowSyncSummary = temp->getShowSummaryAfterSync(); | 2204 | KOPrefs::instance()->mShowSyncSummary = temp->getShowSummaryAfterSync(); |
2174 | 2205 | delete temp; | |
2175 | setCaption( i18n("Remote file saved to temp file.") ); | 2206 | setCaption( i18n("Remote file saved to temp file.") ); |
@@ -2182,3 +2213,4 @@ void MainWindow::readFileFromSocket() | |||
2182 | if ( !mCommandSocketFinish ) { | 2213 | if ( !mCommandSocketFinish ) { |
2183 | mCommandSocketFinish = new QSocket( this ); | 2214 | mCommandSocketFinish = new QSocket( this ); |
2215 | connect( mCommandSocketFinish, SIGNAL(delayedCloseFinished ()), this, SLOT(deleteCommandSocketFinish()) ); | ||
2184 | } | 2216 | } |
@@ -2202,3 +2234,3 @@ void MainWindow::readFileFromSocket() | |||
2202 | if ( KOPrefs::instance()->mWriteBackFile ) { | 2234 | if ( KOPrefs::instance()->mWriteBackFile ) { |
2203 | os2 << "PUT\r\n"; | 2235 | os2 << "PUT " << mPassWordPiSync << "\r\n";; |
2204 | while ( ! ts2.atEnd() ) { | 2236 | while ( ! ts2.atEnd() ) { |
@@ -2210,8 +2242,7 @@ void MainWindow::readFileFromSocket() | |||
2210 | mCommandSocketFinish->close(); | 2242 | mCommandSocketFinish->close(); |
2243 | if ( mCommandSocketFinish->state() == QSocket::Idle ) | ||
2244 | deleteCommandSocketFinish(); | ||
2211 | file.close(); | 2245 | file.close(); |
2212 | // pending: deleting after signal SIGNAL(delayedCloseFinished()) | ||
2213 | //delete ( mCommandSocket); | ||
2214 | //mCommandSocket = 0; | ||
2215 | qDebug("Syncing succesful! "); | 2246 | qDebug("Syncing succesful! "); |
2216 | setCaption( i18n("Easy-Pi-Sync succesful!") ); | 2247 | setCaption( i18n("Pi-Sync succesful!") ); |
2217 | 2248 | ||
@@ -2498,6 +2529,6 @@ void MainWindow::printCal() | |||
2498 | 2529 | ||
2499 | KServerSocket:: KServerSocket ( Q_UINT16 port, int backlog, QObject * parent, const char * name ) : QServerSocket( port, backlog, parent, name ) | 2530 | KServerSocket:: KServerSocket ( QString pw, Q_UINT16 port, int backlog, QObject * parent, const char * name ) : QServerSocket( port, backlog, parent, name ) |
2500 | { | 2531 | { |
2501 | 2532 | mPassWord = pw; | |
2502 | mSocket = 0; | 2533 | mSocket = 0; |
2503 | }; | 2534 | }; |
@@ -2539,6 +2570,16 @@ void KServerSocket::readClient() | |||
2539 | if ( tokens[0] == "GET" ) { | 2570 | if ( tokens[0] == "GET" ) { |
2540 | emit sendFile( mSocket ); | 2571 | if ( tokens[1] == mPassWord ) |
2572 | emit sendFile( mSocket ); | ||
2573 | else { | ||
2574 | KMessageBox::information( 0, i18n("ERROR:\nGot send file request\nwith invalid password")); | ||
2575 | qDebug("password %s, invalid password %s ",mPassWord.latin1(), tokens[1].latin1() ); | ||
2576 | } | ||
2541 | } | 2577 | } |
2542 | if ( tokens[0] == "PUT" ) { | 2578 | if ( tokens[0] == "PUT" ) { |
2543 | emit getFile( mSocket ); | 2579 | if ( tokens[1] == mPassWord ) |
2580 | emit getFile( mSocket ); | ||
2581 | else { | ||
2582 | KMessageBox::information( 0, i18n("ERROR:\nGot receive file request\nwith invalid password")); | ||
2583 | qDebug("password %s, invalid password %s ",mPassWord.latin1(), tokens[1].latin1() ); | ||
2584 | } | ||
2544 | } | 2585 | } |
diff --git a/korganizer/mainwindow.h b/korganizer/mainwindow.h index cc656a3..d217578 100644 --- a/korganizer/mainwindow.h +++ b/korganizer/mainwindow.h | |||
@@ -6,2 +6,5 @@ | |||
6 | #include <qdict.h> | 6 | #include <qdict.h> |
7 | #include <qfile.h> | ||
8 | #include <qsocket.h> | ||
9 | #include <qtextstream.h> | ||
7 | #include <qregexp.h> | 10 | #include <qregexp.h> |
@@ -29,3 +32,3 @@ class KServerSocket : public QServerSocket | |||
29 | public: | 32 | public: |
30 | KServerSocket ( Q_UINT16 port, int backlog = 0, QObject * parent=0, const char * name=0 ); | 33 | KServerSocket ( QString password, Q_UINT16 port, int backlog = 0, QObject * parent=0, const char * name=0 ); |
31 | 34 | ||
@@ -42,2 +45,3 @@ private slots: | |||
42 | QSocket* mSocket; | 45 | QSocket* mSocket; |
46 | QString mPassWord; | ||
43 | }; | 47 | }; |
@@ -116,2 +120,7 @@ class MainWindow : public QMainWindow | |||
116 | private slots: | 120 | private slots: |
121 | QSocket* piSocket; | ||
122 | QString piFileString; | ||
123 | QTime piTime; | ||
124 | void deleteCommandSocket(); | ||
125 | void deleteCommandSocketFinish(); | ||
117 | void fillSyncMenu(); | 126 | void fillSyncMenu(); |
@@ -120,4 +129,7 @@ class MainWindow : public QMainWindow | |||
120 | void readFileFromSocket(); | 129 | void readFileFromSocket(); |
130 | void readBackFileFromSocket(); | ||
121 | void endConnect(); | 131 | void endConnect(); |
122 | private: | 132 | private: |
133 | QTimer* mTimerCommandSocket; | ||
134 | QString mPassWordPiSync; | ||
123 | QSocket* mCommandSocket; | 135 | QSocket* mCommandSocket; |