From 41dfcbd92abd9f16a7fe6ee222f7c710226438c8 Mon Sep 17 00:00:00 2001 From: Sergey Bolhovskoy Date: Thu, 26 Feb 2015 05:23:01 +0000 Subject: VKontakte: code cleanup and reorganisation git-svn-id: http://svn.miranda-ng.org/main/trunk@12270 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c --- protocols/VKontakte/src/misc.cpp | 2 - protocols/VKontakte/src/vk_proto.cpp | 103 ++---------- protocols/VKontakte/src/vk_proto.h | 3 - protocols/VKontakte/src/vk_search.cpp | 3 +- protocols/VKontakte/src/vk_status.cpp | 261 ++++++++++++++++++++++++++++++ protocols/VKontakte/src/vk_thread.cpp | 197 ---------------------- protocols/VKontakte/vk_10.vcxproj | 1 + protocols/VKontakte/vk_10.vcxproj.filters | 3 + protocols/VKontakte/vk_12.vcxproj | 1 + protocols/VKontakte/vk_12.vcxproj.filters | 3 + 10 files changed, 279 insertions(+), 298 deletions(-) create mode 100644 protocols/VKontakte/src/vk_status.cpp (limited to 'protocols') diff --git a/protocols/VKontakte/src/misc.cpp b/protocols/VKontakte/src/misc.cpp index 2098bd6f15..63bdf935e2 100644 --- a/protocols/VKontakte/src/misc.cpp +++ b/protocols/VKontakte/src/misc.cpp @@ -44,7 +44,6 @@ CMString json_as_CMString(JSONNODE* pNode) return tszString; } - LPCSTR findHeader(NETLIBHTTPREQUEST *pReq, LPCSTR szField) { for (int i = 0; i < pReq->headersCount; i++) @@ -473,7 +472,6 @@ bool CVkProto::AutoFillForm(char *pBody, CMStringA &szAction, CMStringA& szResul return true; } - CMString CVkProto::RunConfirmationCode() { ENTER_STRING pForm = { sizeof(pForm) }; diff --git a/protocols/VKontakte/src/vk_proto.cpp b/protocols/VKontakte/src/vk_proto.cpp index 39fcd06e2d..a73b2e8267 100644 --- a/protocols/VKontakte/src/vk_proto.cpp +++ b/protocols/VKontakte/src/vk_proto.cpp @@ -23,7 +23,6 @@ static int sttCompareProtocols(const CVkProto *p1, const CVkProto *p2) } LIST vk_Instances(1, sttCompareProtocols); - static COLORREF sttColors[] = { 0, 1, 2, 3, 4, 5, 6 }; CVkProto::CVkProto(const char *szModuleName, const TCHAR *ptszUserName) : @@ -561,50 +560,6 @@ void CVkProto::OnSendMessage(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) ////////////////////////////////////////////////////////////////////////////// -int CVkProto::SetStatus(int iNewStatus) -{ - debugLogA("CVkProto::SetStatus iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d m_hWorkerThread = %d", iNewStatus, m_iStatus, m_iDesiredStatus, m_hWorkerThread == NULL? 0 : 1 ); - if (m_iDesiredStatus == iNewStatus || iNewStatus == ID_STATUS_IDLE) - return 0; - - int oldStatus = m_iStatus; - m_iDesiredStatus = iNewStatus; - - if (iNewStatus == ID_STATUS_OFFLINE) { - if (IsOnline()) { - SetServerStatus(ID_STATUS_OFFLINE); - debugLogA("CVkProto::SetStatus ShutdownSession"); - ShutdownSession(); - } - - m_iStatus = m_iDesiredStatus = ID_STATUS_OFFLINE; - ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); - debugLogA("CVkProto::SetStatus (1) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - } - else if (m_hWorkerThread == NULL && !(m_iStatus >= ID_STATUS_CONNECTING && m_iStatus < ID_STATUS_CONNECTING + MAX_CONNECT_RETRIES)) { - m_iStatus = ID_STATUS_CONNECTING; - ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); - debugLogA("CVkProto::SetStatus (2) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - m_hWorkerThread = ForkThreadEx(&CVkProto::WorkerThread, 0, NULL); - } - else if (IsOnline()) { - debugLogA("CVkProto::SetStatus (3) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - SetServerStatus(iNewStatus); - } - else { - debugLogA("CVkProto::SetStatus (4) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); - if (!(m_iStatus >= ID_STATUS_CONNECTING && m_iStatus < ID_STATUS_CONNECTING + MAX_CONNECT_RETRIES)) - m_iDesiredStatus = m_iStatus; - debugLogA("CVkProto::SetStatus (5) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - } - - debugLogA("CVkProto::SetStatus (ret) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); - return 0; -} - -////////////////////////////////////////////////////////////////////////////// - int CVkProto::OnEvent(PROTOEVENTTYPE event, WPARAM wParam, LPARAM lParam) { switch (event) { @@ -739,16 +694,6 @@ int CVkProto::UserIsTyping(MCONTACT hContact, int type) return 1; } -MCONTACT CVkProto::AddToListByEvent(int, int, MEVENT) -{ - return NULL; -} - -int CVkProto::AuthRecv(MCONTACT, PROTORECVEVENT *) -{ - return 1; -} - int CVkProto::GetInfo(MCONTACT hContact, int) { debugLogA("CVkProto::GetInfo"); @@ -759,42 +704,12 @@ int CVkProto::GetInfo(MCONTACT hContact, int) return 0; } -int CVkProto::RecvContacts(MCONTACT, PROTORECVEVENT *) -{ - return 1; -} - -int CVkProto::RecvUrl(MCONTACT, PROTORECVEVENT *) -{ - return 1; -} - -int CVkProto::SendContacts(MCONTACT, int, int, MCONTACT*) -{ - return 1; -} - -int CVkProto::SendUrl(MCONTACT, int, const char*) -{ - return 1; -} - -int CVkProto::SetApparentMode(MCONTACT, int) -{ - return 1; -} - -int CVkProto::RecvAwayMsg(MCONTACT, int, PROTORECVEVENT*) -{ - return 1; -} - -HANDLE CVkProto::GetAwayMsg(MCONTACT) -{ - return 0; // Status messages are disabled -} - -int CVkProto::SetAwayMsg(int, const PROTOCHAR*) -{ - return 0; // Status messages are disabled -} +////////////////////////////////////////////////////////////////////////////// +MCONTACT CVkProto::AddToListByEvent(int, int, MEVENT) { return NULL; } +int CVkProto::AuthRecv(MCONTACT, PROTORECVEVENT *) { return 1; } +int CVkProto::RecvContacts(MCONTACT, PROTORECVEVENT *) { return 1; } +int CVkProto::RecvUrl(MCONTACT, PROTORECVEVENT *) { return 1; } +int CVkProto::SendContacts(MCONTACT, int, int, MCONTACT*) { return 1; } +int CVkProto::SendUrl(MCONTACT, int, const char*) { return 1; } +int CVkProto::SetApparentMode(MCONTACT, int) { return 1; } +////////////////////////////////////////////////////////////////////////////// \ No newline at end of file diff --git a/protocols/VKontakte/src/vk_proto.h b/protocols/VKontakte/src/vk_proto.h index babd8f45f2..e765b3b379 100644 --- a/protocols/VKontakte/src/vk_proto.h +++ b/protocols/VKontakte/src/vk_proto.h @@ -199,7 +199,6 @@ struct CVKNotification { TCHAR *ptszTranslate; }; - struct CVKNewsItem : public MZeroedObject { CVKNewsItem() : tDate(NULL), @@ -230,7 +229,6 @@ struct CVKBBCItem { TCHAR *ptszTempate; }; - struct TFakeAckParams { __inline TFakeAckParams(MCONTACT _hContact, int _msgid) : @@ -241,7 +239,6 @@ struct TFakeAckParams int msgid; }; - struct CVkProto : public PROTO { CVkProto(const char*, const TCHAR*); diff --git a/protocols/VKontakte/src/vk_search.cpp b/protocols/VKontakte/src/vk_search.cpp index 6eef22a8f8..c7e919dec4 100644 --- a/protocols/VKontakte/src/vk_search.cpp +++ b/protocols/VKontakte/src/vk_search.cpp @@ -44,7 +44,6 @@ HANDLE CVkProto::SearchByName(const PROTOCHAR* nick, const PROTOCHAR* firstName, return (HANDLE)1; } - void CVkProto::SearchBasicThread(void* id) { debugLogA("CVkProto::OnSearchBasicThread"); @@ -215,4 +214,4 @@ void CVkProto::OnSearchByMail(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) } ProtoBroadcastAck(0, ACKTYPE_SEARCH, ACKRESULT_SUCCESS, (HANDLE)1, 0); -} +} \ No newline at end of file diff --git a/protocols/VKontakte/src/vk_status.cpp b/protocols/VKontakte/src/vk_status.cpp new file mode 100644 index 0000000000..256a1a9e47 --- /dev/null +++ b/protocols/VKontakte/src/vk_status.cpp @@ -0,0 +1,261 @@ +/* +Copyright (c) 2013-15 Miranda NG project (http://miranda-ng.org) + +This program is free software; you can redistribute it and/or +modify it under the terms of the GNU General Public License +as published by the Free Software Foundation version 2 +of the License. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program. If not, see . +*/ + +#include "stdafx.h" + +////////////////////////////////////////////////////////////////////////////// +int CVkProto::RecvAwayMsg(MCONTACT, int, PROTORECVEVENT*) { return 1; } +HANDLE CVkProto::GetAwayMsg(MCONTACT) { return 0; } +int CVkProto::SetAwayMsg(int, const PROTOCHAR*) { return 0; } +////////////////////////////////////////////////////////////////////////////// + +int CVkProto::SetStatus(int iNewStatus) +{ + debugLogA("CVkProto::SetStatus iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d m_hWorkerThread = %d", iNewStatus, m_iStatus, m_iDesiredStatus, m_hWorkerThread == NULL ? 0 : 1); + if (m_iDesiredStatus == iNewStatus || iNewStatus == ID_STATUS_IDLE) + return 0; + + int oldStatus = m_iStatus; + m_iDesiredStatus = iNewStatus; + + if (iNewStatus == ID_STATUS_OFFLINE) { + if (IsOnline()) { + SetServerStatus(ID_STATUS_OFFLINE); + debugLogA("CVkProto::SetStatus ShutdownSession"); + ShutdownSession(); + } + + m_iStatus = m_iDesiredStatus = ID_STATUS_OFFLINE; + ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); + debugLogA("CVkProto::SetStatus (1) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + } + else if (m_hWorkerThread == NULL && !(m_iStatus >= ID_STATUS_CONNECTING && m_iStatus < ID_STATUS_CONNECTING + MAX_CONNECT_RETRIES)) { + m_iStatus = ID_STATUS_CONNECTING; + ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); + debugLogA("CVkProto::SetStatus (2) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + m_hWorkerThread = ForkThreadEx(&CVkProto::WorkerThread, 0, NULL); + } + else if (IsOnline()) { + debugLogA("CVkProto::SetStatus (3) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + SetServerStatus(iNewStatus); + } + else { + debugLogA("CVkProto::SetStatus (4) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)oldStatus, m_iStatus); + if (!(m_iStatus >= ID_STATUS_CONNECTING && m_iStatus < ID_STATUS_CONNECTING + MAX_CONNECT_RETRIES)) + m_iDesiredStatus = m_iStatus; + debugLogA("CVkProto::SetStatus (5) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + } + + debugLogA("CVkProto::SetStatus (ret) iNewStatus = %d, m_iStatus = %d, m_iDesiredStatus = %d oldStatus = %d", iNewStatus, m_iStatus, m_iDesiredStatus, oldStatus); + return 0; +} + +void CVkProto::SetServerStatus(int iNewStatus) +{ + debugLogA("CVkProto::SetServerStatus %d %d", iNewStatus, m_iStatus); + if (!IsOnline() || iNewStatus < ID_STATUS_OFFLINE) + return; + + int iOldStatus = m_iStatus; + CMString oldStatusMsg = ptrT(db_get_tsa(NULL, m_szModuleName, "OldStatusMsg")); + ptrT ptszListeningToMsg(db_get_tsa(NULL, m_szModuleName, "ListeningTo")); + + if (iNewStatus == ID_STATUS_OFFLINE) { + m_bNeedSendOnline = false; + if (!IsEmpty(ptszListeningToMsg) && m_bSetBroadcast) { + RetrieveStatusMsg(oldStatusMsg); + m_bSetBroadcast = false; + } + m_iStatus = ID_STATUS_OFFLINE; + if (iOldStatus != ID_STATUS_OFFLINE && iOldStatus != ID_STATUS_INVISIBLE) + Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOffline.json", true, &CVkProto::OnReceiveSmth) + << VER_API); + } + else if (iNewStatus != ID_STATUS_INVISIBLE) { + m_bNeedSendOnline = true; + if (iOldStatus == ID_STATUS_ONLINE) + return; + m_iStatus = ID_STATUS_ONLINE; + Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOnline.json", true, &CVkProto::OnReceiveSmth) + << VER_API); + } + else { + m_bNeedSendOnline = false; + if (!IsEmpty(ptszListeningToMsg) && m_bSetBroadcast) { + RetrieveStatusMsg(oldStatusMsg); + m_bSetBroadcast = false; + } + m_iStatus = ID_STATUS_INVISIBLE; + if (iOldStatus == ID_STATUS_ONLINE) + Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOffline.json", true, &CVkProto::OnReceiveSmth) + << VER_API); + } + + ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)iOldStatus, m_iStatus); +} + +///////////////////////////////////////////////////////////////////////////////////////// + +INT_PTR __cdecl CVkProto::SvcSetStatusMsg(WPARAM, LPARAM) +{ + debugLogA("CVkProto::SvcSetStatusMsg"); + if (!IsOnline()) + return 1; + + MsgPopup(NULL, TranslateT("Loading status message from vk.com.\nThis may take some time."), TranslateT("Waiting...")); + + Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/status.get.json", true, &CVkProto::OnReceiveStatusMsg) + << VER_API); + + return 0; +} + +void CVkProto::OnReceiveStatusMsg(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) +{ + debugLogA("CVkProto::OnReceiveStatusMsg %d", reply->resultCode); + if (reply->resultCode != 200) + return; + + OnReceiveStatus(reply, pReq); + + ptrT ptszOldStatusMsg(db_get_tsa(NULL, m_szModuleName, "OldStatusMsg")); + CMString tszOldStatusMsg(ptszOldStatusMsg); + + ENTER_STRING pForm = { sizeof(pForm) }; + pForm.type = ESF_MULTILINE; + pForm.caption = TranslateT("Enter new status message"); + pForm.ptszInitVal = ptszOldStatusMsg; + pForm.szModuleName = m_szModuleName; + pForm.szDataPrefix = "statusmsgform_"; + + if (!EnterString(&pForm)) + return; + + CMString tszNewStatusMsg(ptrT(pForm.ptszResult)); + if (tszOldStatusMsg == tszNewStatusMsg) + return; + + RetrieveStatusMsg(tszNewStatusMsg); + setTString("OldStatusMsg", ptszOldStatusMsg); +} + +void CVkProto::OnReceiveStatus(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) +{ + debugLogA("CVkProto::OnReceiveStatus %d", reply->resultCode); + if (reply->resultCode != 200) + return; + JSONROOT pRoot; + JSONNODE *pResponse = CheckJsonResponse(pReq, reply, pRoot); + if (pResponse == NULL) + return; + + JSONNODE *pAudio = json_get(pResponse, "audio"); + if (pAudio == NULL) { + ptrT ptszStatusText(json_as_string(json_get(pResponse, "text"))); + if (ptszStatusText[0] != TCHAR(9835)) + setTString("OldStatusMsg", ptszStatusText); + } +} + +void CVkProto::RetrieveStatusMsg(const CMString &StatusMsg) +{ + debugLogA("CVkProto::RetrieveStatusMsg"); + if (!IsOnline()) + return; + + Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/status.set.json", true, &CVkProto::OnReceiveSmth) + << TCHAR_PARAM("text", StatusMsg) + << VER_API); +} + +void CVkProto::RetrieveStatusMusic(const CMString &StatusMsg) +{ + debugLogA("CVkProto::RetrieveStatusMusic"); + if (!IsOnline() || m_iStatus == ID_STATUS_INVISIBLE || m_iMusicSendMetod == sendNone) + return; + + CMString code; + ptrT ptszOldStatusMsg(db_get_tsa(0, m_szModuleName, "OldStatusMsg")); + if (StatusMsg.IsEmpty()) { + if (m_iMusicSendMetod == sendBroadcastOnly) + code = "API.audio.setBroadcast();return null;"; + else { + CMString codeformat("API.status.set({text:\"%s\"});return null;"); + code.AppendFormat(codeformat, ptszOldStatusMsg); + } + m_bSetBroadcast = false; + } + else { + if (m_iMusicSendMetod == sendBroadcastOnly) { + CMString codeformat("var StatusMsg=\"%s\";var CntLmt=100;var OldMsg=API.status.get();" + "var Tracks=API.audio.search({\"q\":StatusMsg,\"count\":CntLmt,\"search_own\":1});" + "var Cnt=Tracks.count;if(Cnt>CntLmt){Cnt=CntLmt;}" + "if(Cnt==0){API.audio.setBroadcast();}" + "else{var i=0;var j=0;var Track=\" \";" + "while(iCntLmt){Cnt=CntLmt;}" + "if(Cnt==0){Track=\"♫ \"+StatusMsg;API.status.set({\"text\":Track});}" + "else{var i=0;var j=-1;" + "while(icbSize != sizeof(LISTENINGTOINFO)) + db_unset(NULL, m_szModuleName, "ListeningTo"); + else if (pliInfo->dwFlags & LTI_UNICODE) { + if (ServiceExists(MS_LISTENINGTO_GETPARSEDTEXT)) + tszListeningTo = ptrT((LPWSTR)CallService(MS_LISTENINGTO_GETPARSEDTEXT, (WPARAM)_T("%artist% - %title%"), (LPARAM)pliInfo)); + else + tszListeningTo.Format(_T("%s - %s"), + pliInfo->ptszArtist ? pliInfo->ptszArtist : _T(""), + pliInfo->ptszTitle ? pliInfo->ptszTitle : _T("")); + setTString("ListeningTo", tszListeningTo); + } + RetrieveStatusMusic(tszListeningTo); + return 0; +} \ No newline at end of file diff --git a/protocols/VKontakte/src/vk_thread.cpp b/protocols/VKontakte/src/vk_thread.cpp index 9e27ba6d36..99b9685001 100644 --- a/protocols/VKontakte/src/vk_thread.cpp +++ b/protocols/VKontakte/src/vk_thread.cpp @@ -18,7 +18,6 @@ along with this program. If not, see . #include "stdafx.h" UINT_PTR CVkProto::m_timer; - char szBlankUrl[] = "https://oauth.vk.com/blank.html"; static char VK_TOKEN_BEG[] = "access_token="; static char VK_LOGIN_DOMAIN[] = "https://m.vk.com"; @@ -103,50 +102,6 @@ void CVkProto::OnLoggedOut() m_chats.destroy(); } -void CVkProto::SetServerStatus(int iNewStatus) -{ - debugLogA("CVkProto::SetServerStatus %d %d", iNewStatus, m_iStatus); - if (!IsOnline() || iNewStatus < ID_STATUS_OFFLINE) - return; - - int iOldStatus = m_iStatus; - CMString oldStatusMsg = ptrT(db_get_tsa(NULL, m_szModuleName, "OldStatusMsg")); - ptrT ptszListeningToMsg(db_get_tsa(NULL, m_szModuleName, "ListeningTo")); - - if (iNewStatus == ID_STATUS_OFFLINE) { - m_bNeedSendOnline = false; - if (!IsEmpty(ptszListeningToMsg) && m_bSetBroadcast) { - RetrieveStatusMsg(oldStatusMsg); - m_bSetBroadcast = false; - } - m_iStatus = ID_STATUS_OFFLINE; - if (iOldStatus != ID_STATUS_OFFLINE && iOldStatus != ID_STATUS_INVISIBLE) - Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOffline.json", true, &CVkProto::OnReceiveSmth) - << VER_API); - } - else if (iNewStatus != ID_STATUS_INVISIBLE) { - m_bNeedSendOnline = true; - if (iOldStatus == ID_STATUS_ONLINE) - return; - m_iStatus = ID_STATUS_ONLINE; - Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOnline.json", true, &CVkProto::OnReceiveSmth) - << VER_API); - } - else { - m_bNeedSendOnline = false; - if (!IsEmpty(ptszListeningToMsg) && m_bSetBroadcast) { - RetrieveStatusMsg(oldStatusMsg); - m_bSetBroadcast = false; - } - m_iStatus = ID_STATUS_INVISIBLE; - if (iOldStatus == ID_STATUS_ONLINE) - Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/account.setOffline.json", true, &CVkProto::OnReceiveSmth) - << VER_API); - } - - ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)iOldStatus, m_iStatus); -} - ///////////////////////////////////////////////////////////////////////////////////////// void CVkProto::OnOAuthAuthorize(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) @@ -1023,158 +978,6 @@ void CVkProto::PollingThread(void*) ///////////////////////////////////////////////////////////////////////////////////////// -INT_PTR __cdecl CVkProto::SvcSetStatusMsg(WPARAM, LPARAM) -{ - debugLogA("CVkProto::SvcSetStatusMsg"); - if (!IsOnline()) - return 1; - - MsgPopup(NULL, TranslateT("Loading status message from vk.com.\nThis may take some time."), TranslateT("Waiting...")); - - Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/status.get.json", true, &CVkProto::OnReceiveStatusMsg) - << VER_API); - - return 0; -} - -void CVkProto::OnReceiveStatusMsg(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) -{ - debugLogA("CVkProto::OnReceiveStatusMsg %d", reply->resultCode); - if (reply->resultCode != 200) - return; - - OnReceiveStatus(reply, pReq); - - ptrT ptszOldStatusMsg(db_get_tsa(NULL, m_szModuleName, "OldStatusMsg")); - CMString tszOldStatusMsg(ptszOldStatusMsg); - - ENTER_STRING pForm = { sizeof(pForm) }; - pForm.type = ESF_MULTILINE; - pForm.caption = TranslateT("Enter new status message"); - pForm.ptszInitVal = ptszOldStatusMsg; - pForm.szModuleName = m_szModuleName; - pForm.szDataPrefix = "statusmsgform_"; - - if (!EnterString(&pForm)) - return; - - CMString tszNewStatusMsg(ptrT(pForm.ptszResult)); - if (tszOldStatusMsg == tszNewStatusMsg) - return; - - RetrieveStatusMsg(tszNewStatusMsg); - setTString("OldStatusMsg", ptszOldStatusMsg); -} - - -void CVkProto::OnReceiveStatus(NETLIBHTTPREQUEST *reply, AsyncHttpRequest *pReq) -{ - debugLogA("CVkProto::OnReceiveStatus %d", reply->resultCode); - if (reply->resultCode != 200) - return; - JSONROOT pRoot; - JSONNODE *pResponse = CheckJsonResponse(pReq, reply, pRoot); - if (pResponse == NULL) - return; - - JSONNODE *pAudio = json_get(pResponse, "audio"); - if (pAudio == NULL) { - ptrT ptszStatusText(json_as_string(json_get(pResponse, "text"))); - if (ptszStatusText[0] != TCHAR(9835)) - setTString("OldStatusMsg", ptszStatusText); - } -} - -void CVkProto::RetrieveStatusMsg(const CMString &StatusMsg) -{ - debugLogA("CVkProto::RetrieveStatusMsg"); - if (!IsOnline()) - return; - - Push(new AsyncHttpRequest(this, REQUEST_GET, "/method/status.set.json", true, &CVkProto::OnReceiveSmth) - << TCHAR_PARAM("text", StatusMsg) - << VER_API); -} - -void CVkProto::RetrieveStatusMusic(const CMString &StatusMsg) -{ - debugLogA("CVkProto::RetrieveStatusMusic"); - if (!IsOnline() || m_iStatus == ID_STATUS_INVISIBLE || m_iMusicSendMetod == sendNone) - return; - - CMString code; - ptrT ptszOldStatusMsg(db_get_tsa(0, m_szModuleName, "OldStatusMsg")); - if (StatusMsg.IsEmpty()) { - if (m_iMusicSendMetod == sendBroadcastOnly) - code = "API.audio.setBroadcast();return null;"; - else { - CMString codeformat("API.status.set({text:\"%s\"});return null;"); - code.AppendFormat(codeformat, ptszOldStatusMsg); - } - m_bSetBroadcast = false; - } - else { - if (m_iMusicSendMetod == sendBroadcastOnly) { - CMString codeformat("var StatusMsg=\"%s\";var CntLmt=100;var OldMsg=API.status.get();" - "var Tracks=API.audio.search({\"q\":StatusMsg,\"count\":CntLmt,\"search_own\":1});" - "var Cnt=Tracks.count;if(Cnt>CntLmt){Cnt=CntLmt;}" - "if(Cnt==0){API.audio.setBroadcast();}" - "else{var i=0;var j=0;var Track=\" \";" - "while(iCntLmt){Cnt=CntLmt;}" - "if(Cnt==0){Track=\"♫ \"+StatusMsg;API.status.set({\"text\":Track});}" - "else{var i=0;var j=-1;" - "while(icbSize != sizeof(LISTENINGTOINFO)) - db_unset(NULL, m_szModuleName, "ListeningTo"); - else if (pliInfo->dwFlags & LTI_UNICODE) { - if (ServiceExists(MS_LISTENINGTO_GETPARSEDTEXT)) - tszListeningTo = ptrT((LPWSTR)CallService(MS_LISTENINGTO_GETPARSEDTEXT, (WPARAM)_T("%artist% - %title%"), (LPARAM)pliInfo)); - else - tszListeningTo.Format(_T("%s - %s"), - pliInfo->ptszArtist ? pliInfo->ptszArtist : _T(""), - pliInfo->ptszTitle ? pliInfo->ptszTitle : _T("")); - setTString("ListeningTo", tszListeningTo); - } - RetrieveStatusMusic(tszListeningTo); - return 0; -} - -///////////////////////////////////////////////////////////////////////////////////////// - INT_PTR __cdecl CVkProto::SvcAddAsFriend(WPARAM hContact, LPARAM) { debugLogA("CVkProto::SvcAddAsFriend"); diff --git a/protocols/VKontakte/vk_10.vcxproj b/protocols/VKontakte/vk_10.vcxproj index f0ccfad283..b4d79e134d 100644 --- a/protocols/VKontakte/vk_10.vcxproj +++ b/protocols/VKontakte/vk_10.vcxproj @@ -190,6 +190,7 @@ + diff --git a/protocols/VKontakte/vk_10.vcxproj.filters b/protocols/VKontakte/vk_10.vcxproj.filters index 83df172d18..c16159b9b3 100644 --- a/protocols/VKontakte/vk_10.vcxproj.filters +++ b/protocols/VKontakte/vk_10.vcxproj.filters @@ -60,6 +60,9 @@ Source Files + + Source Files + diff --git a/protocols/VKontakte/vk_12.vcxproj b/protocols/VKontakte/vk_12.vcxproj index 18acb8719e..f476303ed3 100644 --- a/protocols/VKontakte/vk_12.vcxproj +++ b/protocols/VKontakte/vk_12.vcxproj @@ -191,6 +191,7 @@ + diff --git a/protocols/VKontakte/vk_12.vcxproj.filters b/protocols/VKontakte/vk_12.vcxproj.filters index 41ceea8205..9d5568ee1a 100644 --- a/protocols/VKontakte/vk_12.vcxproj.filters +++ b/protocols/VKontakte/vk_12.vcxproj.filters @@ -60,6 +60,9 @@ Source Files + + Source Files + -- cgit v1.2.3