2012-03-05 01:08:21 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Austin English
|
2012-03-18 19:20:08 +01:00
|
|
|
* Copyright 2012 André Hentschel
|
2012-03-05 01:08:21 +01:00
|
|
|
*
|
|
|
|
* 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>
|
|
|
|
|
2021-02-03 09:11:21 +01:00
|
|
|
#define NONAMELESSUNION
|
|
|
|
|
2012-03-05 01:08:21 +01:00
|
|
|
#include "windef.h"
|
|
|
|
#include "winbase.h"
|
2012-03-18 19:20:08 +01:00
|
|
|
#include "winevt.h"
|
2012-03-05 01:08:21 +01:00
|
|
|
#include "wine/debug.h"
|
|
|
|
|
|
|
|
WINE_DEFAULT_DEBUG_CHANNEL(wevtapi);
|
|
|
|
|
2021-02-03 09:11:21 +01:00
|
|
|
static const WCHAR log_pathW[] = L"C:\\windows\\temp\\evt.log";
|
|
|
|
|
2017-11-28 17:58:49 +01:00
|
|
|
EVT_HANDLE WINAPI EvtOpenSession(EVT_LOGIN_CLASS login_class, void *login, DWORD timeout, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%u %p %u %u) stub\n", login_class, login, timeout, flags);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-11-28 17:58:51 +01:00
|
|
|
EVT_HANDLE WINAPI EvtOpenLog(EVT_HANDLE session, const WCHAR *path, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %s %u) stub\n", session, debugstr_w(path), flags);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2012-03-18 19:21:04 +01:00
|
|
|
BOOL WINAPI EvtGetChannelConfigProperty(EVT_HANDLE ChannelConfig,
|
|
|
|
EVT_CHANNEL_CONFIG_PROPERTY_ID PropertyId,
|
|
|
|
DWORD Flags,
|
|
|
|
DWORD PropertyValueBufferSize,
|
|
|
|
PEVT_VARIANT PropertyValueBuffer,
|
|
|
|
DWORD *PropertyValueBufferUsed)
|
|
|
|
{
|
|
|
|
FIXME("(%p %i %u %u %p %p) stub\n", ChannelConfig, PropertyId, Flags, PropertyValueBufferSize,
|
|
|
|
PropertyValueBuffer, PropertyValueBufferUsed);
|
2021-02-03 09:11:21 +01:00
|
|
|
|
|
|
|
switch (PropertyId)
|
|
|
|
{
|
|
|
|
case EvtChannelLoggingConfigLogFilePath:
|
|
|
|
*PropertyValueBufferUsed = sizeof(log_pathW) + sizeof(EVT_VARIANT);
|
|
|
|
|
|
|
|
if (PropertyValueBufferSize < sizeof(log_pathW) + sizeof(EVT_VARIANT) || !PropertyValueBuffer)
|
|
|
|
{
|
|
|
|
SetLastError(ERROR_INSUFFICIENT_BUFFER);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
PropertyValueBuffer->u.StringVal = (LPWSTR)(PropertyValueBuffer + 1);
|
|
|
|
wcscpy((LPWSTR)PropertyValueBuffer->u.StringVal, log_pathW);
|
|
|
|
PropertyValueBuffer->Type = EvtVarTypeString;
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
default:
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-03-18 19:21:04 +01:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL WINAPI EvtSetChannelConfigProperty(EVT_HANDLE ChannelConfig,
|
|
|
|
EVT_CHANNEL_CONFIG_PROPERTY_ID PropertyId,
|
|
|
|
DWORD Flags,
|
|
|
|
PEVT_VARIANT PropertyValue)
|
|
|
|
{
|
|
|
|
FIXME("(%p %i %u %p) stub\n", ChannelConfig, PropertyId, Flags, PropertyValue);
|
2021-02-01 12:36:08 +01:00
|
|
|
return TRUE;
|
2012-03-18 19:21:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
EVT_HANDLE WINAPI EvtSubscribe(EVT_HANDLE Session, HANDLE SignalEvent, LPCWSTR ChannelPath,
|
|
|
|
LPCWSTR Query, EVT_HANDLE Bookmark, PVOID context,
|
|
|
|
EVT_SUBSCRIBE_CALLBACK Callback, DWORD Flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %p %s %s %p %p %p %u) stub\n", Session, SignalEvent, debugstr_w(ChannelPath),
|
|
|
|
debugstr_w(Query), Bookmark, context, Callback, Flags);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-11-28 17:58:47 +01:00
|
|
|
EVT_HANDLE WINAPI EvtOpenChannelEnum(EVT_HANDLE session, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %u) stub\n", session, flags);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-11-28 17:58:50 +01:00
|
|
|
BOOL WINAPI EvtNextChannelPath(EVT_HANDLE channel_enum, DWORD buffer_len, WCHAR *buffer, DWORD *used)
|
|
|
|
{
|
|
|
|
FIXME("(%p %u %p %p) stub\n", channel_enum, buffer_len, buffer, used);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2012-03-18 19:20:08 +01:00
|
|
|
EVT_HANDLE WINAPI EvtOpenChannelConfig(EVT_HANDLE Session, LPCWSTR ChannelPath, DWORD Flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %s %u) stub\n", Session, debugstr_w(ChannelPath), Flags);
|
2021-02-01 12:36:02 +01:00
|
|
|
return (EVT_HANDLE)0xdeadbeef;
|
2012-03-18 19:20:08 +01:00
|
|
|
}
|
2015-12-10 07:53:54 +01:00
|
|
|
|
2017-11-28 17:58:48 +01:00
|
|
|
EVT_HANDLE WINAPI EvtQuery(EVT_HANDLE session, const WCHAR *path, const WCHAR *query, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %s %s %u) stub\n", session, debugstr_w(path), debugstr_w(query), flags);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2021-02-01 12:36:11 +01:00
|
|
|
BOOL WINAPI EvtSaveChannelConfig(EVT_HANDLE channel, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p,%08x) stub\n", channel, flags);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2015-12-10 07:53:54 +01:00
|
|
|
BOOL WINAPI EvtClose(EVT_HANDLE handle)
|
|
|
|
{
|
|
|
|
FIXME("(%p) stub\n", handle);
|
|
|
|
return TRUE;
|
|
|
|
}
|
2018-01-26 14:57:21 +01:00
|
|
|
|
|
|
|
BOOL WINAPI EvtNext(EVT_HANDLE result_set, DWORD size, EVT_HANDLE *array, DWORD timeout, DWORD flags, DWORD *ret_count)
|
|
|
|
{
|
|
|
|
FIXME("(%p %u %p %u %#x %p) stub!\n", result_set, size, array, timeout, flags, ret_count);
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
|
|
|
return FALSE;
|
|
|
|
}
|
2018-03-23 13:23:57 +01:00
|
|
|
|
|
|
|
BOOL WINAPI EvtExportLog(EVT_HANDLE session, const WCHAR *path, const WCHAR *query, const WCHAR *file, DWORD flags)
|
|
|
|
{
|
|
|
|
FIXME("(%p %s %s %s %#x) stub!\n", session, debugstr_w(path), debugstr_w(query), debugstr_w(file), flags);
|
|
|
|
SetLastError(ERROR_CALL_NOT_IMPLEMENTED);
|
|
|
|
return FALSE;
|
|
|
|
}
|