64 lines
1.9 KiB
Python
64 lines
1.9 KiB
Python
#!/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 firewall log files."""
|
|
|
|
from plaso.formatters import interface
|
|
|
|
|
|
class WinFirewallFormatter(interface.ConditionalEventFormatter):
|
|
"""A formatter for Windows firewall log entries."""
|
|
|
|
DATA_TYPE = 'windows:firewall:log_entry'
|
|
|
|
# TODO: Add more "elegant" formatting, as in transform ICMP code/type into
|
|
# a more human readable format as well as translating the additional info
|
|
# column (meaning may depend on action field).
|
|
FORMAT_STRING_PIECES = [
|
|
u'{action}',
|
|
u'[',
|
|
u'{protocol}',
|
|
u'{path}',
|
|
u']',
|
|
u'From: {source_ip}',
|
|
u':{source_port}',
|
|
u'>',
|
|
u'{dest_ip}',
|
|
u':{dest_port}',
|
|
u'Size (bytes): {size}',
|
|
u'Flags [{flags}]',
|
|
u'TCP Seq Number: {tcp_seq}',
|
|
u'TCP ACK Number: {tcp_ack}',
|
|
u'TCP Window Size (bytes): {tcp_win}',
|
|
u'ICMP type: {icmp_type}',
|
|
u'ICMP code: {icmp_code}',
|
|
u'Additional info: {info}',
|
|
]
|
|
|
|
FORMAT_STRING_SHORT_PIECES = [
|
|
u'{action}',
|
|
u'[{protocol}]',
|
|
u'{source_ip}',
|
|
u': {source_port}',
|
|
u'>',
|
|
u'{dest_ip}',
|
|
u': {dest_port}',
|
|
]
|
|
|
|
SOURCE_LONG = 'Windows Firewall Log'
|
|
SOURCE_SHORT = 'LOG'
|