summaryrefslogtreecommitdiff
path: root/protocols/SkypeWeb/src/skype_messages.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/SkypeWeb/src/skype_messages.cpp')
-rw-r--r--protocols/SkypeWeb/src/skype_messages.cpp60
1 files changed, 46 insertions, 14 deletions
diff --git a/protocols/SkypeWeb/src/skype_messages.cpp b/protocols/SkypeWeb/src/skype_messages.cpp
index c4f9498885..869d7e75d5 100644
--- a/protocols/SkypeWeb/src/skype_messages.cpp
+++ b/protocols/SkypeWeb/src/skype_messages.cpp
@@ -3,21 +3,21 @@
/* MESSAGE RECEIVING */
// writing message/even into db
-int CSkypeProto::OnReceiveMessage(MCONTACT hContact, PROTORECVEVENT *pre)
+int CSkypeProto::OnReceiveMessage(const char *from, const char *convLink, time_t timeStamp, char *content)
{
- //return Proto_RecvMessage(hContact, pre);
- if (pre->szMessage == NULL)
- return NULL;
-
- DBEVENTINFO dbei = { sizeof(dbei) };
- dbei.szModule = GetContactProto(hContact);
- dbei.timestamp = pre->timestamp;
- dbei.flags = DBEF_UTF;
- dbei.eventType = pre->lParam;
- dbei.cbBlob = (DWORD)mir_strlen(pre->szMessage) + 1;
- dbei.pBlob = (PBYTE)pre->szMessage;
-
- return (INT_PTR)db_event_add(hContact, &dbei);
+ PROTORECVEVENT recv = { 0 };
+ recv.flags = PREF_UTF;
+ recv.timestamp = timeStamp;
+ recv.szMessage = content;
+ debugLogA("Incoming message from %s", ContactUrlToName(from));
+ if (IsMe(ContactUrlToName(from)))
+ {
+ recv.flags |= PREF_SENT;
+ MCONTACT hContact = GetContact(ContactUrlToName(convLink));
+ return ProtoChainRecvMsg(hContact, &recv);
+ }
+ MCONTACT hContact = GetContact(ContactUrlToName(from));
+ return ProtoChainRecvMsg(hContact, &recv);
}
/* MESSAGE SENDING */
@@ -26,4 +26,36 @@ int CSkypeProto::OnReceiveMessage(MCONTACT hContact, PROTORECVEVENT *pre)
int CSkypeProto::OnSendMessage(MCONTACT hContact, int flags, const char *szMessage)
{
return 0;
+}
+
+void CSkypeProto::OnMessageSent(const NETLIBHTTPREQUEST *response, void *arg)
+{
+ SendMessageParam *param = (SendMessageParam*)arg;
+
+ ptrT error(mir_tstrdup(TranslateT("Unknown error")));
+ ptrT username(getTStringA(param->hContact, "Skypename"));
+
+ if (response != NULL && (response->resultCode == 201 || response->resultCode == 200))
+ {
+ JSONROOT root(response->pData);
+ JSONNODE *node = json_get(root, "errorCode");
+ if (node)
+ error = json_as_string(node);
+ }
+
+ int status = ACKRESULT_FAILED;
+
+ if (error == NULL)
+ {
+ status = ACKRESULT_SUCCESS;
+ }
+ else
+ debugLog(_T("CSkypeProto::OnMessageSent: failed to send message for %s (%s)"), username, error);
+
+ ProtoBroadcastAck(
+ param->hContact,
+ ACKTYPE_MESSAGE,
+ status,
+ param->hMessage,
+ error);
} \ No newline at end of file