summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--protocols/Skype/src/skype_contacts.cpp21
-rw-r--r--protocols/Skype/src/skype_menus.cpp8
-rw-r--r--protocols/Skype/src/skype_proto.cpp7
3 files changed, 26 insertions, 10 deletions
diff --git a/protocols/Skype/src/skype_contacts.cpp b/protocols/Skype/src/skype_contacts.cpp
index 60d062f9cd..23a47699f3 100644
--- a/protocols/Skype/src/skype_contacts.cpp
+++ b/protocols/Skype/src/skype_contacts.cpp
@@ -787,9 +787,26 @@ HANDLE CSkypeProto::AddContactBySid(const wchar_t* sid, const wchar_t* nick, DWO
::CallService(MS_PROTO_ADDTOCONTACT, (WPARAM)hContact, (LPARAM)this->m_szModuleName);
this->SetSettingString(hContact, "sid", sid);
-
this->SetSettingString(hContact, "Nick", nick);
- //::DBWriteContactSettingWString(hContact, "CList", "MyHandle", displayName);
+ this->SetSettingByte(hContact, "Auth", 1);
+
+ CContact::Ref contact;
+ if (g_skype->GetContact(::mir_u2a(sid), contact))
+ {
+ contact.fetch();
+ bool result;
+ if (contact->IsMemberOfHardwiredGroup(CContactGroup::ALL_KNOWN_CONTACTS, result) && result)
+ {
+ CContactGroup::Ref group;
+ if (g_skype->GetHardwiredContactGroup(CContactGroup::ALL_KNOWN_CONTACTS, group))
+ {
+ group.fetch();
+ group->AddContact(contact);
+ }
+ }
+ }
+
+ this->UpdateContactProfile(hContact, contact);
if (flags & PALF_TEMPORARY)
{
diff --git a/protocols/Skype/src/skype_menus.cpp b/protocols/Skype/src/skype_menus.cpp
index 3ef76141ca..0b47f6882d 100644
--- a/protocols/Skype/src/skype_menus.cpp
+++ b/protocols/Skype/src/skype_menus.cpp
@@ -35,8 +35,8 @@ int CSkypeProto::OnPrebuildContactMenu(WPARAM wParam, LPARAM)
{
bool ctrlPressed = (GetKeyState(VK_CONTROL) & 0x8000) != 0;
- bool authNeed = this->GetSettingByte(hContact, "Auth");
- bool grantNeed = this->GetSettingByte(hContact, "Grant");
+ bool authNeed = this->GetSettingByte(hContact, "Auth") > 0;
+ bool grantNeed = this->GetSettingByte(hContact, "Grant") > 0;
sttEnableMenuItem( g_hContactMenuItems[CMI_AUTH_REQUEST], ctrlPressed || authNeed);
sttEnableMenuItem( g_hContactMenuItems[CMI_AUTH_GRANT], ctrlPressed || grantNeed);
@@ -80,7 +80,10 @@ int CSkypeProto::GrantAuth(WPARAM wParam, LPARAM lParam)
if (g_skype->GetContact(sid, contact))
{
if (contact->SetBuddyStatus(true))
+ {
+ this->DeleteSetting(hContact, "Auth");
this->DeleteSetting(hContact, "Grant");
+ }
}
return 0;
@@ -95,7 +98,6 @@ int CSkypeProto::RevokeAuth(WPARAM wParam, LPARAM lParam)
{
if (contact->SetBuddyStatus(false))
{
- //this->DeleteSetting(hContact, "Auth");
this->SetSettingByte(hContact, "Grant", 1);
}
this->contactList.remove_val(contact);
diff --git a/protocols/Skype/src/skype_proto.cpp b/protocols/Skype/src/skype_proto.cpp
index 9f1c6c8e27..87a1e758cf 100644
--- a/protocols/Skype/src/skype_proto.cpp
+++ b/protocols/Skype/src/skype_proto.cpp
@@ -38,10 +38,7 @@ CSkypeProto::~CSkypeProto()
HANDLE __cdecl CSkypeProto::AddToList(int flags, PROTOSEARCHRESULT* psr)
{
- //if (psr->cbSize != sizeof(PROTOSEARCHRESULT))
- return 0;
-
- return this->AddContactBySid(psr->id, psr->nick, flags);
+ return this->AddContactBySid(psr->id, psr->nick, 0);
}
HANDLE __cdecl CSkypeProto::AddToListByEvent(int flags, int iContact, HANDLE hDbEvent)
@@ -370,7 +367,7 @@ void __cdecl CSkypeProto::SignInAsync(void*)
fetch(g_skype->inbox);
g_skype->SetOnConversationAddedCallback(
(CSkype::OnConversationAdded)&CSkypeProto::OnConversationAdded, this);
- for (int i = 0 ; i < g_skype->inbox.size(); i++)
+ for (uint i = 0 ; i < g_skype->inbox.size(); i++)
{
g_skype->inbox[i]->SetOnMessageReceivedCallback(
(CConversation::OnMessageReceived)&CSkypeProto::OnOnMessageReceived, this);