diff options
-rw-r--r-- | protocols/FacebookRM/src/contacts.cpp | 3 | ||||
-rw-r--r-- | protocols/FacebookRM/src/db.h | 1 | ||||
-rw-r--r-- | protocols/FacebookRM/src/entities.h | 480 | ||||
-rw-r--r-- | protocols/FacebookRM/src/json.cpp | 4 | ||||
-rw-r--r-- | protocols/FacebookRM/src/process.cpp | 10 |
5 files changed, 257 insertions, 241 deletions
diff --git a/protocols/FacebookRM/src/contacts.cpp b/protocols/FacebookRM/src/contacts.cpp index 808bdef735..76939ee44b 100644 --- a/protocols/FacebookRM/src/contacts.cpp +++ b/protocols/FacebookRM/src/contacts.cpp @@ -212,6 +212,9 @@ MCONTACT FacebookProto::AddToContactList(facebook_user* fbu, ContactType type, b if (!fbu->real_name.empty()) SaveName(hContact, fbu); + if (!fbu->username.empty()) + setString(hContact, FACEBOOK_KEY_USERNAME, fbu->username.c_str()); + if (fbu->gender) setByte(hContact, "Gender", fbu->gender); diff --git a/protocols/FacebookRM/src/db.h b/protocols/FacebookRM/src/db.h index 9f28ee4211..834f7e7a74 100644 --- a/protocols/FacebookRM/src/db.h +++ b/protocols/FacebookRM/src/db.h @@ -30,6 +30,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>. #define FACEBOOK_KEY_SECOND_NAME "SecondName"
#define FACEBOOK_KEY_LAST_NAME "LastName"
#define FACEBOOK_KEY_NICK "Nick"
+#define FACEBOOK_KEY_USERNAME "Username"
#define FACEBOOK_KEY_PASS "Password"
#define FACEBOOK_KEY_DEVICE_ID "DeviceID"
#define FACEBOOK_KEY_AV_URL "AvatarURL"
diff --git a/protocols/FacebookRM/src/entities.h b/protocols/FacebookRM/src/entities.h index a99479bdab..977b9b635d 100644 --- a/protocols/FacebookRM/src/entities.h +++ b/protocols/FacebookRM/src/entities.h @@ -1,239 +1,241 @@ -/*
-
-Facebook plugin for Miranda Instant Messenger
-_____________________________________________
-
-Copyright © 2009-11 Michal Zelinka, 2011-13 Robert Pösel
-
-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, either version 2 of the License, or
-(at your option) any later version.
-
-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 <http://www.gnu.org/licenses/>.
-
-*/
-
-#pragma once
-
-struct facebook_user
-{
- MCONTACT handle;
-
- std::string user_id;
- std::string real_name;
- std::string nick;
-
- unsigned int status_id;
- unsigned int gender;
- DWORD last_active;
-
- std::string image_url;
-
- bool deleted;
- bool idle;
-
- ClientType client;
-
- facebook_user()
- {
- this->handle = NULL;
- this->user_id = this->real_name = this->nick = this->image_url = "";
- this->status_id = ID_STATUS_OFFLINE;
- this->gender = this->last_active = 0;
- this->deleted = this->idle = false;
- this->client = CLIENT_WEB;
- }
-
- facebook_user(facebook_user* fu)
- {
- this->handle = fu->handle;
- this->user_id = fu->user_id;
- this->real_name = fu->real_name;
- this->nick = fu->nick;
- this->status_id = fu->status_id;
- this->gender = fu->gender;
- this->last_active = fu->last_active;
- this->image_url = fu->image_url;
- this->deleted = fu->deleted;
- this->idle = fu->idle;
- this->client = fu->client;
- }
-
- TCHAR *getMirVer()
- {
- switch (this->client) {
- case CLIENT_APP:
- return _T(FACEBOOK_CLIENT_APP);
- case CLIENT_MESSENGER:
- return _T(FACEBOOK_CLIENT_MESSENGER);
- case CLIENT_OTHER:
- return _T(FACEBOOK_CLIENT_OTHER);
- case CLIENT_MOBILE:
- return _T(FACEBOOK_CLIENT_MOBILE);
- case CLIENT_WEB:
- default:
- return _T(FACEBOOK_CLIENT_WEB);
- }
- }
-};
-
-struct facebook_chatroom
-{
- std::tstring chat_name;
- std::tstring thread_id;
- std::map<std::string, std::string> participants;
-
- std::string message_readers;
-
- DWORD last_active;
-};
-
-struct facebook_message
-{
- std::string user_id;
- std::string sender_name;
- std::string message_text;
- std::string message_id;
- std::string thread_id;
- DWORD time;
- bool isIncoming;
- bool isUnread;
- bool isChat;
-
- int flag_;
-
- facebook_message()
- {
- this->user_id = this->message_text = this->sender_name = this->message_id = this->thread_id = "";
- this->time = 0;
- this->isUnread = this->isIncoming = true;
- this->isChat = false;
- this->flag_ = 0;
- }
-
- facebook_message(const facebook_message& msg)
- {
- this->user_id = msg.user_id;
- this->sender_name = msg.sender_name;
- this->message_text = msg.message_text;
- this->message_id = msg.message_id;
- this->message_id = msg.thread_id;
- this->time = msg.time;
- this->isIncoming = msg.isIncoming;
- this->isUnread = msg.isUnread;
- this->isChat = msg.isChat;
- this->flag_ = msg.flag_;
- }
-};
-
-struct facebook_notification
-{
- std::string user_id;
- std::string text;
- std::string link;
- std::string id;
- bool seen;
- HWND hWndPopup;
-
- facebook_notification()
- {
- this->user_id = this->text = this->link = this->id = "";
- this->seen = false;
- this->hWndPopup = NULL;
- }
-};
-
-struct facebook_newsfeed
-{
- std::string user_id;
- std::string title;
- std::string text;
- std::string link;
-
- facebook_newsfeed()
- {
- this->user_id = this->title = this->text = this->link = "";
- }
-};
-
-struct send_chat
-{
- send_chat(const std::string &chat_id,const std::string &msg) : chat_id(chat_id), msg(msg) {}
- std::string chat_id;
- std::string msg;
-};
-
-struct send_direct
-{
- send_direct(MCONTACT hContact,const std::string &msg, HANDLE msgid) : hContact(hContact), msg(msg), msgid(msgid) {}
- MCONTACT hContact;
- std::string msg;
- HANDLE msgid;
-};
-
-struct send_typing
-{
- send_typing(MCONTACT hContact,const int status) : hContact(hContact), status(status) {}
- MCONTACT hContact;
- int status;
-};
-
-struct popup_data
-{
- popup_data(FacebookProto *proto) : proto(proto) {}
- popup_data(FacebookProto *proto, std::string url) : proto(proto), url(url) {}
- FacebookProto *proto;
- std::string url;
- std::string notification_id;
-};
-
-struct status_data
-{
- status_data() {
- this->user_id = this->text = this->url = this->place = this->privacy = "";
- this->isPage = false;
- }
- std::string user_id;
- std::string text;
- std::string url;
- std::string place;
- std::string privacy;
- bool isPage;
- std::vector<facebook_user*> users;
-};
-
-struct wall_data
-{
- wall_data() {
- this->user_id = "";
- this->title = NULL;
- this->isPage = false;
- }
- wall_data(std::string user_id, TCHAR *title, bool isPage = false) : user_id(user_id), title(title), isPage(isPage) {}
- std::string user_id;
- TCHAR *title;
- bool isPage;
-};
-
-struct post_status_data {
- post_status_data(FacebookProto *proto) : proto(proto) {}
- post_status_data(FacebookProto *proto, wall_data *wall) : proto(proto) {
- this->walls.push_back(wall);
- }
- FacebookProto *proto;
- std::vector<wall_data*> walls;
-};
-
-struct open_url
-{
- open_url(TCHAR *browser, TCHAR *url) : browser(browser), url(url) {}
- TCHAR *browser;
- TCHAR *url;
-};
+/* + +Facebook plugin for Miranda Instant Messenger +_____________________________________________ + +Copyright � 2009-11 Michal Zelinka, 2011-13 Robert P�sel + +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, either version 2 of the License, or +(at your option) any later version. + +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 <http://www.gnu.org/licenses/>. + +*/ + +#pragma once + +struct facebook_user +{ + MCONTACT handle; + + std::string user_id; + std::string real_name; + std::string nick; + std::string username; + + unsigned int status_id; + unsigned int gender; + DWORD last_active; + + std::string image_url; + + bool deleted; + bool idle; + + ClientType client; + + facebook_user() + { + this->handle = NULL; + this->user_id = this->real_name = this->nick = this->username = this->image_url = ""; + this->status_id = ID_STATUS_OFFLINE; + this->gender = this->last_active = 0; + this->deleted = this->idle = false; + this->client = CLIENT_WEB; + } + + facebook_user(facebook_user* fu) + { + this->handle = fu->handle; + this->user_id = fu->user_id; + this->real_name = fu->real_name; + this->nick = fu->nick; + this->username = fu->username; + this->status_id = fu->status_id; + this->gender = fu->gender; + this->last_active = fu->last_active; + this->image_url = fu->image_url; + this->deleted = fu->deleted; + this->idle = fu->idle; + this->client = fu->client; + } + + TCHAR *getMirVer() + { + switch (this->client) { + case CLIENT_APP: + return _T(FACEBOOK_CLIENT_APP); + case CLIENT_MESSENGER: + return _T(FACEBOOK_CLIENT_MESSENGER); + case CLIENT_OTHER: + return _T(FACEBOOK_CLIENT_OTHER); + case CLIENT_MOBILE: + return _T(FACEBOOK_CLIENT_MOBILE); + case CLIENT_WEB: + default: + return _T(FACEBOOK_CLIENT_WEB); + } + } +}; + +struct facebook_chatroom +{ + std::tstring chat_name; + std::tstring thread_id; + std::map<std::string, std::string> participants; + + std::string message_readers; + + DWORD last_active; +}; + +struct facebook_message +{ + std::string user_id; + std::string sender_name; + std::string message_text; + std::string message_id; + std::string thread_id; + DWORD time; + bool isIncoming; + bool isUnread; + bool isChat; + + int flag_; + + facebook_message() + { + this->user_id = this->message_text = this->sender_name = this->message_id = this->thread_id = ""; + this->time = 0; + this->isUnread = this->isIncoming = true; + this->isChat = false; + this->flag_ = 0; + } + + facebook_message(const facebook_message& msg) + { + this->user_id = msg.user_id; + this->sender_name = msg.sender_name; + this->message_text = msg.message_text; + this->message_id = msg.message_id; + this->message_id = msg.thread_id; + this->time = msg.time; + this->isIncoming = msg.isIncoming; + this->isUnread = msg.isUnread; + this->isChat = msg.isChat; + this->flag_ = msg.flag_; + } +}; + +struct facebook_notification +{ + std::string user_id; + std::string text; + std::string link; + std::string id; + bool seen; + HWND hWndPopup; + + facebook_notification() + { + this->user_id = this->text = this->link = this->id = ""; + this->seen = false; + this->hWndPopup = NULL; + } +}; + +struct facebook_newsfeed +{ + std::string user_id; + std::string title; + std::string text; + std::string link; + + facebook_newsfeed() + { + this->user_id = this->title = this->text = this->link = ""; + } +}; + +struct send_chat +{ + send_chat(const std::string &chat_id,const std::string &msg) : chat_id(chat_id), msg(msg) {} + std::string chat_id; + std::string msg; +}; + +struct send_direct +{ + send_direct(MCONTACT hContact,const std::string &msg, HANDLE msgid) : hContact(hContact), msg(msg), msgid(msgid) {} + MCONTACT hContact; + std::string msg; + HANDLE msgid; +}; + +struct send_typing +{ + send_typing(MCONTACT hContact,const int status) : hContact(hContact), status(status) {} + MCONTACT hContact; + int status; +}; + +struct popup_data +{ + popup_data(FacebookProto *proto) : proto(proto) {} + popup_data(FacebookProto *proto, std::string url) : proto(proto), url(url) {} + FacebookProto *proto; + std::string url; + std::string notification_id; +}; + +struct status_data +{ + status_data() { + this->user_id = this->text = this->url = this->place = this->privacy = ""; + this->isPage = false; + } + std::string user_id; + std::string text; + std::string url; + std::string place; + std::string privacy; + bool isPage; + std::vector<facebook_user*> users; +}; + +struct wall_data +{ + wall_data() { + this->user_id = ""; + this->title = NULL; + this->isPage = false; + } + wall_data(std::string user_id, TCHAR *title, bool isPage = false) : user_id(user_id), title(title), isPage(isPage) {} + std::string user_id; + TCHAR *title; + bool isPage; +}; + +struct post_status_data { + post_status_data(FacebookProto *proto) : proto(proto) {} + post_status_data(FacebookProto *proto, wall_data *wall) : proto(proto) { + this->walls.push_back(wall); + } + FacebookProto *proto; + std::vector<wall_data*> walls; +}; + +struct open_url +{ + open_url(TCHAR *browser, TCHAR *url) : browser(browser), url(url) {} + TCHAR *browser; + TCHAR *url; +}; diff --git a/protocols/FacebookRM/src/json.cpp b/protocols/FacebookRM/src/json.cpp index f29913600c..331e473fd3 100644 --- a/protocols/FacebookRM/src/json.cpp +++ b/protocols/FacebookRM/src/json.cpp @@ -174,7 +174,7 @@ void parseUser(JSONNODE *it, facebook_user *fbu) JSONNODE *name = json_get(it, "name");
JSONNODE *thumbSrc = json_get(it, "thumbSrc");
JSONNODE *gender = json_get(it, "gender");
- JSONNODE *vanity = json_get(it, "vanity"); // username (this ISN'T nickname, but we will use it that way - but it's ugly and noone will use it)
+ JSONNODE *vanity = json_get(it, "vanity"); // username
//JSONNODE *uri = json_get(it, "uri"); // profile url
//JSONNODE *is_friend = json_get(it, "is_friend"); // e.g. "True"
//JSONNODE *type = json_get(it, "type"); // e.g. "friend" (classic contact) or "user" (disabled/deleted account)
@@ -185,7 +185,7 @@ void parseUser(JSONNODE *it, facebook_user *fbu) if (thumbSrc)
fbu->image_url = utils::text::slashu_to_utf8(utils::text::special_expressions_decode(json_as_pstring(thumbSrc)));
if (vanity)
- fbu->nick = utils::text::slashu_to_utf8(utils::text::special_expressions_decode(json_as_pstring(vanity)));
+ fbu->username = utils::text::slashu_to_utf8(utils::text::special_expressions_decode(json_as_pstring(vanity)));
if (gender)
switch (json_as_int(gender)) {
diff --git a/protocols/FacebookRM/src/process.cpp b/protocols/FacebookRM/src/process.cpp index 7c4584f5f0..2f13369f5a 100644 --- a/protocols/FacebookRM/src/process.cpp +++ b/protocols/FacebookRM/src/process.cpp @@ -210,6 +210,16 @@ void FacebookProto::ProcessFriendList(void*) SaveName(hContact, fbu); } + // Update username + ptrA username(getStringA(hContact, FACEBOOK_KEY_USERNAME)); + if (!username || strcmp(username, fbu->username.c_str())) { + if (!fbu->username.empty()) + setString(hContact, FACEBOOK_KEY_USERNAME, fbu->username.c_str()); + else + delSetting(hContact, FACEBOOK_KEY_USERNAME); + } + + // Update contact type if (getByte(hContact, FACEBOOK_KEY_CONTACT_TYPE, 0) != CONTACT_FRIEND) { setByte(hContact, FACEBOOK_KEY_CONTACT_TYPE, CONTACT_FRIEND); // TODO: remove that popup and use "Contact added you" event? |