From 3e34adae711d9ddf79b4959143a696b6a403a522 Mon Sep 17 00:00:00 2001 From: George Hazan Date: Wed, 28 Dec 2016 20:30:46 +0300 Subject: first version that logs in successfully --- protocols/Discord/src/server.cpp | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) (limited to 'protocols/Discord/src/server.cpp') diff --git a/protocols/Discord/src/server.cpp b/protocols/Discord/src/server.cpp index 4b7c2afa13..62d2dfb17c 100644 --- a/protocols/Discord/src/server.cpp +++ b/protocols/Discord/src/server.cpp @@ -24,10 +24,30 @@ void CDiscordProto::RetrieveMyInfo() void CDiscordProto::SetServerStatus(int iStatus) { + if (!m_bOnline) + return; + int iOldStatus = m_iStatus; m_iStatus = iStatus; + ProtoBroadcastAck(NULL, ACKTYPE_STATUS, ACKRESULT_SUCCESS, (HANDLE)iOldStatus, m_iStatus); } -void CDiscordProto::OnReceiveToken(NETLIBHTTPREQUEST *pReply, AsyncHttpRequest *pReq) +void CDiscordProto::OnReceiveToken(NETLIBHTTPREQUEST *pReply, AsyncHttpRequest*) { - + if (pReply->resultCode != 200) { +LBL_Error: + ConnectionFailed(LOGINERR_WRONGPASSWORD); + return; + } + + JSONNode *root = json_parse(pReply->pData); + if (root == NULL) + goto LBL_Error; + + CMStringA szToken = root->at("token").as_mstring(); + if (szToken.IsEmpty()) + goto LBL_Error; + + m_szAccessToken = szToken.Detach(); + setString("AccessToken", m_szAccessToken); + OnLoggedIn(); } -- cgit v1.2.3