/* UserinfoEx plugin for Miranda IM Copyright: � 2006-2010 DeathAxe, Yasnovidyashii, Merlin, K. Romanov, Kreol 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. */ #include "commonheaders.h" static HANDLE ghMenuItem = NULL; static HANDLE ghExtraIconDef = INVALID_HANDLE_VALUE; static HANDLE ghExtraIconSvc = INVALID_HANDLE_VALUE; static HANDLE hChangedHook = NULL; static HANDLE hApplyIconHook = NULL; static HANDLE hRebuildIconsHook = NULL; /** * This function reads the email address of the contact. * * @param hContact - handle to contact to read email from * * @retval email address * @retval NULL, if contact does not provide any email address **/ static LPSTR Get(HANDLE hContact) { // ignore owner if (hContact != NULL) { LPCSTR pszProto = DB::Contact::Proto(hContact); if (pszProto != NULL) { LPCSTR e[2][4] = { { SET_CONTACT_EMAIL, SET_CONTACT_EMAIL0, SET_CONTACT_EMAIL1, "Mye-mail0"}, { SET_CONTACT_COMPANY_EMAIL, SET_CONTACT_COMPANY_EMAIL0, SET_CONTACT_COMPANY_EMAIL1, "MyCompanye-mail0"} }; int i, j; LPSTR pszEMail; for (i = 0; i < 2; i++) { for (j = 0; j < 4; j++) { pszEMail = DB::Setting::GetAStringEx(hContact, USERINFO, pszProto, e[i][j]); if (pszEMail) { if (strchr(pszEMail, '@')) { return pszEMail; } mir_free(pszEMail); } } } } } return NULL; } /** * Service function that sends emails * * @param wParam - handle to contact to send an email to * @param lParam - not used * * @retval 0 if email was sent * @retval 1 if no email can be sent **/ static INT_PTR MenuCommand(WPARAM wParam,LPARAM lParam) { int result; LPSTR val = NULL; __try { val = Get((HANDLE) wParam); if (val) { LPSTR szUrl; INT_PTR len; len = mir_strlen(val) + strlen("mailto:"); szUrl = (LPSTR)_alloca(len + 1); mir_snprintf(szUrl, len + 1, "mailto:%s", val); mir_free(val); result = CallService(MS_UTILS_OPENURL, 1, (LPARAM)szUrl); } else { result = 1; MsgBox((HWND)lParam, MB_OK, LPGENT("Send e-mail"), NULL, LPGENT("Memory allocation error!")); } } __except(GetExceptionCode()==EXCEPTION_ACCESS_VIOLATION ? EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH) { if (val) { mir_free(val); } result = 1; MsgErr((HWND)lParam, LPGENT("Memory allocation error!")); } return result; } /*********************************************************************************************************** * Event Handler functions ***********************************************************************************************************/ /** * Notification handler for clist extra icons to be applied for a contact. * * @param wParam - handle to the contact whose extra icon is to apply * @param lParam - not used **/ static int OnCListApplyIcons(WPARAM wParam, LPARAM lParam) { LPSTR val = Get((HANDLE)wParam); ExtraIcon_SetIcon(ghExtraIconSvc, (HANDLE)wParam, (val) ? ICO_BTN_EMAIL: 0); mir_free(val); return 0; } /** * Notification handler for changed contact settings * * @param wParam - (HANDLE)hContact * @param lParam - (DBCONTACTWRITESETTING*)pdbcws **/ static int OnContactSettingChanged(HANDLE hContact, DBCONTACTWRITESETTING* pdbcws) { if (hContact && pdbcws && pdbcws->szSetting && ((pdbcws->value.type & DBVTF_VARIABLELENGTH) || (pdbcws->value.type == DBVT_DELETED)) && (!mir_strncmp(pdbcws->szSetting, SET_CONTACT_EMAIL, 6) || !mir_strncmp(pdbcws->szSetting, SET_CONTACT_COMPANY_EMAIL, 13) || !mir_strncmp(pdbcws->szSetting, "mye-mail0", 9))) { OnCListApplyIcons((WPARAM)hContact, 0); } return 0; } /** * This function decides whether to show menuitem for sending emails or not. * * @param wParam - handle to contact to send an email to * @param lParam - not used * * @return always 0 **/ static int OnPreBuildMenu(WPARAM wParam, LPARAM lParam) { CLISTMENUITEM mi = { sizeof(mi) }; mi.flags = CMIM_FLAGS; LPSTR val = Get((HANDLE)wParam); if (val) mir_free(val); else mi.flags = CMIM_FLAGS | CMIF_HIDDEN; CallService(MS_CLIST_MODIFYMENUITEM, (WPARAM)ghMenuItem, (LPARAM)&mi); return 0; } /*********************************************************************************************************** * public Module Interface functions ***********************************************************************************************************/ /** * This function enables or disables menuitems. **/ void SvcEMailRebuildMenu() { static HANDLE hPrebuildMenuHook = NULL; if (DB::Setting::GetByte(SET_EXTENDED_EMAILSERVICE, TRUE)) { if (!hPrebuildMenuHook) { hPrebuildMenuHook = HookEvent(ME_CLIST_PREBUILDCONTACTMENU, OnPreBuildMenu); } if (!ghMenuItem) { // insert contact menuitem CLISTMENUITEM mi = { sizeof(mi) }; mi.position = -2000010000; mi.hIcon = IcoLib_GetIcon(ICO_BTN_EMAIL); mi.pszName = "&E-mail"; mi.pszService = MS_EMAIL_SENDEMAIL; ghMenuItem = Menu_AddContactMenuItem(&mi); } } else { if (hPrebuildMenuHook) { UnhookEvent(ME_CLIST_PREBUILDCONTACTMENU); hPrebuildMenuHook = NULL; } if (ghMenuItem) { CallService(MS_CLIST_REMOVECONTACTMENUITEM, (WPARAM)ghMenuItem, NULL); ghMenuItem = NULL; } } } /** * Force all icons to be reloaded. * * @param wParam - handle to the contact whose extra icon is to apply * @param lParam - not used **/ void SvcEMailApplyCListIcons() { HANDLE hContact; //walk through all the contacts stored in the DB for (hContact = DB::Contact::FindFirst(); hContact != NULL; hContact = DB::Contact::FindNext(hContact)) { OnCListApplyIcons((WPARAM)hContact, 0); } } /** * Enable or disable the replacement of clist extra icons. * * @param bEnable - determines whether icons are enabled or not * @param bUpdateDB - if true the database setting is updated, too. **/ void SvcEMailEnableExtraIcons(BYTE bEnable, BYTE bUpdateDB) { if (bUpdateDB) DB::Setting::WriteByte(SET_CLIST_EXTRAICON_EMAIL, bEnable); if (bEnable) { // E-mail checkt // hook events if (hChangedHook == NULL) hChangedHook = HookEvent(ME_DB_CONTACT_SETTINGCHANGED, (MIRANDAHOOK)OnContactSettingChanged); if (hApplyIconHook == NULL) hApplyIconHook = HookEvent(ME_CLIST_EXTRA_IMAGE_APPLY, OnCListApplyIcons); if (ghExtraIconSvc == INVALID_HANDLE_VALUE) ghExtraIconSvc = ExtraIcon_Register("email", LPGEN("E-mail (uinfoex)"), ICO_BTN_EMAIL); } else { // E-mail uncheckt if (hChangedHook) { UnhookEvent(hChangedHook); hChangedHook = NULL; } if (hApplyIconHook) { UnhookEvent(hApplyIconHook); hApplyIconHook = NULL; } if (hRebuildIconsHook) { UnhookEvent(hRebuildIconsHook); hRebuildIconsHook = NULL; } } SvcEMailApplyCListIcons(); } /** * This function initially loads the module uppon startup. **/ void SvcEMailOnModulesLoaded() { SvcEMailEnableExtraIcons( DB::Setting::GetByte(SET_CLIST_EXTRAICON_EMAIL, DEFVAL_CLIST_EXTRAICON_EMAIL), FALSE); } /** * This function initially loads the module uppon startup. **/ void SvcEMailLoadModule() { if (DB::Setting::GetByte(SET_EXTENDED_EMAILSERVICE, TRUE)) { // create own email send command if (!myDestroyServiceFunction(MS_EMAIL_SENDEMAIL)) CreateServiceFunction(MS_EMAIL_SENDEMAIL, MenuCommand); } } /** * This function unloads the Email module. * * @param none * * @return nothing **/ void SvcEMailUnloadModule() { // unhook event handlers UnhookEvent(hChangedHook); hChangedHook = NULL; UnhookEvent(hApplyIconHook); hApplyIconHook = NULL; UnhookEvent(hRebuildIconsHook); hRebuildIconsHook = NULL; }