252 lines
7.4 KiB
C
252 lines
7.4 KiB
C
/*
|
|
* 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)
|
|
{
|
|
*ppv = NULL;
|
|
FIXME("\n\tCLSID:\t%s,\n\tIID:\t%s\n", debugstr_guid(rclsid), debugstr_guid(iid));
|
|
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)
|
|
{
|
|
return MAPI_ObjectCount == 0 ? S_OK : 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)
|
|
{
|
|
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)
|
|
{
|
|
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;
|
|
}
|