/* * 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); DECLSPEC_HIDDEN LONG MAPI_ObjectCount = 0; DECLSPEC_HIDDEN HINSTANCE hInstMAPI32; /*********************************************************************** * 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: hInstMAPI32 = hinstDLL; DisableThreadLibraryCalls(hinstDLL); load_mapi_providers(); break; case DLL_PROCESS_DETACH: if (fImpLoad) break; 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; }