Release 1.3.7.
[wine/gsoc-2012-control.git] / dlls / wer / main.c
blob585ac91a30b73b5033ada066b3bedd0e7a27f4dc
1 /*
2 * Copyright 2010 Louis Lenders
3 * Copyright 2010 Detlef Riekenberg
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
20 #include "config.h"
22 #include <stdarg.h>
24 #include "windef.h"
25 #include "winbase.h"
26 #include "winreg.h"
27 #include "werapi.h"
28 #include "wine/list.h"
29 #include "wine/unicode.h"
30 #include "wine/debug.h"
32 WINE_DEFAULT_DEBUG_CHANNEL(wer);
34 typedef struct {
35 struct list entry;
36 WER_REPORT_INFORMATION info;
37 WER_REPORT_TYPE reporttype;
38 WCHAR eventtype[1];
39 } report_t;
42 static CRITICAL_SECTION report_table_cs;
43 static CRITICAL_SECTION_DEBUG report_table_cs_debug =
45 0, 0, &report_table_cs,
46 { &report_table_cs_debug.ProcessLocksList, &report_table_cs_debug.ProcessLocksList },
47 0, 0, { (DWORD_PTR)(__FILE__ ": report_table_cs") }
49 static CRITICAL_SECTION report_table_cs = { &report_table_cs_debug, -1, 0, 0, 0, 0 };
51 static struct list report_table = LIST_INIT(report_table);
53 static WCHAR regpath_exclude[] = {'S','o','f','t','w','a','r','e','\\',
54 'M','i','c','r','o','s','o','f','t','\\',
55 'W','i','n','d','o','w','s',' ','E','r','r','o','r',' ','R','e','p','o','r','t','i','n','g','\\',
56 'E','x','c','l','u','d','e','d','A','p','p','l','i','c','a','t','i','o','n','s',0};
58 /***********************************************************************
59 * Memory alloccation helper
62 static inline void * __WINE_ALLOC_SIZE(1) heap_alloc_zero(size_t len)
64 return HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, len);
67 static inline BOOL heap_free(void *mem)
69 return HeapFree(GetProcessHeap(), 0, mem);
72 BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved)
74 TRACE("(0x%p, %d, %p)\n", hinstDLL, fdwReason, lpvReserved);
76 switch (fdwReason)
78 case DLL_WINE_PREATTACH:
79 return FALSE; /* prefer native version */
80 case DLL_PROCESS_ATTACH:
81 DisableThreadLibraryCalls(hinstDLL);
82 break;
83 case DLL_PROCESS_DETACH:
84 break;
87 return TRUE;
90 /***********************************************************************
91 * WerAddExcludedApplication (wer.@)
93 * Add an application to the user specific or the system wide exclusion list
95 * PARAMS
96 * exeName [i] The application name
97 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
99 * RETURNS
100 * Success: S_OK
101 * Faulure: A HRESULT error code
104 HRESULT WINAPI WerAddExcludedApplication(PCWSTR exeName, BOOL allUsers)
106 HKEY hkey;
107 DWORD value = 1;
108 LPWSTR bs;
110 TRACE("(%s, %d)\n",debugstr_w(exeName), allUsers);
111 if (!exeName || !exeName[0])
112 return E_INVALIDARG;
114 bs = strrchrW(exeName, '\\');
115 if (bs) {
116 bs++; /* skip the backslash */
117 if (!bs[0]) {
118 return E_INVALIDARG;
120 } else
121 bs = (LPWSTR) exeName;
123 if (!RegCreateKeyW(allUsers ? HKEY_LOCAL_MACHINE : HKEY_CURRENT_USER, regpath_exclude, &hkey)) {
124 RegSetValueExW(hkey, bs, 0, REG_DWORD, (LPBYTE)&value, sizeof(DWORD));
125 RegCloseKey(hkey);
126 return S_OK;
128 return E_ACCESSDENIED;
131 /***********************************************************************
132 * WerRemoveExcludedApplication (wer.@)
134 * remove an application from the exclusion list
136 * PARAMS
137 * exeName [i] The application name
138 * allUsers [i] for all users (TRUE) or for the current user (FALSE)
140 * RETURNS
141 * Success: S_OK
142 * Faulure: A HRESULT error code
145 HRESULT WINAPI WerRemoveExcludedApplication(PCWSTR exeName, BOOL allUsers)
147 HKEY hkey;
148 LPWSTR bs;
149 LONG lres;
151 TRACE("(%s, %d)\n",debugstr_w(exeName), allUsers);
152 if (!exeName || !exeName[0])
153 return E_INVALIDARG;
155 bs = strrchrW(exeName, '\\');
156 if (bs) {
157 bs++; /* skip the backslash */
158 if (!bs[0]) {
159 return E_INVALIDARG;
161 } else
162 bs = (LPWSTR) exeName;
164 if (!RegCreateKeyW(allUsers ? HKEY_LOCAL_MACHINE : HKEY_CURRENT_USER, regpath_exclude, &hkey)) {
165 lres = RegDeleteValueW(hkey, bs);
166 RegCloseKey(hkey);
167 return lres ? __HRESULT_FROM_WIN32(ERROR_ENVVAR_NOT_FOUND) : S_OK;
169 return E_ACCESSDENIED;
172 /***********************************************************************
173 * WerReportCloseHandle (wer.@)
175 * Close an error reporting handle and free associated resources
177 * PARAMS
178 * hreport [i] error reporting handle to close
180 * RETURNS
181 * Success: S_OK
182 * Failure: A HRESULT error code
185 HRESULT WINAPI WerReportCloseHandle(HREPORT hreport)
187 report_t * report = (report_t *) hreport;
188 report_t * cursor;
189 BOOL found = FALSE;
191 TRACE("(%p)\n", hreport);
192 EnterCriticalSection(&report_table_cs);
193 if (report) {
194 LIST_FOR_EACH_ENTRY(cursor, &report_table, report_t, entry)
196 if (cursor == report) {
197 found = TRUE;
198 list_remove(&report->entry);
199 break;
203 LeaveCriticalSection(&report_table_cs);
204 if (!found)
205 return E_INVALIDARG;
207 heap_free(report);
209 return S_OK;
212 /***********************************************************************
213 * WerReportCreate (wer.@)
215 * Create an error report in memory and return a related HANDLE
217 * PARAMS
218 * eventtype [i] a name for the event type
219 * reporttype [i] what type of report should be created
220 * reportinfo [i] NULL or a ptr to a struct with some detailed information
221 * phandle [o] ptr, where the resulting handle should be saved
223 * RETURNS
224 * Success: S_OK
225 * Failure: A HRESULT error code
227 * NOTES
228 * The event type must be registered at microsoft. Predefined types are
229 * "APPCRASH" as the default on Windows, "Crash32" and "Crash64"
232 HRESULT WINAPI WerReportCreate(PCWSTR eventtype, WER_REPORT_TYPE reporttype, PWER_REPORT_INFORMATION reportinfo, HREPORT *phandle)
234 report_t *report;
235 DWORD len;
237 TRACE("(%s, %d, %p, %p)\n", debugstr_w(eventtype), reporttype, reportinfo, phandle);
238 if (reportinfo) {
239 TRACE(".wzFriendlyEventName: %s\n", debugstr_w(reportinfo->wzFriendlyEventName));
240 TRACE(".wzApplicationName: %s\n", debugstr_w(reportinfo->wzApplicationName));
243 if (phandle) *phandle = NULL;
244 if (!eventtype || !eventtype[0] || !phandle) {
245 return E_INVALIDARG;
248 len = lstrlenW(eventtype) + 1;
250 report = heap_alloc_zero(len * sizeof(WCHAR) + sizeof(report_t));
251 if (!report)
252 return __HRESULT_FROM_WIN32(ERROR_OUTOFMEMORY);
254 lstrcpyW(report->eventtype, eventtype);
255 report->reporttype = reporttype;
257 if (reportinfo) {
258 report->info = *reportinfo;
259 } else {
260 FIXME("build report information from scratch for %p\n", report);
263 EnterCriticalSection(&report_table_cs);
264 list_add_head(&report_table, &report->entry);
265 LeaveCriticalSection(&report_table_cs);
267 *phandle = report;
268 TRACE("=> %p\n", report);
269 return S_OK;
272 /***********************************************************************
273 * WerReportSetParameter (wer.@)
275 * Set one of 10 parameter / value pairs for a report handle
277 * PARAMS
278 * hreport [i] error reporting handle to add the parameter
279 * id [i] parameter to set (WER_P0 upto WER_P9)
280 * name [i] optional name of the parameter
281 * value [i] value of the parameter
283 * RETURNS
284 * Success: S_OK
285 * Failure: A HRESULT error code
288 HRESULT WINAPI WerReportSetParameter(HREPORT hreport, DWORD id, PCWSTR name, PCWSTR value)
290 FIXME("(%p, %d, %s, %s) :stub\n", hreport, id, debugstr_w(name), debugstr_w(value));
292 return E_NOTIMPL;
295 /***********************************************************************
296 * WerReportSubmit (wer.@)
298 * Ask the user for permission and send the error report
299 * then kill or restart the application, when requested
301 * PARAMS
302 * hreport [i] error reporting handle to send
303 * consent [i] current transmit permission
304 * flags [i] flag to select dialog, transmission snd restart options
305 * presult [o] ptr, where the transmission result should be saved
307 * RETURNS
308 * Success: S_OK
309 * Failure: A HRESULT error code
312 HRESULT WINAPI WerReportSubmit(HREPORT hreport, WER_CONSENT consent, DWORD flags, PWER_SUBMIT_RESULT presult)
314 FIXME("(%p, %d, 0x%x, %p) :stub\n", hreport, consent, flags, presult);
316 if(!presult)
317 return E_INVALIDARG;
319 *presult = WerDisabled;
320 return E_NOTIMPL;