Skip to content

Commit

Permalink
xml/filterx-parse-windows-eventlog-xml: add quick validation
Browse files Browse the repository at this point in the history
Signed-off-by: Attila Szakacs <[email protected]>
  • Loading branch information
alltilla committed Sep 18, 2024
1 parent fc22cf8 commit ebd6a1b
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 9 deletions.
61 changes: 52 additions & 9 deletions modules/xml/filterx-parse-windows-eventlog-xml.c
Original file line number Diff line number Diff line change
Expand Up @@ -148,25 +148,67 @@ _collect_attrs(const gchar **attribute_names, const gchar **attribute_values,
state->has_named_data = TRUE;
}

static void
_push_position(FilterXParseWEVTState *state, const gchar *element_name)
static gboolean
_has_valid_schema_url(const gchar **attribute_names, const gchar **attribute_values, GError **error)
{
if (!attribute_names[0])
return FALSE;

if (g_strcmp0(attribute_names[0], "xmlns") != 0)
return FALSE;

if (g_strcmp0(attribute_values[0], "http://schemas.microsoft.com/win/2004/08/events/event") != 0)
{
_set_error(error, "unexpected schema URL: %s", attribute_values[0]);
return FALSE;
}

if (attribute_names[1])
{
_set_error(error, "unexpected attribute in Event, number of attributes must be 1, got: %s", attribute_names[1]);
return FALSE;
}

return TRUE;
}

static gboolean
_is_root_elem_valid(const gchar *element_name, const gchar **attribute_names, const gchar **attribute_values,
GError **error)
{
if (g_strcmp0(element_name, "Event") != 0)
{
_set_error(error, "unexpected Windows EventLog XML root element: %s, expected \"Event\"", element_name);
return FALSE;
}

if (!_has_valid_schema_url(attribute_names, attribute_values, error))
return FALSE;

return TRUE;
}

static gboolean
_push_position(FilterXParseWEVTState *state, const gchar *element_name,
const gchar **attribute_names, const gchar **attribute_values, GError **error)
{
switch (state->position)
{
case WEVT_POS_NONE:
if (g_strcmp0(element_name, "Event") == 0)
state->position = WEVT_POS_EVENT;
break;
if (!_is_root_elem_valid(element_name, attribute_names, attribute_values, error))
return FALSE;
state->position = WEVT_POS_EVENT;
return TRUE;
case WEVT_POS_EVENT:
if (g_strcmp0(element_name, "EventData") == 0)
state->position = WEVT_POS_EVENT_DATA;
break;
return TRUE;
case WEVT_POS_EVENT_DATA:
if (g_strcmp0(element_name, "Data") == 0)
state->position = WEVT_POS_DATA;
break;
return TRUE;
case WEVT_POS_DATA:
break;
return TRUE;
default:
g_assert_not_reached();
}
Expand Down Expand Up @@ -229,7 +271,8 @@ _start_elem(FilterXGeneratorFunctionParseXml *s,
FilterXParseWEVTState *state = (FilterXParseWEVTState *) st;
XmlElemContext *last_elem_context = xml_elem_context_stack_peek_last(state->super.xml_elem_context_stack);

_push_position(state, element_name);
if (!_push_position(state, element_name, attribute_names, attribute_values, error))
return;

if (!_has_wevt_event_data_attr(attribute_names, state, error))
{
Expand Down
2 changes: 2 additions & 0 deletions modules/xml/tests/test_filterx_parse_windows_eventlog_xml.c
Original file line number Diff line number Diff line change
Expand Up @@ -182,6 +182,8 @@ Test(filterx_parse_windows_eventlog_xml, invalid_inputs)
{
_assert_parse_event_data_fail("<Data almafa='param1'>foo</Data>\n");
_assert_parse_event_data_fail("<Data Name='param1' almafa='kortefa'>foo</Data>\n");
_assert_parse_fail("<Event xmlns='http://unexpected.schema.url'></Event>");
_assert_parse_fail("<NotEvent xmlns='http://schemas.microsoft.com/win/2004/08/events/event'></NotEvent>");
}

static void
Expand Down

0 comments on commit ebd6a1b

Please sign in to comment.