plaso-rubanetra/plaso/formatters/winreg.py

82 lines
2.8 KiB
Python
Raw Normal View History

2020-04-06 16:48:34 +00:00
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
# Copyright 2013 The Plaso Project Authors.
# Please see the AUTHORS file for details on individual authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Formatter for Windows NT Registry (REGF) files."""
from plaso.lib import errors
from plaso.formatters import interface
class WinRegistryGenericFormatter(interface.EventFormatter):
"""Formatter for a generic Windows Registry key or value."""
DATA_TYPE = 'windows:registry:key_value'
FORMAT_STRING = u'[{keyname}] {text}'
FORMAT_STRING_ALTERNATIVE = u'{text}'
SOURCE_LONG = 'Registry Key'
SOURCE_SHORT = 'REG'
def GetMessages(self, event_object):
"""Returns a list of messages extracted from an event object.
Args:
event_object: The event object (EventObject) containing the event
specific data.
Returns:
A list that contains both the longer and shorter version of the message
string.
"""
if self.DATA_TYPE != event_object.data_type:
raise errors.WrongFormatter(u'Unsupported data type: {0:s}.'.format(
event_object.data_type))
regvalue = getattr(event_object, 'regvalue', {})
string_parts = []
for key, value in sorted(regvalue.items()):
string_parts.append(u'{0:s}: {1!s}'.format(key, value))
text = u' '.join(string_parts)
event_object.text = text
if hasattr(event_object, 'keyname'):
self.format_string = self.FORMAT_STRING
else:
self.format_string = self.FORMAT_STRING_ALTERNATIVE
return super(WinRegistryGenericFormatter, self).GetMessages(event_object)
def GetSources(self, event_object):
"""Returns a list of source short and long messages for the event."""
if self.DATA_TYPE != event_object.data_type:
raise errors.WrongFormatter(u'Unsupported data type: {0:s}.'.format(
event_object.data_type))
self.source_string = getattr(event_object, 'source_long', None)
if not self.source_string:
registry_type = getattr(event_object, 'registry_type', 'UNKNOWN')
self.source_string = u'{0:s} key'.format(registry_type)
if hasattr(event_object, 'source_append'):
self.source_string += u' {0:s}'.format(event_object.source_append)
return super(WinRegistryGenericFormatter, self).GetSources(event_object)