WindowsXP-SP1/base/eventlog/server/elfdef.h
2020-09-30 16:53:49 +02:00

512 lines
17 KiB
C

/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
elfdef.h
Abstract:
This file contains defines for the eventlog service.
Author:
Rajen Shah (rajens) 1-Jul-1991
Revision History:
--*/
#ifndef _EVENTDEF_
#define _EVENTDEF_
//
// Logfile object specific access type
//
#define ELF_LOGFILE_READ 0x0001
#define ELF_LOGFILE_WRITE 0x0002
#define ELF_LOGFILE_CLEAR 0x0004
#define ELF_LOGFILE_START 0x0008
#define ELF_LOGFILE_STOP 0x000C
#define ELF_LOGFILE_CONFIGURE 0x0010
#define ELF_LOGFILE_BACKUP 0x0020 // Set iff a backup operator
// opens the security log -
// this overrides all other
// flags.
#define ELF_LOGFILE_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | \
ELF_LOGFILE_READ | \
ELF_LOGFILE_WRITE | \
ELF_LOGFILE_CLEAR | \
ELF_LOGFILE_START | \
ELF_LOGFILE_STOP | \
ELF_LOGFILE_CONFIGURE)
//
// Three types of logfiles are defined from a security perspective:
//
// ELF_LOGFILE_SECURITY - Only Admins/LocalSystem can RW these files
// ELF_LOGFILE_SYSTEM - Only Admins/LocalSystem can W these files
// ELF_LOGFILE_APPLICATION - World can R/W these files
//
// System and Security will be SECURE, Application will be NON_SECURE
//
#define ELF_LOGFILE_SECURITY 0x0000
#define ELF_LOGFILE_SYSTEM 0x0001
#define ELF_LOGFILE_APPLICATION 0x0002
//
// Macro to convert a given file size into one that is "acceptable" for
// eventlogging. It basically truncates it to a 64K boundary making sure
// that it is as least 64K
//
#define ELFFILESIZE(x) ((x & 0xFFFF0000) ? (x & 0xFFFF0000) : 65536)
//
// The largest possible buffer we would need to hold an admin alert
// information. This primarily depends on the number and length of the
// replacement strings that would be passed with the message ID.
//
#define ELF_ADMIN_ALERT_BUFFER_SIZE 256
//
// Timeout defines.
//
#define INFINITE_WAIT_TIME -1 // Wait time for events
#define ELF_GLOBAL_RESOURCE_WAIT 2000 // 2-second timeout for global resource
//
// Signature placed before each event record in a file. Is used to
// validate where we are in a file.
//
#define ELF_RECORD_SIGNATURE 0x654c6652 // ASCII for eLfR
//
// Size by which to grow a log file until it reaches the max size
//
#define ELF_DEFAULT_LOG_SIZE 65536
//
// Bits for whether to take the global resource exclusively or shared.
//
#define ELF_GLOBAL_SHARED 0x0001
#define ELF_GLOBAL_EXCLUSIVE 0x0002
//
// Flag bits to keep track of what resources have been allocated at INIT time
//
#define ELF_INIT_LOGHANDLE_CRIT_SEC 0x0001
#define ELF_INIT_GLOBAL_RESOURCE 0x0002
#define ELF_STARTED_LPC_THREAD 0x0004
#define ELF_STARTED_REGISTRY_MONITOR 0x0008
#define ELF_STARTED_RPC_SERVER 0x0010
#define ELF_INIT_LOGFILE_CRIT_SEC 0x0020
#define ELF_INIT_LOGMODULE_CRIT_SEC 0x0040
#define ELF_INIT_WELL_KNOWN_SIDS 0x0080
#define ELF_INIT_QUEUED_EVENT_CRIT_SEC 0x0100
#define ELF_INIT_QUEUED_MESSAGE_CRIT_SEC 0x0200
#define ELF_INIT_CLUS_CRIT_SEC 0x0400
//
// Enumeration and macro to keep track of the "log full" popup per log
//
#define IS_WORKSTATION() (USER_SHARED_DATA->NtProductType == NtProductWinNt)
typedef enum
{
LOGPOPUP_NEVER_SHOW = 0, // Never show it for this log (e.g., Security)
LOGPOPUP_CLEARED, // Show it when this log fills up
LOGPOPUP_ALREADY_SHOWN // Don't show it again until this log is cleared
}
LOGPOPUP, *PLOGPOPUP;
//
// Structure containing information on each log file
//
// ActualMaxFileSize and ConfigMaxFileSize are stored in BYTEs.
// ActualMaxFileSize is the actual size of the file on the disk.
// ConfigMaxFileSize is the configured size of the file, which may not
// be the same as the actual size of the file.
//
// CurrentRecordNumber is the next absolute record number to write
//
// OldestRecordNumber is the next one to get overwritten
//
// Retention time is stored as the number of seconds.
//
// BaseAddress points to the physical beginning of the file.
//
// ViewSize is ALWAYS the size of the file in bytes.
//
// For the Flag bits, see the ELF_LOGFILE_HEADER_xxxx bits defined below.
//
typedef struct _LOGFILE {
LIST_ENTRY FileList;
LIST_ENTRY Notifiees; // List of ChangeNotify recipients
PUNICODE_STRING LogFileName; // Full path name of log file
PUNICODE_STRING LogModuleName; // Name of default module for this log
ULONG RefCount; // Number of modules using this file
ULONG Flags; // Autowrap, dirty, etc. - See bits below
ULONG ConfigMaxFileSize; // Max it can be
ULONG ActualMaxFileSize; // How big it is now
ULONG NextClearMaxFileSize; // Can't be shrunk on the fly
ULONG CurrentRecordNumber;// The next one to be created
ULONG OldestRecordNumber; // The next one to overwrite
ULONG SessionStartRecordNumber; //the first record number logged in this session
ULONG Retention; // Max. Retention time
ULONG NextClearRetention; // they shrank the file when they set this
HANDLE FileHandle; // Handle to open file
HANDLE SectionHandle; // Memory mapped section handle
PVOID BaseAddress; // Map view base address
ULONG ViewSize; // Mapped view size
ULONG BeginRecord; // Offset of first log record
ULONG EndRecord; // Offset of byte after last log record
ULONG ulLastPulseTime; // Time this log was last notified of a change
LOGPOPUP logpLogPopup; // "Log full" policy for this log
PSECURITY_DESCRIPTOR Sd; // User security object for this log
RTL_RESOURCE Resource;
BOOL bFullAlertDone;
DWORD AutoBackupLogFiles;
} LOGFILE, *PLOGFILE;
//
// Structure containing information on each module that is registered to
// log events.
//
typedef struct _LOGMODULE {
LIST_ENTRY ModuleList;
PWSTR ModuleName; // Name of module
ATOM ModuleAtom; // Atom identifying this module
PLOGFILE LogFile; // Log file for this module
} LOGMODULE, *PLOGMODULE;
//
// Command codes put in the request packets.
//
#define ELF_COMMAND_READ 1
#define ELF_COMMAND_WRITE 2
#define ELF_COMMAND_CLEAR 3
#define ELF_COMMAND_BACKUP 4
#define ELF_COMMAND_WRITE_QUEUED 5
//
// Structures that contain the operation-specific information.
//
typedef struct _WRITE_PKT {
DWORD Datasize; // Size of data in the buffer
PVOID Buffer; // Contains filled event log record
} WRITE_PKT, *PWRITE_PKT;
//
// The following flag bits are used in the READ_PKT Flag field.
//
#define ELF_IREAD_UNICODE 0x0001
#define ELF_IREAD_ANSI 0x0002
#define ELF_LAST_READ_FORWARD 0x0004
typedef struct _READ_PKT {
ULONG Flags; // UNICODE or ANSI
ULONG BufferSize; // Bytes to read
PVOID Buffer; // User's buffer
ULONG ReadFlags; // Sequential? Forwards? Random-access? Backwards?
ULONG RecordNumber; // Where to start the READ
ULONG MinimumBytesNeeded; // For return info if buffer too small
ULONG LastSeekPos; // Last seek position in terms of bytes
ULONG LastSeekRecord; // Last seek position in terms of records
ULONG BytesRead; // Bytes read - for return to caller
ULONG RecordsRead;
} READ_PKT, *PREAD_PKT;
typedef struct _CLEAR_PKT {
PUNICODE_STRING BackupFileName; // File to back up current log file (or NULL)
} CLEAR_PKT, *PCLEAR_PKT;
typedef struct _BACKUP_PKT {
PUNICODE_STRING BackupFileName; // File to back up current log file (or NULL)
} BACKUP_PKT, *PBACKUP_PKT;
//
// Flags used in the ELF_REQUEST_RECORD
//
#define ELF_FORCE_OVERWRITE 0x01 // Ignore retention period for this write
//
// Structure for the packet that contains all the information needed
// to perform the request.
//
typedef struct _ELF_REQUEST_RECORD {
USHORT Flags;
NTSTATUS Status; // To return status of operation
PLOGFILE LogFile; // File on which to operate
PLOGMODULE Module; // Information on module
USHORT Command; // Operation to be performed
union {
PWRITE_PKT WritePkt;
PREAD_PKT ReadPkt;
PCLEAR_PKT ClearPkt;
PBACKUP_PKT BackupPkt;
} Pkt;
} ELF_REQUEST_RECORD, *PELF_REQUEST_RECORD;
typedef
#ifdef _WIN64
__declspec(align(8))
#endif
struct _ELF_ALERT_RECORD {
DWORD TimeOut;
DWORD MessageId;
DWORD NumberOfStrings;
// array of UNICODE_STRINGs NumberOfStringsLong
// each string
} ELF_ALERT_RECORD, * PELF_ALERT_RECORD;
typedef struct _ELF_MESSAGE_RECORD {
DWORD MessageId;
DWORD NumberOfStrings;
// UNICODE null terminated strings
} ELF_MESSAGE_RECORD, * PELF_MESSAGE_RECORD;
//
// Record for the linked list of deferred events (these are raised by the
// eventlog service itself for writing once the current operation is complete
//
typedef struct _ELF_QUEUED_EVENT {
LIST_ENTRY Next;
enum _ELF_QUEUED_EVENT_TYPE {
Event,
Alert,
Message
} Type;
union _ELF_QUEUED_EVENT_DATA {
ELF_REQUEST_RECORD Request;
ELF_ALERT_RECORD Alert;
ELF_MESSAGE_RECORD Message;
} Event;
} ELF_QUEUED_EVENT, *PELF_QUEUED_EVENT;
//
// Structure containing information on callers of ElfChangeNotify
//
typedef struct _NOTIFIEE {
LIST_ENTRY Next;
IELF_HANDLE Handle;
HANDLE Event;
} NOTIFIEE, *PNOTIFIEE;
//
// Structure that describes the header that is at the beginning of the
// log files.
//
// To see if there are any records in the file, one must subtract the
// EndOffset from the StartOffset (allowing for the file having wrapped
// around) and check for a difference of greater than 1.
//
// The header size is stored at the beginning and end so that it looks
// just like any other event log record (the lengths do at any rate).
//
typedef struct _ELF_LOGFILE_HEADER {
ULONG HeaderSize; // Size of this header
ULONG Signature; // Signature field
ULONG MajorVersion;
ULONG MinorVersion;
ULONG StartOffset; // Where the first record is located
ULONG EndOffset; // The end of the last record + 1
ULONG CurrentRecordNumber; // The next record to create
ULONG OldestRecordNumber; // The next record to overwrite
ULONG MaxSize; // Max. size when file was created
ULONG Flags; // DIRTY, etc.
ULONG Retention; // Last Retention period.
ULONG EndHeaderSize; // Size of this header
} ELF_LOGFILE_HEADER, *PELF_LOGFILE_HEADER;
#define FILEHEADERBUFSIZE sizeof(ELF_LOGFILE_HEADER)
#define ELF_LOG_FILE_SIGNATURE 0x654c664c // ASCII for eLfL
//
// The following flag bits are used in ELF_LOGFILE_HEADER and in the
// LOGFILE structures' Flag fields.
//
#define ELF_LOGFILE_HEADER_DIRTY 0x0001 // File has been written to
#define ELF_LOGFILE_HEADER_WRAP 0x0002 // The file has wrapped
#define ELF_LOGFILE_LOGFULL_WRITTEN 0x0004 // Written logfull record
#define ELF_LOGFILE_ARCHIVE_SET 0x0008 // Archive bit flag
//
// Structure that defines the record that identifies the end of the
// circular log file.
// This record is used to identify where the last record in the circular
// buffer is located.
//
// NOTE: It is *essential* that this record is of a size that a "normal"
// event log record can never have. There is code that relies on
// this fact to detect an "EOF" record.
//
// Care must be taken to not disturb the first part of this record. It
// is used to identify an EOF record. ELFEOFUNIQUEPART must be the
// number of bytes that are constant.
//
typedef struct _ELF_EOF_RECORD {
ULONG RecordSizeBeginning;
ULONG One;
ULONG Two;
ULONG Three;
ULONG Four;
ULONG BeginRecord;
ULONG EndRecord;
ULONG CurrentRecordNumber;
ULONG OldestRecordNumber;
ULONG RecordSizeEnd;
} ELF_EOF_RECORD, *PELF_EOF_RECORD;
#define ELFEOFRECORDSIZE sizeof (ELF_EOF_RECORD)
//
// The following constant is how much of the EOF record is constant, and can
// be used to identify an EOF record
//
#define ELFEOFUNIQUEPART 5 * sizeof(ULONG)
//
// This is used to fill the end of a log record so that the fixed portion
// of a log record doesn't split the end of the file. It must be less than
// the minimum size of any valid record
//
#define ELF_SKIP_DWORD sizeof(ELF_EOF_RECORD) - 1
//
// Time for the sender of a start or stop request to the Eventlog
// service to wait (in milliseconds) before checking on the
// Eventlog service again to see if it is done
//
#define ELF_WAIT_HINT_TIME 20000 // 20 seconds
//
// Flags used by ElfpCloseLogFile
//
#define ELF_LOG_CLOSE_NORMAL 0x0000
#define ELF_LOG_CLOSE_FORCE 0x0001
#define ELF_LOG_CLOSE_BACKUP 0x0002
//
// Structure used to store information read from the registry
//
typedef struct _LOG_FILE_INFO {
PUNICODE_STRING LogFileName;
ULONG MaxFileSize;
ULONG Retention;
ULONG GuestAccessRestriction;
LOGPOPUP logpLogPopup;
DWORD dwAutoBackup;
} LOG_FILE_INFO, *PLOG_FILE_INFO;
//
// DEBUG stuff.
//
//
// This signature is placed in the context handle for debug purposes only,
// to track down a bug in freeing the structures.
//
#define ELF_CONTEXTHANDLE_SIGN 0x654c6648 // ASCII for eLfH
//
// The different file open (or create) options are based on the type of file.
// The types, and their meanings are:
//
// ElfNormalLog Normal log file, opened for cached io
// ElfSecurityLog Audit logs, opened for write-thru
// ElfBackupLog Not an active log file, opened read only, cached
//
typedef enum _ELF_LOG_TYPE {
ElfNormalLog,
ElfSecurityLog,
ElfBackupLog
} ELF_LOG_TYPE, *PELF_LOG_TYPE;
//
// Eventlog States (used as return codes)
//
#define UPDATE_ONLY 0 // no change in state - just send current status.
#define STARTING 1 // the messenger is initializing.
#define RUNNING 2 // initialization completed normally - now running
#define STOPPING 3 // uninstall pending
#define STOPPED 4 // uninstalled
#define PAUSED 5 // Paused
#define PAUSING 6 // In the process of pausing
#define CONTINUING 7 // In the process of continuing
//
// Forced Shutdown PendingCodes
//
#define PENDING TRUE
#define IMMEDIATE FALSE
//
// defines for reliability logging
//
#define DEFAULT_INTERVAL 0
#define SHUTDOWN_UNPLANNED 0x80000000
#define SHUTDOWN_REASON_MASK 0xFFFF
typedef enum _TIMESTAMPEVENT{
EVENT_Boot=0,
EVENT_NormalShutdown,
EVENT_AbNormalShutdown
} TIMESTAMPEVENT, *PTIMESTAMPEVENT;
//SS:Clustering specific extensions
typedef struct _PROPLOGFILEINFO{
PLOGFILE pLogFile;
PVOID pStartPosition;
PVOID pEndPosition;
ULONG ulTotalEventSize;
ULONG ulNumRecords;
}PROPLOGFILEINFO, *PPROPLOGFILEINFO;
//structure for propagation is preallocated.
#define MAXSIZE_OF_EVENTSTOPROP (1 * 1024)
#endif // ifndef _EVENTDEF_