| /* | 
 |  *             MAPI basics | 
 |  * | 
 |  * Copyright 2001, 2009 CodeWeavers Inc. | 
 |  * | 
 |  * This library is free software; you can redistribute it and/or | 
 |  * modify it under the terms of the GNU Lesser General Public | 
 |  * License as published by the Free Software Foundation; either | 
 |  * version 2.1 of the License, or (at your option) any later version. | 
 |  * | 
 |  * This library 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 | 
 |  * Lesser General Public License for more details. | 
 |  * | 
 |  * You should have received a copy of the GNU Lesser General Public | 
 |  * License along with this library; if not, write to the Free Software | 
 |  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA | 
 |  */ | 
 |  | 
 | #include <stdarg.h> | 
 |  | 
 | #include "windef.h" | 
 | #include "winbase.h" | 
 | #include "winerror.h" | 
 | #include "objbase.h" | 
 | #include "initguid.h" | 
 | #include "mapix.h" | 
 | #include "mapiform.h" | 
 | #include "mapi.h" | 
 | #include "wine/debug.h" | 
 | #include "util.h" | 
 |  | 
 | WINE_DEFAULT_DEBUG_CHANNEL(mapi); | 
 |  | 
 | LONG MAPI_ObjectCount = 0; | 
 |  | 
 | /*********************************************************************** | 
 |  *              DllMain (MAPI32.init) | 
 |  */ | 
 | BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID fImpLoad) | 
 | { | 
 |     TRACE("(%p,%d,%p)\n", hinstDLL, fdwReason, fImpLoad); | 
 |  | 
 |     switch (fdwReason) | 
 |     { | 
 |     case DLL_PROCESS_ATTACH: | 
 |         DisableThreadLibraryCalls(hinstDLL); | 
 |         load_mapi_providers(); | 
 |         break; | 
 |     case DLL_PROCESS_DETACH: | 
 | 	TRACE("DLL_PROCESS_DETACH: %d objects remaining\n", MAPI_ObjectCount); | 
 |         unload_mapi_providers(); | 
 | 	break; | 
 |     } | 
 |     return TRUE; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  *		DllGetClassObject (MAPI32.27) | 
 |  */ | 
 | HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID iid, LPVOID *ppv) | 
 | { | 
 |     if (mapiFunctions.DllGetClassObject) | 
 |     { | 
 |         HRESULT ret = mapiFunctions.DllGetClassObject(rclsid, iid, ppv); | 
 |  | 
 |         TRACE("ret: %x\n", ret); | 
 |         return ret; | 
 |     } | 
 |  | 
 |     FIXME("\n\tCLSID:\t%s,\n\tIID:\t%s\n", debugstr_guid(rclsid), debugstr_guid(iid)); | 
 |  | 
 |     *ppv = NULL; | 
 |     return CLASS_E_CLASSNOTAVAILABLE; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * DllCanUnloadNow (MAPI32.28) | 
 |  * | 
 |  * Determine if this dll can be unloaded from the callers address space. | 
 |  * | 
 |  * PARAMS | 
 |  *  None. | 
 |  * | 
 |  * RETURNS | 
 |  *  S_OK, if the dll can be unloaded, | 
 |  *  S_FALSE, otherwise. | 
 |  */ | 
 | HRESULT WINAPI DllCanUnloadNow(void) | 
 | { | 
 |     HRESULT ret = S_OK; | 
 |  | 
 |     if (mapiFunctions.DllCanUnloadNow) | 
 |     { | 
 |         ret = mapiFunctions.DllCanUnloadNow(); | 
 |         TRACE("(): provider returns %d\n", ret); | 
 |     } | 
 |  | 
 |     return MAPI_ObjectCount == 0 ? ret : S_FALSE; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * MAPIInitialize | 
 |  * | 
 |  * Initialises the MAPI library. In our case, we pass through to the | 
 |  * loaded Extended MAPI provider. | 
 |  */ | 
 | HRESULT WINAPI MAPIInitialize(LPVOID init) | 
 | { | 
 |     TRACE("(%p)\n", init); | 
 |  | 
 |     if (mapiFunctions.MAPIInitialize) | 
 |         return mapiFunctions.MAPIInitialize(init); | 
 |  | 
 |     return MAPI_E_NOT_INITIALIZED; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * MAPILogon | 
 |  * | 
 |  * Logs on to a MAPI provider. If available, we pass this through to a | 
 |  * Simple MAPI provider. Otherwise, we maintain basic functionality | 
 |  * ourselves. | 
 |  */ | 
 | ULONG WINAPI MAPILogon(ULONG_PTR uiparam, LPSTR profile, LPSTR password, | 
 |     FLAGS flags, ULONG reserved, LPLHANDLE session) | 
 | { | 
 |     TRACE("(0x%08lx %s %p 0x%08x 0x%08x %p)\n", uiparam, | 
 |           debugstr_a(profile), password, flags, reserved, session); | 
 |  | 
 |     if (mapiFunctions.MAPILogon) | 
 |         return mapiFunctions.MAPILogon(uiparam, profile, password, flags, reserved, session); | 
 |  | 
 |     if (session) *session = 1; | 
 |     return SUCCESS_SUCCESS; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * MAPILogoff | 
 |  * | 
 |  * Logs off from a MAPI provider. If available, we pass this through to a | 
 |  * Simple MAPI provider. Otherwise, we maintain basic functionality | 
 |  * ourselves. | 
 |  */ | 
 | ULONG WINAPI MAPILogoff(LHANDLE session, ULONG_PTR uiparam, FLAGS flags, | 
 |     ULONG reserved ) | 
 | { | 
 |     TRACE("(0x%08lx 0x%08lx 0x%08x 0x%08x)\n", session, | 
 |           uiparam, flags, reserved); | 
 |  | 
 |     if (mapiFunctions.MAPILogoff) | 
 |         return mapiFunctions.MAPILogoff(session, uiparam, flags, reserved); | 
 |  | 
 |     return SUCCESS_SUCCESS; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * MAPILogonEx | 
 |  * | 
 |  * Logs on to a MAPI provider. If available, we pass this through to an | 
 |  * Extended MAPI provider. Otherwise, we return an error. | 
 |  */ | 
 | HRESULT WINAPI MAPILogonEx(ULONG_PTR uiparam, LPWSTR profile, | 
 |     LPWSTR password, ULONG flags, LPMAPISESSION *session) | 
 | { | 
 |     TRACE("(0x%08lx %s %p 0x%08x %p)\n", uiparam, | 
 |           debugstr_w(profile), password, flags, session); | 
 |  | 
 |     if (mapiFunctions.MAPILogonEx) | 
 |         return mapiFunctions.MAPILogonEx(uiparam, profile, password, flags, session); | 
 |  | 
 |     return E_FAIL; | 
 | } | 
 |  | 
 | HRESULT WINAPI MAPIOpenLocalFormContainer(LPVOID *ppfcnt) | 
 | { | 
 |     if (mapiFunctions.MAPIOpenLocalFormContainer) | 
 |         return mapiFunctions.MAPIOpenLocalFormContainer(ppfcnt); | 
 |  | 
 |     FIXME("(%p) Stub\n", ppfcnt); | 
 |     return E_FAIL; | 
 | } | 
 |  | 
 | /*********************************************************************** | 
 |  * MAPIUninitialize | 
 |  * | 
 |  * Uninitialises the MAPI library. In our case, we pass through to the | 
 |  * loaded Extended MAPI provider. | 
 |  * | 
 |  */ | 
 | VOID WINAPI MAPIUninitialize(void) | 
 | { | 
 |     TRACE("()\n"); | 
 |  | 
 |     /* Try to uninitialise the Extended MAPI library */ | 
 |     if (mapiFunctions.MAPIUninitialize) | 
 |         mapiFunctions.MAPIUninitialize(); | 
 | } | 
 |  | 
 | HRESULT WINAPI MAPIAdminProfiles(ULONG ulFlags,  LPPROFADMIN *lppProfAdmin) | 
 | { | 
 |     if (mapiFunctions.MAPIAdminProfiles) | 
 |         return mapiFunctions.MAPIAdminProfiles(ulFlags, lppProfAdmin); | 
 |  | 
 |     FIXME("(%u, %p): stub\n", ulFlags, lppProfAdmin); | 
 |     *lppProfAdmin = NULL; | 
 |     return E_FAIL; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIAddress(LHANDLE session, ULONG_PTR uiparam, LPSTR caption, | 
 |     ULONG editfields, LPSTR labels, ULONG nRecips, lpMapiRecipDesc lpRecips, | 
 |     FLAGS flags, ULONG reserved, LPULONG newRecips, lpMapiRecipDesc * lppNewRecips) | 
 | { | 
 |     if (mapiFunctions.MAPIAddress) | 
 |         return mapiFunctions.MAPIAddress(session, uiparam, caption, editfields, labels, | 
 |             nRecips, lpRecips, flags, reserved, newRecips, lppNewRecips); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIDeleteMail(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_id, | 
 |     FLAGS flags, ULONG reserved) | 
 | { | 
 |     if (mapiFunctions.MAPIDeleteMail) | 
 |         return mapiFunctions.MAPIDeleteMail(session, uiparam, msg_id, flags, reserved); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIDetails(LHANDLE session, ULONG_PTR uiparam, lpMapiRecipDesc recip, | 
 |     FLAGS flags, ULONG reserved) | 
 | { | 
 |     if (mapiFunctions.MAPIDetails) | 
 |         return mapiFunctions.MAPIDetails(session, uiparam, recip, flags, reserved); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIFindNext(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_type, | 
 |     LPSTR seed_msg_id, FLAGS flags, ULONG reserved, LPSTR msg_id) | 
 | { | 
 |     if (mapiFunctions.MAPIFindNext) | 
 |         return mapiFunctions.MAPIFindNext(session, uiparam, msg_type, seed_msg_id, flags, reserved, msg_id); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIReadMail(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_id, | 
 |     FLAGS flags, ULONG reserved, lpMapiMessage msg) | 
 | { | 
 |     if (mapiFunctions.MAPIReadMail) | 
 |         return mapiFunctions.MAPIReadMail(session, uiparam, msg_id, flags, reserved, msg); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPIResolveName(LHANDLE session, ULONG_PTR uiparam, LPSTR name, | 
 |     FLAGS flags, ULONG reserved, lpMapiRecipDesc *recip) | 
 | { | 
 |     if (mapiFunctions.MAPIResolveName) | 
 |         return mapiFunctions.MAPIResolveName(session, uiparam, name, flags, reserved, recip); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } | 
 |  | 
 | ULONG WINAPI MAPISaveMail(LHANDLE session, ULONG_PTR uiparam, lpMapiMessage msg, | 
 |     FLAGS flags, ULONG reserved, LPSTR msg_id) | 
 | { | 
 |     if (mapiFunctions.MAPISaveMail) | 
 |         return mapiFunctions.MAPISaveMail(session, uiparam, msg, flags, reserved, msg_id); | 
 |  | 
 |     return MAPI_E_NOT_SUPPORTED; | 
 | } |