Source code for plaso.formatters.winevt

# -*- coding: utf-8 -*-
"""The Windows EventLog (EVT) file event formatter."""

from __future__ import unicode_literals

from plaso.formatters import interface
from plaso.formatters import manager
from plaso.lib import errors


[docs]class WinEVTFormatter(interface.ConditionalEventFormatter): """Formatter for a Windows EventLog (EVT) record event.""" DATA_TYPE = 'windows:evt:record' # TODO: add string representation of facility. FORMAT_STRING_PIECES = [ '[{event_identifier} /', '0x{event_identifier:04x}]', 'Source Name: {source_name}', 'Message string: {message_string}', 'Strings: {strings}', 'Computer Name: {computer_name}', 'Severity: {severity}', 'Record Number: {record_number}', 'Event Type: {event_type}', 'Event Category: {event_category}'] FORMAT_STRING_SHORT_PIECES = [ '[{event_identifier} /', '0x{event_identifier:04x}]', 'Strings: {strings}'] SOURCE_LONG = 'WinEVT' SOURCE_SHORT = 'EVT' # Mapping of the numeric event types to a descriptive string. _EVENT_TYPES = [ 'Error event', 'Warning event', 'Information event', 'Success Audit event', 'Failure Audit event'] _SEVERITY = [ 'Success', 'Informational', 'Warning', 'Error']
[docs] def GetEventTypeString(self, event_type): """Retrieves a string representation of the event type. Args: event_type (int): event type. Returns: str: description of the event type. """ if event_type >= 0 and event_type < len(self._EVENT_TYPES): return self._EVENT_TYPES[event_type]
return 'Unknown {0:d}'.format(event_type)
[docs] def GetSeverityString(self, severity): """Retrieves a string representation of the severity. Args: severity (int): severity. Returns: str: description of the event severity. """ if severity >= 0 and severity < len(self._SEVERITY): return self._SEVERITY[severity]
return 'Unknown {0:d}'.format(severity)
[docs] def GetMessages(self, formatter_mediator, event): """Determines the formatted message strings for an event object. Args: formatter_mediator (FormatterMediator): mediates the interactions between formatters and other components, such as storage and Windows EventLog resources. event (EventObject): event. Returns: tuple(str, str): formatted message string and short message string. Raises: WrongFormatter: if the event object cannot be formatted by the formatter. """ if self.DATA_TYPE != event.data_type: raise errors.WrongFormatter('Unsupported data type: {0:s}.'.format( event.data_type)) event_values = event.CopyToDict() event_type = event_values.get('event_type', None) if event_type is not None: event_values['event_type'] = self.GetEventTypeString(event_type) # TODO: add string representation of facility. severity = event_values.get('severity', None) if severity is not None: event_values['severity'] = self.GetSeverityString(severity) source_name = event_values.get('source_name', None) message_identifier = event_values.get('message_identifier', None) strings = event_values.get('strings', []) if source_name and message_identifier: message_string = formatter_mediator.GetWindowsEventMessage( source_name, message_identifier) if message_string: try: event_values['message_string'] = message_string.format(*strings) except IndexError: # Unable to create the message string. pass message_strings = [] for string in strings: message_strings.append('\'{0:s}\''.format(string)) message_string = ', '.join(message_strings) event_values['strings'] = '[{0:s}]'.format(message_string)
return self._ConditionalFormatMessages(event_values) manager.FormattersManager.RegisterFormatter(WinEVTFormatter)