Source code for plaso.preprocessors.windows

# -*- coding: utf-8 -*-
"""This file contains preprocessors for Windows."""

from __future__ import unicode_literals

from plaso.containers import artifacts
from plaso.lib import errors
from plaso.lib import py2to3
from plaso.preprocessors import interface
from plaso.preprocessors import logger
from plaso.preprocessors import manager
from plaso.winnt import time_zones


[docs]class WindowsEnvironmentVariableArtifactPreprocessorPlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """Windows environment variable artifact preprocessor plugin interface.""" _NAME = None def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) environment_variable = artifacts.EnvironmentVariableArtifact( case_sensitive=False, name=self._NAME, value=value_data) try: knowledge_base.AddEnvironmentVariable(environment_variable) except KeyError: # TODO: add and store preprocessing errors.
pass
[docs]class WindowsPathEnvironmentVariableArtifactPreprocessorPlugin( interface.FileSystemArtifactPreprocessorPlugin): """Windows path environment variable plugin interface.""" _NAME = None def _ParsePathSpecification( self, knowledge_base, searcher, file_system, path_specification, path_separator): """Parses artifact file system data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. searcher (dfvfs.FileSystemSearcher): file system searcher to preprocess the file system. file_system (dfvfs.FileSystem): file system to be preprocessed. path_specification (dfvfs.PathSpec): path specification that contains the artifact value data. path_separator (str): path segment separator. Raises: errors.PreProcessFail: if the preprocessing fails. """ relative_path = searcher.GetRelativePath(path_specification) if not relative_path: raise errors.PreProcessFail( 'Unable to read: {0:s} with error: missing relative path'.format( self.ARTIFACT_DEFINITION_NAME)) if path_separator != file_system.PATH_SEPARATOR: relative_path_segments = file_system.SplitPath(relative_path) relative_path = '{0:s}{1:s}'.format( path_separator, path_separator.join(relative_path_segments)) evironment_variable = artifacts.EnvironmentVariableArtifact( case_sensitive=False, name=self._NAME, value=relative_path) try: knowledge_base.AddEnvironmentVariable(evironment_variable) except KeyError: # TODO: add and store preprocessing errors.
pass
[docs]class WindowsCodepagePlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """The Windows codepage plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsCodePage' def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) # Map the Windows code page name to a Python equivalent name. codepage = 'cp{0:s}'.format(value_data) if not knowledge_base.codepage: try: knowledge_base.SetCodepage(codepage) except ValueError: # TODO: add and store preprocessing errors.
pass
[docs]class WindowsHostnamePlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """The Windows hostname plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsComputerName' def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) if not knowledge_base.GetHostname(): hostname_artifact = artifacts.HostnameArtifact(name=value_data)
knowledge_base.SetHostname(hostname_artifact)
[docs]class WindowsProgramFilesEnvironmentVariablePlugin( WindowsEnvironmentVariableArtifactPreprocessorPlugin): """The Windows %ProgramFiles% environment variable plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsEnvironmentVariableProgramFiles'
_NAME = 'programfiles'
[docs]class WindowsProgramFilesX86EnvironmentVariablePlugin( WindowsEnvironmentVariableArtifactPreprocessorPlugin): """The Windows %ProgramFilesX86% environment variable plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsEnvironmentVariableProgramFilesX86'
_NAME = 'programfilesx86'
[docs]class WindowsSystemProductPlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """The Windows system product information plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsProductName' def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) if not knowledge_base.GetValue('operating_system_product'):
knowledge_base.SetValue('operating_system_product', value_data)
[docs]class WindowsSystemRootEnvironmentVariablePlugin( WindowsPathEnvironmentVariableArtifactPreprocessorPlugin): """The Windows %SystemRoot% environment variable plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsEnvironmentVariableSystemRoot'
_NAME = 'systemroot'
[docs]class WindowsSystemVersionPlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """The Windows system version information plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsCurrentVersion' def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) if not knowledge_base.GetValue('operating_system_version'):
knowledge_base.SetValue('operating_system_version', value_data)
[docs]class WindowsTimeZonePlugin( interface.WindowsRegistryValueArtifactPreprocessorPlugin): """The Windows time zone plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsTimezone' def _ParseValueData(self, knowledge_base, value_data): """Parses Windows Registry value data for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. value_data (object): Windows Registry value data. Raises: errors.PreProcessFail: if the preprocessing fails. """ if not isinstance(value_data, py2to3.UNICODE_TYPE): raise errors.PreProcessFail( 'Unsupported Windows Registry value type: {0:s} for ' 'artifact: {1:s}.'.format( type(value_data), self.ARTIFACT_DEFINITION_NAME)) # Map the Windows time zone name to a Python equivalent name. lookup_key = value_data.replace(' ', '') time_zone = time_zones.TIME_ZONES.get(lookup_key, value_data) # TODO: check if time zone is set in knowledge base. if time_zone: try: # Catch and warn about unsupported preprocessor plugin. knowledge_base.SetTimeZone(time_zone) except ValueError: # TODO: add and store preprocessing errors. time_zone = value_data logger.warning('Unable to map: "{0:s}" to time zone'.format(
value_data))
[docs]class WindowsUserAccountsPlugin( interface.WindowsRegistryKeyArtifactPreprocessorPlugin): """The Windows user account plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsRegistryProfiles' def _GetUsernameFromProfilePath(self, path): """Retrieves the username from a Windows profile path. Trailing path path segment are ignored. Args: path (str): a Windows path with '\\' as path segment separator. Returns: str: basename which is the last path segment. """ # Strip trailing key separators. while path and path[-1] == '\\': path = path[:-1] if path: _, _, path = path.rpartition('\\') return path def _ParseKey(self, knowledge_base, registry_key, value_name): """Parses a Windows Registry key for a preprocessing attribute. Args: knowledge_base (KnowledgeBase): to fill with preprocessing information. registry_key (dfwinreg.WinRegistryKey): Windows Registry key. value_name (str): name of the Windows Registry value. Raises: errors.PreProcessFail: if the preprocessing fails. """ user_account = artifacts.UserAccountArtifact( identifier=registry_key.name) registry_value = registry_key.GetValueByName('ProfileImagePath') if registry_value: profile_path = registry_value.GetDataAsObject() username = self._GetUsernameFromProfilePath(profile_path) user_account.user_directory = profile_path or None user_account.username = username or None try: knowledge_base.AddUserAccount(user_account) except KeyError: # TODO: add and store preprocessing errors.
pass
[docs]class WindowsWinDirEnvironmentVariablePlugin( WindowsPathEnvironmentVariableArtifactPreprocessorPlugin): """The Windows %WinDir% environment variable plugin.""" ARTIFACT_DEFINITION_NAME = 'WindowsEnvironmentVariableWinDir'
_NAME = 'windir' manager.PreprocessPluginsManager.RegisterPlugins([ WindowsCodepagePlugin, WindowsHostnamePlugin, WindowsProgramFilesEnvironmentVariablePlugin, WindowsProgramFilesX86EnvironmentVariablePlugin, WindowsSystemProductPlugin, WindowsSystemRootEnvironmentVariablePlugin, WindowsSystemVersionPlugin, WindowsTimeZonePlugin, WindowsWinDirEnvironmentVariablePlugin, WindowsUserAccountsPlugin])