* Adium is the legal property of its developers, whose names are listed in the copyright file included * with this source distribution. * 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, * write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #import "adiumPurpleAccounts.h" #import <Adium/AIContactControllerProtocol.h> #import <Adium/AdiumAuthorization.h> /* A buddy we already have added us to their buddy list. */ static void adiumPurpleAccountNotifyAdded(PurpleAccount *account, const char *remote_user, const char *identifier, const char *alias, static void adiumPurpleAccountStatusChanged(PurpleAccount *account, PurpleStatus *status) /* Someone we don't have on our list added us. Will prompt to add them. */ static void adiumPurpleAccountRequestAdd(PurpleAccount *account, const char *remote_user, const char *accountID, const char *alias, #warning Something is better than nothing, but we should display a message which includes message and alias /* purple displays something like "Add remote_user to your list? remote_user (alias) has made accountID his buddy." */ [accountLookup(account) requestAddContactWithUID:[NSString stringWithUTF8String:remote_user]]; * @brief A contact requests authorization to add us to her list * @param account PurpleAccount being added * @param remote_user The UID of the contact * @param anId May be NULL; an ID associated with the authorization request (?) * @param alias The contact's alias. May be NULL. * @param mess A message accompanying the request. May be NULL. * @param authorize_cb Call if authorization granted * @param deny_cb Call if authroization denied * @param user_data Data for the process; be sure to return it in the callback static void *adiumPurpleAccountRequestAuthorize(PurpleAccount *account, const char *remote_user, const char *anId, const char *alias, const char *message, gboolean on_list, PurpleAccountRequestAuthorizationCb authorize_cb, PurpleAccountRequestAuthorizationCb deny_cb, NSMutableDictionary *infoDict = [NSMutableDictionary dictionaryWithObjectsAndKeys: [NSString stringWithUTF8String:remote_user], @"Remote Name", [NSValue valueWithPointer:authorize_cb], @"authorizeCB", [NSValue valueWithPointer:deny_cb], @"denyCB", [NSValue valueWithPointer:user_data], @"userData", if (message && strlen(message)) [infoDict setObject:[NSString stringWithUTF8String:message] forKey:@"Reason"]; if (alias && strlen(alias)) [infoDict setObject:[NSString stringWithUTF8String:alias] forKey:@"Alias"]; //Note that CBPurpleAccount will retain ownership of this object to keep it around for us in case adiumPurpleAccountRequestClose() is called. return [accountLookup(account) authorizationRequestWithDict:infoDict]; static void adiumPurpleAccountRequestClose(void *ui_handle) id ourHandle = (id)ui_handle; // Remove the request; we're passing the pointer to it. [AdiumAuthorization closeAuthorizationForUIHandle:ourHandle]; void adiumPurpleAccountRegisterCb(PurpleAccount *account, gboolean succeeded, void *user_data) { id ourHandle = user_data; if([ourHandle respondsToSelector:@selector(purpleAccountRegistered:)]) [ourHandle purpleAccountRegistered:(succeeded ? YES : NO)]; static PurpleAccountUiOps adiumPurpleAccountOps = { &adiumPurpleAccountNotifyAdded, &adiumPurpleAccountStatusChanged, &adiumPurpleAccountRequestAdd, &adiumPurpleAccountRequestAuthorize, &adiumPurpleAccountRequestClose, /* _purple_reserved 1-4 */ PurpleAccountUiOps *adium_purple_accounts_get_ui_ops(void) return &adiumPurpleAccountOps;