diff options
author | George Hazan <george.hazan@gmail.com> | 2014-07-12 15:38:46 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2014-07-12 15:38:46 +0000 |
commit | 01ab72c6afb99b7403eb577a44f35b09eda594f7 (patch) | |
tree | cac72eaf375cf83ef2c799c64f9ef133e01659d3 | |
parent | 5970c40dd0ae37efac77c480ec379a74279fc347 (diff) |
wipe out of the old ugly disconnection code
git-svn-id: http://svn.miranda-ng.org/main/trunk@9773 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r-- | protocols/IcqOscarJ/src/chan_04close.cpp | 1 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/chan_05ping.cpp | 23 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/fam_01service.cpp | 22 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/icq_avatar.cpp | 23 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/icq_proto.cpp | 4 | ||||
-rw-r--r-- | protocols/IcqOscarJ/src/icq_server.cpp | 62 |
6 files changed, 57 insertions, 78 deletions
diff --git a/protocols/IcqOscarJ/src/chan_04close.cpp b/protocols/IcqOscarJ/src/chan_04close.cpp index 409926b3df..b5a1e6388f 100644 --- a/protocols/IcqOscarJ/src/chan_04close.cpp +++ b/protocols/IcqOscarJ/src/chan_04close.cpp @@ -86,7 +86,6 @@ void CIcqProto::handleLoginReply(BYTE *buf, WORD datalen, serverthread_info *inf // we return only if the server did not gave us cookie (possible to connect with soft error)
if (!chain->getLength(0x06, 1)) {
disposeChain(&chain);
- SetCurrentStatus(ID_STATUS_OFFLINE);
icq_serverDisconnect();
return; // Failure
}
diff --git a/protocols/IcqOscarJ/src/chan_05ping.cpp b/protocols/IcqOscarJ/src/chan_05ping.cpp index bd5539b974..62c3377ada 100644 --- a/protocols/IcqOscarJ/src/chan_05ping.cpp +++ b/protocols/IcqOscarJ/src/chan_05ping.cpp @@ -29,7 +29,6 @@ void CIcqProto::handlePingChannel(BYTE *buf, WORD datalen) debugLogA("Warning: Ignoring server packet on PING channel");
}
-
void __cdecl CIcqProto::KeepAliveThread(void *arg)
{
serverthread_info *info = (serverthread_info*)arg;
@@ -40,23 +39,21 @@ void __cdecl CIcqProto::KeepAliveThread(void *arg) info->hKeepAliveEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
- for (;;)
- {
+ for (;;) {
DWORD dwWait = ICQWaitForSingleObject(info->hKeepAliveEvent, dwInterval);
if (serverThreadHandle == NULL) // connection lost, end
break;
- if (dwWait == WAIT_TIMEOUT)
- {
+
+ // Possible shutdown in progress
+ if (dwWait == WAIT_IO_COMPLETION)
+ break;
+
+ if (dwWait == WAIT_TIMEOUT) {
// Send a keep alive packet to server
packet.wLen = 0;
write_flap(&packet, ICQ_PING_CHAN);
sendServPacket(&packet);
}
- else if (dwWait == WAIT_IO_COMPLETION)
- // Possible shutdown in progress
- if (Miranda_Terminated()) break;
- else
- break;
}
debugLogA("Keep alive thread ended.");
@@ -65,19 +62,17 @@ void __cdecl CIcqProto::KeepAliveThread(void *arg) info->hKeepAliveEvent = NULL;
}
-
void CIcqProto::StartKeepAlive(serverthread_info *info)
{
if (info->hKeepAliveEvent) // start only once
return;
if (getByte("KeepAlive", DEFAULT_KEEPALIVE_ENABLED))
- CloseHandle( ForkThreadEx(&CIcqProto::KeepAliveThread, info, 0));
+ ForkThread(&CIcqProto::KeepAliveThread, info);
}
-
void CIcqProto::StopKeepAlive(serverthread_info *info)
-{ // finish keep alive thread
+{
if (info->hKeepAliveEvent)
SetEvent(info->hKeepAliveEvent);
}
diff --git a/protocols/IcqOscarJ/src/fam_01service.cpp b/protocols/IcqOscarJ/src/fam_01service.cpp index 2debcedfeb..148bfecf83 100644 --- a/protocols/IcqOscarJ/src/fam_01service.cpp +++ b/protocols/IcqOscarJ/src/fam_01service.cpp @@ -848,7 +848,7 @@ void CIcqProto::handleServUINSettings(int nPort, serverthread_info *info) packDWord(&packet, dwDirectCookie); // DC Cookie
packDWord(&packet, WEBFRONTPORT); // Web front port
packDWord(&packet, CLIENTFEATURES); // Client features
- packDWord(&packet, 0x7fffffff); // Abused timestamp
+ packDWord(&packet, 0x7fffffff); // Abused timestamp
packDWord(&packet, ICQ_PLUG_VERSION); // Abused timestamp
if (ServiceExists("SecureIM/IsContactSecured"))
packDWord(&packet, 0x5AFEC0DE); // SecureIM Abuse
@@ -929,16 +929,15 @@ void CIcqProto::handleServUINSettings(int nPort, serverthread_info *info) // login sequence is complete enter logged-in mode
info->bLoggedIn = 1;
- m_bConnectionLost = FALSE;
+ m_bConnectionLost = false;
// enable auto info-update routine
- icq_EnableUserLookup(TRUE);
+ icq_EnableUserLookup(true);
- if (!info->isMigrating)
- { /* Get Offline Messages Reqeust */
+ if (!info->isMigrating) {
+ // Get Offline Messages Reqeust
cookie_offline_messages *ack = (cookie_offline_messages*)SAFE_MALLOC(sizeof(cookie_offline_messages));
- if (ack)
- {
+ if (ack) {
DWORD dwCookie = AllocateCookie(CKT_OFFLINEMESSAGE, ICQ_MSG_CLI_REQ_OFFLINE, 0, ack);
serverPacketInit(&packet, 10);
@@ -946,8 +945,7 @@ void CIcqProto::handleServUINSettings(int nPort, serverthread_info *info) sendServPacket(&packet);
}
- else
- icq_LogMessage(LOG_WARNING, LPGEN("Failed to request offline messages. They may be received next time you log in."));
+ else icq_LogMessage(LOG_WARNING, LPGEN("Failed to request offline messages. They may be received next time you log in."));
// Update our information from the server
sendOwnerInfoRequest();
@@ -958,8 +956,7 @@ void CIcqProto::handleServUINSettings(int nPort, serverthread_info *info) // Start sending Keep-Alive packets
StartKeepAlive(info);
- if (m_bAvatarsEnabled)
- { // Send SNAC 1,4 - request avatar family 0x10 connection
+ if (m_bAvatarsEnabled) { // Send SNAC 1,4 - request avatar family 0x10 connection
icq_requestnewfamily(ICQ_AVATAR_FAMILY, &CIcqProto::StartAvatarThread);
m_avatarsConnectionPending = TRUE;
@@ -971,8 +968,7 @@ void CIcqProto::handleServUINSettings(int nPort, serverthread_info *info) }
info->isMigrating = 0;
- if (m_bAimEnabled)
- {
+ if (m_bAimEnabled) {
char **szAwayMsg = NULL;
icq_lock l(m_modeMsgsMutex);
diff --git a/protocols/IcqOscarJ/src/icq_avatar.cpp b/protocols/IcqOscarJ/src/icq_avatar.cpp index 58dda500da..cf4d57fc11 100644 --- a/protocols/IcqOscarJ/src/icq_avatar.cpp +++ b/protocols/IcqOscarJ/src/icq_avatar.cpp @@ -178,15 +178,13 @@ BYTE* calcMD5HashOfFile(const TCHAR *tszFile) int CIcqProto::IsAvatarChanged(MCONTACT hContact, const BYTE *pHash, int nHashLen)
{
DBVARIANT dbvSaved = { 0 };
- if (!getSetting(hContact, "AvatarSaved", &dbvSaved)) {
- if ((dbvSaved.cpbVal != nHashLen) || memcmp(dbvSaved.pbVal, pHash, nHashLen)) { // the hashes are different
- db_free(&dbvSaved);
- return 2;
- }
- db_free(&dbvSaved);
- return 0; // hash is there and is the same - Success
- }
- return 1; // saved Avatar hash is missing
+ if (getSetting(hContact, "AvatarSaved", &dbvSaved))
+ return 1; // saved Avatar hash is missing
+
+ // are the hashes different?
+ int ret = (dbvSaved.cpbVal != nHashLen || memcmp(dbvSaved.pbVal, pHash, nHashLen)) ? 2 : 0;
+ db_free(&dbvSaved);
+ return ret;
}
void CIcqProto::StartAvatarThread(HANDLE hConn, char *cookie, WORD cookieLen) // called from event
@@ -229,18 +227,18 @@ void CIcqProto::StartAvatarThread(HANDLE hConn, char *cookie, WORD cookieLen) // if (m_avatarsConnection && m_avatarsConnection->isPending()) {
debugLogA("Avatar, Multiple start thread attempt, ignored.");
- NetLib_CloseConnection(&hConn, FALSE);
+ NetLib_CloseConnection(&hConn, false);
SAFE_FREE((void**)&cookie);
return;
}
+
if (m_avatarsConnection)
m_avatarsConnection->closeConnection();
-
m_avatarsConnection = new avatars_server_connection(this, hConn, cookie, cookieLen); // the old connection should not be used anymore
// connection object created, remove the connection request pending flag
- m_avatarsConnectionPending = FALSE;
+ m_avatarsConnectionPending = false;
}
void CIcqProto::StopAvatarThread()
@@ -1078,7 +1076,6 @@ void avatars_server_connection::connectionThread() }
SAFE_FREE((void**)&pCookie);
- ppro->debugLogA("Avatar thread ended");
}
int avatars_server_connection::sendServerPacket(icq_packet *pPacket)
diff --git a/protocols/IcqOscarJ/src/icq_proto.cpp b/protocols/IcqOscarJ/src/icq_proto.cpp index 345be0d80d..d19156bd12 100644 --- a/protocols/IcqOscarJ/src/icq_proto.cpp +++ b/protocols/IcqOscarJ/src/icq_proto.cpp @@ -1689,11 +1689,9 @@ int __cdecl CIcqProto::SetStatus(int iNewStatus) if (hServerConn) { // Connected, Send disconnect packet
icq_sendCloseConnection();
-
icq_serverDisconnect();
- SetCurrentStatus(ID_STATUS_OFFLINE);
-
+ m_bConnectionLost = false;
debugLogA("Logged off.");
}
}
diff --git a/protocols/IcqOscarJ/src/icq_server.cpp b/protocols/IcqOscarJ/src/icq_server.cpp index 2a0e433761..ca86fa0eca 100644 --- a/protocols/IcqOscarJ/src/icq_server.cpp +++ b/protocols/IcqOscarJ/src/icq_server.cpp @@ -37,8 +37,8 @@ void icq_newConnectionReceived(HANDLE hNewConnection, DWORD dwRemoteIP, void *pE void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam)
{
- serverthread_info info = {0};
- info.isLoginServer = 1;
+ serverthread_info info = { 0 };
+ info.isLoginServer = info.bReinitRecver = true;
info.wAuthKeyLen = infoParam->wPassLen;
null_strcpy((char*)info.szAuthKey, infoParam->szPass, info.wAuthKeyLen);
// store server port
@@ -103,16 +103,15 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) }
// This is the "infinite" loop that receives the packets from the ICQ server
+ NETLIBPACKETRECVER packetRecv;
info.hPacketRecver = (HANDLE)CallService(MS_NETLIB_CREATEPACKETRECVER, (WPARAM)hServerConn, 0x2400);
- NETLIBPACKETRECVER packetRecv = { sizeof(packetRecv) };
- packetRecv.dwTimeout = INFINITE;
while (serverThreadHandle) {
if (info.bReinitRecver) { // we reconnected, reinit struct
- info.bReinitRecver = 0;
+ info.bReinitRecver = false;
ZeroMemory(&packetRecv, sizeof(packetRecv));
packetRecv.cbSize = sizeof(packetRecv);
- packetRecv.dwTimeout = INFINITE;
+ packetRecv.dwTimeout = 1000;
}
int recvResult = CallService(MS_NETLIB_GETMOREPACKETS, (WPARAM)info.hPacketRecver, (LPARAM)&packetRecv);
@@ -122,18 +121,16 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) }
if (recvResult == SOCKET_ERROR) {
- debugLogA("Abortive closure of server socket, error: %d", GetLastError());
- break;
- }
-
- if (m_iDesiredStatus == ID_STATUS_OFFLINE) { // Disconnect requested, send disconnect packet
- icq_sendCloseConnection();
-
- // disconnected upon request
- m_bConnectionLost = FALSE;
- SetCurrentStatus(ID_STATUS_OFFLINE);
-
- debugLogA("Logged off.");
+ DWORD dwError = GetLastError();
+ if (dwError == ERROR_TIMEOUT) {
+ if (m_iDesiredStatus == ID_STATUS_OFFLINE)
+ break;
+ continue;
+ }
+ if (dwError == WSAESHUTDOWN) // ok, we're going offline
+ break;
+
+ debugLogA("Abortive closure of server socket, error: %d", dwError);
break;
}
@@ -161,7 +158,7 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) icq_LogMessage(LOG_FATAL, LPGEN("Connection failed.\nLogin sequence failed for unknown reason.\nTry again later."));
// set flag indicating we were kicked out
- m_bConnectionLost = TRUE;
+ m_bConnectionLost = true;
SetCurrentStatus(ID_STATUS_OFFLINE);
}
@@ -181,15 +178,16 @@ void __cdecl CIcqProto::ServerThread(serverthread_start_info *infoParam) // Offline all contacts
debugLogA("Setting offline status to contacts...");
for (MCONTACT hContact = db_find_first(m_szModuleName); hContact; hContact = db_find_next(hContact, m_szModuleName)) {
+ if (getContactStatus(hContact) == ID_STATUS_OFFLINE)
+ continue;
+
+ setWord(hContact, "Status", ID_STATUS_OFFLINE);
+
DWORD dwUIN;
uid_str szUID;
if (!getContactUid(hContact, &dwUIN, &szUID)) {
- if (getContactStatus(hContact) != ID_STATUS_OFFLINE) {
- setWord(hContact, "Status", ID_STATUS_OFFLINE);
-
- char tmp = 0;
- handleXStatusCaps(dwUIN, szUID, hContact, (BYTE*)&tmp, 0, &tmp, 0);
- }
+ char tmp = 0;
+ handleXStatusCaps(dwUIN, szUID, hContact, (BYTE*)&tmp, 0, &tmp, 0);
}
}
@@ -224,6 +222,8 @@ void CIcqProto::icq_serverDisconnect() CloseHandle(serverThreadHandle);
serverThreadHandle = NULL;
}
+
+ SetCurrentStatus(ID_STATUS_OFFLINE);
}
int CIcqProto::handleServerPackets(BYTE *buf, int len, serverthread_info *info)
@@ -298,8 +298,7 @@ void CIcqProto::sendServPacket(icq_packet *pPacket) // make sure to have the connection handle
connectionHandleMutex->Enter();
- if (hServerConn)
- {
+ if (hServerConn) {
int nSendResult;
// This critsec makes sure that the sequence order doesn't get screwed up
@@ -325,19 +324,14 @@ void CIcqProto::sendServPacket(icq_packet *pPacket) if (dwErrorCode != WSAESHUTDOWN)
icq_LogUsingErrorCode(LOG_ERROR, GetLastError(), LPGEN("Your connection with the ICQ server was abortively closed"));
icq_serverDisconnect();
-
- if (m_iStatus != ID_STATUS_OFFLINE)
- SetCurrentStatus(ID_STATUS_OFFLINE);
}
- else
- { // Rates management
+ else { // Rates management
icq_lock l(m_ratesMutex);
m_rates->packetSent(pPacket);
}
}
- else
- {
+ else {
connectionHandleMutex->Leave();
debugLogA("Error: Failed to send packet (no connection)");
}
|