Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/EionRobb/skype4pidgin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEion Robb <eion@robbmob.com>2014-12-02 13:34:19 +0300
committerEion Robb <eion@robbmob.com>2014-12-02 13:34:19 +0300
commit2676be5e429189b10a186502eaf05174a585e6aa (patch)
tree83e7fd531fb54a498e18ad81096347c8b0c24c94
parentcf09cbc7717364e74232c7f858c3670aaa44b6fb (diff)
SkypeWeb : Support receiving picture messages and video mail messages
-rw-r--r--skypeweb/libskypeweb.h1
-rw-r--r--skypeweb/skypeweb_connection.c2
-rw-r--r--skypeweb/skypeweb_contacts.c177
-rw-r--r--skypeweb/skypeweb_contacts.h3
-rw-r--r--skypeweb/skypeweb_messages.c38
5 files changed, 196 insertions, 25 deletions
diff --git a/skypeweb/libskypeweb.h b/skypeweb/libskypeweb.h
index 5d7ed18..14efc9f 100644
--- a/skypeweb/libskypeweb.h
+++ b/skypeweb/libskypeweb.h
@@ -78,6 +78,7 @@
#define SKYPEWEB_CONTACTS_HOST "api.skype.com"
#define SKYPEWEB_MESSAGES_HOST "client-s.gateway.messenger.live.com"
#define SKYPEWEB_LOGIN_HOST "login.skype.com"
+#define SKYPEWEB_VIDEOMAIL_HOST "vm.skype.com"
typedef struct _SkypeWebAccount SkypeWebAccount;
typedef struct _SkypeWebBuddy SkypeWebBuddy;
diff --git a/skypeweb/skypeweb_connection.c b/skypeweb/skypeweb_connection.c
index 933cceb..8d1379b 100644
--- a/skypeweb/skypeweb_connection.c
+++ b/skypeweb/skypeweb_connection.c
@@ -567,7 +567,7 @@ skypeweb_post_or_get(SkypeWebAccount *sa, SkypeWebMethod method,
g_string_append_printf(request, "Content-length: %zu\r\n", strlen(postdata));
}
- if (g_str_equal(host, SKYPEWEB_CONTACTS_HOST)) {
+ if (g_str_equal(host, SKYPEWEB_CONTACTS_HOST) || g_str_equal(host, SKYPEWEB_VIDEOMAIL_HOST)) {
g_string_append_printf(request, "X-Skypetoken: %s\r\n", sa->skype_token);
g_string_append(request, "X-Stratus-Caller: swx-skype.com\r\n");
g_string_append(request, "X-Stratus-Request: abcd1234\r\n");
diff --git a/skypeweb/skypeweb_contacts.c b/skypeweb/skypeweb_contacts.c
index 1b487f4..87e39e9 100644
--- a/skypeweb/skypeweb_contacts.c
+++ b/skypeweb/skypeweb_contacts.c
@@ -5,6 +5,8 @@
#include "skypeweb_messages.h"
#include "skypeweb_util.h"
+#include <ft.h>
+
static guint active_icon_downloads = 0;
static void
@@ -67,6 +69,160 @@ skypeweb_get_icon(PurpleBuddy *buddy)
}
+static void
+skypeweb_got_imagemessage(PurpleUtilFetchUrlData *url_data, gpointer user_data, const gchar *url_text, gsize len, const gchar *error_message)
+{
+ PurpleConversation *conv = user_data;
+ gint icon_id;
+ gchar *msg_tmp;
+
+ if (!url_text || !url_text[0] || url_text[0] == '{')
+ return;
+
+ icon_id = purple_imgstore_add_with_id((gpointer)url_text, len, NULL);
+
+ msg_tmp = g_strdup_printf("<img id='%d'>", icon_id);
+ purple_conversation_write(conv, conv->name, msg_tmp, PURPLE_MESSAGE_SYSTEM, time(NULL));
+ g_free(msg_tmp);
+
+ purple_imgstore_unref_by_id(icon_id);
+}
+
+void
+skypeweb_download_uri_to_conv(SkypeWebAccount *sa, const gchar *uri, PurpleConversation *conv)
+{
+ gchar *url;
+ gchar *clean_uri;
+ gchar *headers;
+
+ clean_uri = purple_strreplace(uri, "//", "/");
+ url = g_strconcat(clean_uri, "/views/imgo", NULL);
+
+ headers = g_strdup_printf("GET %s HTTP/1.0\r\n"
+ "Connection: close\r\n"
+ "Accept: image/*\r\n"
+ "Cookie: skypetoken_asm=%s\r\n"
+ "Host: api.asm.skype.com\r\n"
+ "\r\n\r\n",
+ strchr(url, '/'), sa->skype_token);
+
+ purple_util_fetch_url_request(sa->account, url, TRUE, NULL, FALSE, headers, FALSE, -1, skypeweb_got_imagemessage, conv);
+
+ g_free(headers);
+ g_free(url);
+ g_free(clean_uri);
+}
+
+
+static void
+skypeweb_got_vm_file(PurpleUtilFetchUrlData *url_data, gpointer user_data, const gchar *url_text, gsize len, const gchar *error_message)
+{
+ PurpleXfer *xfer = user_data;
+
+ purple_xfer_write(xfer, (guchar *)url_text, len);
+}
+
+static void
+skypeweb_init_vm_download(PurpleXfer *xfer)
+{
+ JsonObject *file = xfer->data;
+ gint64 fileSize;
+ const gchar *url;
+
+ fileSize = json_object_get_int_member(file, "fileSize");
+ url = json_object_get_string_member(file, "url");
+
+ purple_xfer_set_completed(xfer, FALSE);
+ purple_util_fetch_url_request(xfer->account, url, TRUE, NULL, FALSE, NULL, FALSE, fileSize, skypeweb_got_vm_file, xfer);
+
+ json_object_unref(file);
+}
+
+static void
+skypeweb_cancel_vm_download(PurpleXfer *xfer)
+{
+ JsonObject *file = xfer->data;
+ json_object_unref(file);
+}
+
+static void
+skypeweb_got_vm_download_info(SkypeWebAccount *sa, JsonNode *node, gpointer user_data)
+{
+ PurpleConversation *conv = user_data;
+ PurpleXfer *xfer;
+ JsonObject *obj, *file;
+ JsonArray *files;
+ gint64 fileSize;
+ const gchar *url, *assetId, *status;
+ gchar *filename;
+
+ obj = json_node_get_object(node);
+ files = json_object_get_array_member(obj, "files");
+ file = json_array_get_object_element(files, 0);
+ if (file != NULL) {
+ status = json_object_get_string_member(file, "status");
+ if (status && g_str_equal(status, "ok")) {
+ assetId = json_object_get_string_member(obj, "assetId");
+ fileSize = json_object_get_int_member(file, "fileSize");
+ url = json_object_get_string_member(file, "url");
+
+ filename = g_strconcat(assetId, ".mp4", NULL);
+
+ xfer = purple_xfer_new(sa->account, PURPLE_XFER_RECEIVE, conv->name);
+ purple_xfer_set_size(xfer, fileSize);
+ purple_xfer_set_filename(xfer, filename);
+ json_object_ref(file);
+ xfer->data = file;
+ purple_xfer_set_init_fnc(xfer, skypeweb_init_vm_download);
+ purple_xfer_set_cancel_recv_fnc(xfer, skypeweb_cancel_vm_download);
+ purple_xfer_add(xfer);
+
+ g_free(filename);
+ } else if (status && g_str_equal(status, "running")) {
+ //skypeweb_download_video_message(sa, sid??????, conv);
+ }
+ }
+}
+
+static void
+skypeweb_got_vm_info(SkypeWebAccount *sa, JsonNode *node, gpointer user_data)
+{
+ PurpleConversation *conv = user_data;
+ JsonObject *obj, *response, *media_stream;
+ const gchar *filename;
+
+ obj = json_node_get_object(node);
+ response = json_object_get_object_member(obj, "response");
+ media_stream = json_object_get_object_member(response, "media_stream");
+ filename = json_object_get_string_member(media_stream, "filename");
+
+ if (filename != NULL) {
+ // Need to keep retrying this url until it comes back with status:ok
+ gchar *url = g_strdup_printf("/vod/api-create?assetId=%s&profile=mp4-vm", purple_url_encode(filename));
+ skypeweb_post_or_get(sa, SKYPEWEB_METHOD_GET | SKYPEWEB_METHOD_SSL, "media.vm.skype.com", url, NULL, skypeweb_got_vm_download_info, conv, TRUE);
+ g_free(url);
+ }
+
+}
+
+void
+skypeweb_download_video_message(SkypeWebAccount *sa, const gchar *sid, PurpleConversation *conv)
+{
+ //1f25364917961071cfbd62c3493e5b4d
+
+ //https://vm.skype.com/users/bigbrownchunx/video_mails/1f25364917961071cfbd62c3493e5b4d
+ //X-Skypetoken
+ gchar *url, *username_encoded;
+
+ username_encoded = g_strdup(purple_url_encode(sa->username));
+ url = g_strdup_printf("/users/%s/video_mails/%s", username_encoded, purple_url_encode(sid));
+
+ skypeweb_post_or_get(sa, SKYPEWEB_METHOD_GET | SKYPEWEB_METHOD_SSL, SKYPEWEB_VIDEOMAIL_HOST, url, NULL, skypeweb_got_vm_info, conv, TRUE);
+
+ g_free(url);
+ g_free(username_encoded);
+
+}
static void
@@ -395,21 +551,6 @@ skypeweb_get_friend_list_cb(SkypeWebAccount *sa, JsonNode *node, gpointer user_d
GSList *users_to_fetch = NULL;
guint index, length;
- /* {
- "skypename": "eionrobb",
- "fullname": "Eion Robb",
- "authorized": true,
- "blocked": false,
- "display_name": "eionrobb",
- "pstn_number": null,
- "phone1": null,
- "phone1_label": null,
- "phone2": null,
- "phone2_label": null,
- "phone3": null,
- "phone3_label": null
-} */
-
friends = json_node_get_array(node);
length = json_array_get_length(friends);
@@ -510,13 +651,7 @@ skypeweb_got_authrequests(SkypeWebAccount *sa, JsonNode *node, gpointer user_dat
guint index, length;
requests = json_node_get_array(node);
- /* [{
- "event_time": "2014-10-21 18:53:53.763883",
- "sender": "gretike1984",
- "greeting": "Kedves Eion Robb! Szeretn\u00e9lek felvenni a partnerlist\u00e1mra."
- }] */
length = json_array_get_length(requests);
-
for(index = 0; index < length; index++)
{
JsonObject *request = json_array_get_object_element(requests, index);
diff --git a/skypeweb/skypeweb_contacts.h b/skypeweb/skypeweb_contacts.h
index a8ff508..5111c01 100644
--- a/skypeweb/skypeweb_contacts.h
+++ b/skypeweb/skypeweb_contacts.h
@@ -5,6 +5,9 @@
#include "libskypeweb.h"
void skypeweb_get_icon(PurpleBuddy *buddy);
+void skypeweb_download_uri_to_conv(SkypeWebAccount *sa, const gchar *uri, PurpleConversation *conv);
+void skypeweb_download_video_message(SkypeWebAccount *sa, const gchar *sid, PurpleConversation *conv);
+
void skypeweb_search_users(PurplePluginAction *action);
void skypeweb_get_friend_profiles(SkypeWebAccount *sa, GSList *contacts);
diff --git a/skypeweb/skypeweb_messages.c b/skypeweb/skypeweb_messages.c
index 28afb19..d763b4c 100644
--- a/skypeweb/skypeweb_messages.c
+++ b/skypeweb/skypeweb_messages.c
@@ -1,6 +1,7 @@
#include "skypeweb_messages.h"
#include "skypeweb_util.h"
#include "skypeweb_connection.h"
+#include "skypeweb_contacts.h"
static void
process_userpresence_resource(SkypeWebAccount *sa, JsonObject *resource)
@@ -37,6 +38,7 @@ process_message_resource(SkypeWebAccount *sa, JsonObject *resource)
const gchar *conversationLink = json_object_get_string_member(resource, "conversationLink");
time_t composetimestamp = purple_str_to_time(composetime, TRUE, NULL, NULL, NULL);
gchar **messagetype_parts;
+ PurpleConversation *conv;
messagetype_parts = g_strsplit(messagetype, "/", -1);
@@ -44,7 +46,6 @@ process_message_resource(SkypeWebAccount *sa, JsonObject *resource)
if (strstr(conversationLink, "/19:")) {
const gchar *chatname, *topic;
- PurpleConversation *conv;
chatname = skypeweb_thread_url_to_name(conversationLink);
conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_CHAT, chatname, sa->account);
@@ -128,7 +129,7 @@ process_message_resource(SkypeWebAccount *sa, JsonObject *resource)
}
if (g_str_equal(sa->username, from)) {
from = skypeweb_contact_url_to_name(conversationLink);
- PurpleConversation *conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_IM, from, sa->account);
+ conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_IM, from, sa->account);
if (conv == NULL)
{
conv = purple_conversation_new(PURPLE_CONV_TYPE_IM, sa->account, from);
@@ -138,6 +139,37 @@ process_message_resource(SkypeWebAccount *sa, JsonObject *resource)
serv_got_im(sa->pc, from, html, PURPLE_MESSAGE_RECV, composetimestamp);
}
g_free(html);
+ } else if (g_str_equal(messagetype, "RichText/UriObject")) {
+ xmlnode *blob = xmlnode_from_str(content, -1);
+ const gchar *uri = xmlnode_get_attrib(blob, "uri");
+
+ if (g_str_equal(sa->username, from)) {
+ from = skypeweb_contact_url_to_name(conversationLink);
+ }
+ conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_IM, from, sa->account);
+ if (conv == NULL)
+ {
+ conv = purple_conversation_new(PURPLE_CONV_TYPE_IM, sa->account, from);
+ }
+
+ skypeweb_download_uri_to_conv(sa, uri, conv);
+ xmlnode_free(blob);
+ } else if (g_str_equal(messagetype, "Event/SkypeVideoMessage")) {
+ xmlnode *blob = xmlnode_from_str(content, -1);
+ const gchar *sid = xmlnode_get_attrib(blob, "sid");
+
+ if (g_str_equal(sa->username, from)) {
+ from = skypeweb_contact_url_to_name(conversationLink);
+ }
+ conv = purple_find_conversation_with_account(PURPLE_CONV_TYPE_IM, from, sa->account);
+ if (conv == NULL)
+ {
+ conv = purple_conversation_new(PURPLE_CONV_TYPE_IM, sa->account, from);
+ }
+
+ //skypeweb_download_video_message(sa, sid, conv);
+ serv_got_im(sa->pc, from, content, PURPLE_MESSAGE_RECV | PURPLE_MESSAGE_SYSTEM, composetimestamp);
+ xmlnode_free(blob);
} else {
purple_debug_warning("skypeweb", "Unhandled message resource messagetype '%s'\n", messagetype);
}
@@ -148,7 +180,7 @@ process_message_resource(SkypeWebAccount *sa, JsonObject *resource)
time_t arrivaltimestamp = purple_str_to_time(originalarrivaltime, TRUE, NULL, NULL, NULL);
PUT "/v1/users/ME/conversations/%s/properties?name=consumptionhorizon", convname
- g_strdup_printf("{\"consumptionhorizon\":\"%" G_GINT64_FORMAT ";%" G_GINT64_FORMAT ";%s\"}", arrivaltimestamp*1000, skypeweb_get_js_time(), clientmessageid)
+ g_strdup_printf("{\"consumptionhorizon\":\"%" G_GINT64_FORMAT ";%" G_GINT64_FORMAT ";%s\"}", ((gint64)arrivaltimestamp)*1000, skypeweb_get_js_time(), clientmessageid)
}*/
g_strfreev(messagetype_parts);