diff options
author | Sergey Bolhovskoy <elzorfox@ya.ru> | 2014-09-10 13:15:54 +0000 |
---|---|---|
committer | Sergey Bolhovskoy <elzorfox@ya.ru> | 2014-09-10 13:15:54 +0000 |
commit | b8a7168685627ff4ea79dcaf3d917f6b40a23f3b (patch) | |
tree | dea3c2f2d883868165d6f4f71ff97fc674f8df9f /protocols | |
parent | f5988c0e4245176f9b3c4380265e70ac2344f62a (diff) |
VKontakte:
fix for ‘to many connections’ on FindUser
add read status every 60 sec
add StatusMsg and About profile fields
some cleanup
git-svn-id: http://svn.miranda-ng.org/main/trunk@10422 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols')
-rw-r--r-- | protocols/VKontakte/src/misc.cpp | 1 | ||||
-rw-r--r-- | protocols/VKontakte/src/vk_captcha.cpp | 2 | ||||
-rw-r--r-- | protocols/VKontakte/src/vk_proto.h | 1 | ||||
-rw-r--r-- | protocols/VKontakte/src/vk_thread.cpp | 60 |
4 files changed, 58 insertions, 6 deletions
diff --git a/protocols/VKontakte/src/misc.cpp b/protocols/VKontakte/src/misc.cpp index a2fae6f2d1..9ce00e1d04 100644 --- a/protocols/VKontakte/src/misc.cpp +++ b/protocols/VKontakte/src/misc.cpp @@ -51,7 +51,6 @@ MCONTACT CVkProto::FindUser(LONG dwUserid, bool bCreate) CallService(MS_PROTO_ADDTOCONTACT, (WPARAM)hNewContact, (LPARAM)m_szModuleName);
setDword(hNewContact, "ID", dwUserid);
db_set_ts(hNewContact, "CList", "Group", m_defaultGroup);
- RetrieveUserInfo(dwUserid);
return hNewContact;
}
diff --git a/protocols/VKontakte/src/vk_captcha.cpp b/protocols/VKontakte/src/vk_captcha.cpp index 1637ba608d..89b77168e7 100644 --- a/protocols/VKontakte/src/vk_captcha.cpp +++ b/protocols/VKontakte/src/vk_captcha.cpp @@ -152,8 +152,6 @@ bool CVkProto::ApplyCaptcha(AsyncHttpRequest *pReq, JSONNODE *pErrorNode) if (!RunCaptchaForm(szUrl, userReply))
return false;
-// pReq->m_szUrl = pReq->szUrl;
-// pReq->m_szUrl.AppendFormat("&captcha_sid=%s&captcha_key=%s", szSid, userReply.GetString());
pReq << CHAR_PARAM("captcha_sid", szSid) << CHAR_PARAM("captcha_key", userReply.GetString());
pReq->bNeedsRestart = true;
return true;
diff --git a/protocols/VKontakte/src/vk_proto.h b/protocols/VKontakte/src/vk_proto.h index 60350ce5ab..38509f42d6 100644 --- a/protocols/VKontakte/src/vk_proto.h +++ b/protocols/VKontakte/src/vk_proto.h @@ -200,6 +200,7 @@ struct CVkProto : public PROTO<CVkProto> void OnReceiveMyInfo(NETLIBHTTPREQUEST*, AsyncHttpRequest*);
void RetrieveUserInfo(LONG userId);
+ void RetrieveUsersInfo(int flag = 0);
void OnReceiveUserInfo(NETLIBHTTPREQUEST*, AsyncHttpRequest*);
void RetrieveFriends();
diff --git a/protocols/VKontakte/src/vk_thread.cpp b/protocols/VKontakte/src/vk_thread.cpp index 033edb4265..6766ec5ab6 100644 --- a/protocols/VKontakte/src/vk_thread.cpp +++ b/protocols/VKontakte/src/vk_thread.cpp @@ -42,8 +42,10 @@ void CVkProto::ConnectionFailed(int iReason) static VOID CALLBACK TimerProc(HWND, UINT, UINT_PTR, DWORD)
{
- for (int i=0; i < vk_Instances.getCount(); i++)
+ for (int i = 0; i < vk_Instances.getCount(); i++){
vk_Instances[i]->SetServerStatus(vk_Instances[i]->m_iStatus);
+ vk_Instances[i]->RetrieveUsersInfo(1);
+ }
}
static void CALLBACK VKSetTimer(void *pObject)
@@ -228,11 +230,33 @@ void CVkProto::OnReceiveMyInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) /////////////////////////////////////////////////////////////////////////////////////////
+static char fieldsName[] = "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online, status, about";
+
void CVkProto::RetrieveUserInfo(LONG userID)
{
Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/users.get.json", true, &CVkProto::OnReceiveUserInfo)
<< INT_PARAM("user_ids", userID)
- << CHAR_PARAM("fields", "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online")
+ << CHAR_PARAM("fields", fieldsName)
+ << CHAR_PARAM("name_case", "nom")
+ << VER_API);
+}
+
+void CVkProto::RetrieveUsersInfo(int flag)
+{
+ CMStringA userIDs;
+ for (MCONTACT hContact = db_find_first(m_szModuleName); hContact; hContact = db_find_next(hContact, m_szModuleName)){
+ LONG userID = getDword(hContact, "ID", -1);
+ if (userID == -1)
+ continue;
+ if (!userIDs.IsEmpty())
+ userIDs.AppendChar(',');
+ userIDs.AppendFormat("%i", userID);
+
+ }
+
+ Push(new AsyncHttpRequest(this, REQUEST_POST, "/method/users.get.json", true, &CVkProto::OnReceiveUserInfo)
+ << CHAR_PARAM("user_ids", userIDs)
+ << CHAR_PARAM("fields", flag?"online,status":fieldsName)
<< CHAR_PARAM("name_case", "nom")
<< VER_API);
}
@@ -264,6 +288,7 @@ void CVkProto::OnReceiveUserInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe return;
CMString tszNick;
+ int iValue;
ptrT szValue( json_as_string( json_get(pRecord, "first_name")));
if (szValue) {
setTString(hContact, "FirstName", szValue);
@@ -294,6 +319,26 @@ void CVkProto::OnReceiveUserInfo(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe SetAvatarUrl(hContact, szValue);
setWord(hContact, "Status", (json_as_int(json_get(pRecord, "online")) == 0) ? ID_STATUS_OFFLINE : ID_STATUS_ONLINE);
+
+ if ((iValue = json_as_int(json_get(pRecord, "timezone"))) != 0)
+ setByte(hContact, "Timezone", iValue * -2);
+
+ szValue = json_as_string(json_get(pRecord, "mobile_phone"));
+ if (szValue && *szValue)
+ setTString(hContact, "Cellular", szValue);
+ szValue = json_as_string(json_get(pRecord, "home_phone"));
+ if (szValue && *szValue)
+ setTString(hContact, "Phone", szValue);
+
+ szValue = json_as_string(json_get(pRecord, "status"));
+ if (szValue && *szValue)
+ db_set_ts(hContact, "CList", "StatusMsg", szValue);
+
+ szValue = json_as_string(json_get(pRecord, "about"));
+ if (szValue && *szValue)
+ setTString(hContact, "About", szValue);
+
+
}
}
@@ -304,7 +349,7 @@ void CVkProto::RetrieveFriends() debugLogA("CVkProto::RetrieveFriends");
Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/friends.get.json", true, &CVkProto::OnReceiveFriends)
<< INT_PARAM("count", 1000)
- << CHAR_PARAM("fields", "id, first_name, last_name, photo_100, sex, country, timezone, contacts, online")
+ << CHAR_PARAM("fields", fieldsName)
<<VER_API);
}
@@ -371,6 +416,14 @@ void CVkProto::OnReceiveFriends(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq szValue = json_as_string(json_get(pInfo, "home_phone"));
if (szValue && *szValue)
setTString(hContact, "Phone", szValue);
+
+ szValue = json_as_string(json_get(pInfo, "status"));
+ if (szValue && *szValue)
+ db_set_ts(hContact, "CList", "StatusMsg", szValue);
+
+ szValue = json_as_string(json_get(pInfo, "about"));
+ if (szValue && *szValue)
+ setTString(hContact, "About", szValue);
}
if (bCleanContacts)
@@ -487,6 +540,7 @@ void CVkProto::OnReceiveMessages(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pRe if (!m_bMarkReadOnReply)
MarkMessagesRead(mids);
+ RetrieveUsersInfo();
}
void CVkProto::OnReceiveDlgs(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq)
|