xref: /reactos/dll/win32/mapi32/mapi32_main.c (revision d5b576b2)
1 /*
2  *             MAPI basics
3  *
4  * Copyright 2001, 2009 CodeWeavers Inc.
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20 
21 #include <stdarg.h>
22 
23 #include "windef.h"
24 #include "winbase.h"
25 #include "winerror.h"
26 #include "objbase.h"
27 #include "initguid.h"
28 #include "mapix.h"
29 #include "mapiform.h"
30 #include "mapi.h"
31 #include "wine/debug.h"
32 #include "util.h"
33 
34 WINE_DEFAULT_DEBUG_CHANNEL(mapi);
35 
36 DECLSPEC_HIDDEN LONG MAPI_ObjectCount = 0;
37 DECLSPEC_HIDDEN HINSTANCE hInstMAPI32;
38 
39 /***********************************************************************
40  *              DllMain (MAPI32.init)
41  */
42 BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID fImpLoad)
43 {
44     TRACE("(%p,%d,%p)\n", hinstDLL, fdwReason, fImpLoad);
45 
46     switch (fdwReason)
47     {
48     case DLL_PROCESS_ATTACH:
49         hInstMAPI32 = hinstDLL;
50         DisableThreadLibraryCalls(hinstDLL);
51         load_mapi_providers();
52         break;
53     case DLL_PROCESS_DETACH:
54         if (fImpLoad) break;
55 	TRACE("DLL_PROCESS_DETACH: %d objects remaining\n", MAPI_ObjectCount);
56         unload_mapi_providers();
57 	break;
58     }
59     return TRUE;
60 }
61 
62 /***********************************************************************
63  *		DllGetClassObject (MAPI32.27)
64  */
65 HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID iid, LPVOID *ppv)
66 {
67     if (mapiFunctions.DllGetClassObject)
68     {
69         HRESULT ret = mapiFunctions.DllGetClassObject(rclsid, iid, ppv);
70 
71         TRACE("ret: %x\n", ret);
72         return ret;
73     }
74 
75     FIXME("\n\tCLSID:\t%s,\n\tIID:\t%s\n", debugstr_guid(rclsid), debugstr_guid(iid));
76 
77     *ppv = NULL;
78     return CLASS_E_CLASSNOTAVAILABLE;
79 }
80 
81 /***********************************************************************
82  * DllCanUnloadNow (MAPI32.28)
83  *
84  * Determine if this dll can be unloaded from the callers address space.
85  *
86  * PARAMS
87  *  None.
88  *
89  * RETURNS
90  *  S_OK, if the dll can be unloaded,
91  *  S_FALSE, otherwise.
92  */
93 HRESULT WINAPI DllCanUnloadNow(void)
94 {
95     HRESULT ret = S_OK;
96 
97     if (mapiFunctions.DllCanUnloadNow)
98     {
99         ret = mapiFunctions.DllCanUnloadNow();
100         TRACE("(): provider returns %d\n", ret);
101     }
102 
103     return MAPI_ObjectCount == 0 ? ret : S_FALSE;
104 }
105 
106 /***********************************************************************
107  * MAPIInitialize
108  *
109  * Initialises the MAPI library. In our case, we pass through to the
110  * loaded Extended MAPI provider.
111  */
112 HRESULT WINAPI MAPIInitialize(LPVOID init)
113 {
114     TRACE("(%p)\n", init);
115 
116     if (mapiFunctions.MAPIInitialize)
117         return mapiFunctions.MAPIInitialize(init);
118 
119     return MAPI_E_NOT_INITIALIZED;
120 }
121 
122 /***********************************************************************
123  * MAPILogon
124  *
125  * Logs on to a MAPI provider. If available, we pass this through to a
126  * Simple MAPI provider. Otherwise, we maintain basic functionality
127  * ourselves.
128  */
129 ULONG WINAPI MAPILogon(ULONG_PTR uiparam, LPSTR profile, LPSTR password,
130     FLAGS flags, ULONG reserved, LPLHANDLE session)
131 {
132     TRACE("(0x%08lx %s %p 0x%08x 0x%08x %p)\n", uiparam,
133           debugstr_a(profile), password, flags, reserved, session);
134 
135     if (mapiFunctions.MAPILogon)
136         return mapiFunctions.MAPILogon(uiparam, profile, password, flags, reserved, session);
137 
138     if (session) *session = 1;
139     return SUCCESS_SUCCESS;
140 }
141 
142 /***********************************************************************
143  * MAPILogoff
144  *
145  * Logs off from a MAPI provider. If available, we pass this through to a
146  * Simple MAPI provider. Otherwise, we maintain basic functionality
147  * ourselves.
148  */
149 ULONG WINAPI MAPILogoff(LHANDLE session, ULONG_PTR uiparam, FLAGS flags,
150     ULONG reserved )
151 {
152     TRACE("(0x%08lx 0x%08lx 0x%08x 0x%08x)\n", session,
153           uiparam, flags, reserved);
154 
155     if (mapiFunctions.MAPILogoff)
156         return mapiFunctions.MAPILogoff(session, uiparam, flags, reserved);
157 
158     return SUCCESS_SUCCESS;
159 }
160 
161 /***********************************************************************
162  * MAPILogonEx
163  *
164  * Logs on to a MAPI provider. If available, we pass this through to an
165  * Extended MAPI provider. Otherwise, we return an error.
166  */
167 HRESULT WINAPI MAPILogonEx(ULONG_PTR uiparam, LPWSTR profile,
168     LPWSTR password, ULONG flags, LPMAPISESSION *session)
169 {
170     TRACE("(0x%08lx %s %p 0x%08x %p)\n", uiparam,
171           debugstr_w(profile), password, flags, session);
172 
173     if (mapiFunctions.MAPILogonEx)
174         return mapiFunctions.MAPILogonEx(uiparam, profile, password, flags, session);
175 
176     return E_FAIL;
177 }
178 
179 HRESULT WINAPI MAPIOpenLocalFormContainer(LPVOID *ppfcnt)
180 {
181     if (mapiFunctions.MAPIOpenLocalFormContainer)
182         return mapiFunctions.MAPIOpenLocalFormContainer(ppfcnt);
183 
184     FIXME("(%p) Stub\n", ppfcnt);
185     return E_FAIL;
186 }
187 
188 /***********************************************************************
189  * MAPIUninitialize
190  *
191  * Uninitialises the MAPI library. In our case, we pass through to the
192  * loaded Extended MAPI provider.
193  *
194  */
195 VOID WINAPI MAPIUninitialize(void)
196 {
197     TRACE("()\n");
198 
199     /* Try to uninitialise the Extended MAPI library */
200     if (mapiFunctions.MAPIUninitialize)
201         mapiFunctions.MAPIUninitialize();
202 }
203 
204 HRESULT WINAPI MAPIAdminProfiles(ULONG ulFlags,  LPPROFADMIN *lppProfAdmin)
205 {
206     if (mapiFunctions.MAPIAdminProfiles)
207         return mapiFunctions.MAPIAdminProfiles(ulFlags, lppProfAdmin);
208 
209     FIXME("(%u, %p): stub\n", ulFlags, lppProfAdmin);
210     *lppProfAdmin = NULL;
211     return E_FAIL;
212 }
213 
214 ULONG WINAPI MAPIAddress(LHANDLE session, ULONG_PTR uiparam, LPSTR caption,
215     ULONG editfields, LPSTR labels, ULONG nRecips, lpMapiRecipDesc lpRecips,
216     FLAGS flags, ULONG reserved, LPULONG newRecips, lpMapiRecipDesc * lppNewRecips)
217 {
218     if (mapiFunctions.MAPIAddress)
219         return mapiFunctions.MAPIAddress(session, uiparam, caption, editfields, labels,
220             nRecips, lpRecips, flags, reserved, newRecips, lppNewRecips);
221 
222     return MAPI_E_NOT_SUPPORTED;
223 }
224 
225 ULONG WINAPI MAPIDeleteMail(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_id,
226     FLAGS flags, ULONG reserved)
227 {
228     if (mapiFunctions.MAPIDeleteMail)
229         return mapiFunctions.MAPIDeleteMail(session, uiparam, msg_id, flags, reserved);
230 
231     return MAPI_E_NOT_SUPPORTED;
232 }
233 
234 ULONG WINAPI MAPIDetails(LHANDLE session, ULONG_PTR uiparam, lpMapiRecipDesc recip,
235     FLAGS flags, ULONG reserved)
236 {
237     if (mapiFunctions.MAPIDetails)
238         return mapiFunctions.MAPIDetails(session, uiparam, recip, flags, reserved);
239 
240     return MAPI_E_NOT_SUPPORTED;
241 }
242 
243 ULONG WINAPI MAPIFindNext(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_type,
244     LPSTR seed_msg_id, FLAGS flags, ULONG reserved, LPSTR msg_id)
245 {
246     if (mapiFunctions.MAPIFindNext)
247         return mapiFunctions.MAPIFindNext(session, uiparam, msg_type, seed_msg_id, flags, reserved, msg_id);
248 
249     return MAPI_E_NOT_SUPPORTED;
250 }
251 
252 ULONG WINAPI MAPIReadMail(LHANDLE session, ULONG_PTR uiparam, LPSTR msg_id,
253     FLAGS flags, ULONG reserved, lpMapiMessage msg)
254 {
255     if (mapiFunctions.MAPIReadMail)
256         return mapiFunctions.MAPIReadMail(session, uiparam, msg_id, flags, reserved, msg);
257 
258     return MAPI_E_NOT_SUPPORTED;
259 }
260 
261 ULONG WINAPI MAPIResolveName(LHANDLE session, ULONG_PTR uiparam, LPSTR name,
262     FLAGS flags, ULONG reserved, lpMapiRecipDesc *recip)
263 {
264     if (mapiFunctions.MAPIResolveName)
265         return mapiFunctions.MAPIResolveName(session, uiparam, name, flags, reserved, recip);
266 
267     return MAPI_E_NOT_SUPPORTED;
268 }
269 
270 ULONG WINAPI MAPISaveMail(LHANDLE session, ULONG_PTR uiparam, lpMapiMessage msg,
271     FLAGS flags, ULONG reserved, LPSTR msg_id)
272 {
273     if (mapiFunctions.MAPISaveMail)
274         return mapiFunctions.MAPISaveMail(session, uiparam, msg, flags, reserved, msg_id);
275 
276     return MAPI_E_NOT_SUPPORTED;
277 }
278