forked from axoflow/axosyslog
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfilterx-eval.h
126 lines (110 loc) · 4.06 KB
/
filterx-eval.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
* Copyright (c) 2023 Balazs Scheidler <balazs.scheidler@axoflow.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* As an additional exemption you are allowed to compile & link against the
* OpenSSL libraries as published by the OpenSSL project. See the file
* COPYING for details.
*
*/
#ifndef FILTERX_EVAL_H_INCLUDED
#define FILTERX_EVAL_H_INCLUDED
#include "filterx/filterx-scope.h"
#include "filterx/filterx-expr.h"
#include "filterx/filterx-error.h"
#include "template/eval.h"
typedef enum _FilterXEvalResult
{
FXE_SUCCESS,
FXE_FAILURE,
FXE_DROP,
} FilterXEvalResult;
typedef enum _FilterXEvalControl
{
FXC_NOTSET,
FXC_DROP,
FXC_DONE
} FilterXEvalControl;
typedef struct _FilterXEvalContext FilterXEvalContext;
struct _FilterXEvalContext
{
LogMessage **msgs;
gint num_msg;
FilterXScope *scope;
FilterXError error;
LogTemplateEvalOptions template_eval_options;
GPtrArray *weak_refs;
FilterXEvalControl eval_control_modifier;
FilterXEvalContext *previous_context;
};
FilterXEvalContext *filterx_eval_get_context(void);
FilterXScope *filterx_eval_get_scope(void);
void filterx_eval_push_error(const gchar *message, FilterXExpr *expr, FilterXObject *object);
void filterx_eval_push_error_info(const gchar *message, FilterXExpr *expr, gchar *info, gboolean free_info);
void filterx_eval_set_context(FilterXEvalContext *context);
FilterXEvalResult filterx_eval_exec(FilterXEvalContext *context, FilterXExpr *expr, LogMessage *msg);
const gchar *filterx_eval_get_last_error(void);
EVTTAG *filterx_format_last_error(void);
EVTTAG *filterx_format_last_error_location(void);
void filterx_eval_clear_errors(void);
EVTTAG *filterx_format_eval_result(FilterXEvalResult result);
void filterx_eval_init_context(FilterXEvalContext *context, FilterXEvalContext *previous_context);
void filterx_eval_deinit_context(FilterXEvalContext *context);
static inline void
filterx_eval_sync_message(FilterXEvalContext *context, LogMessage **pmsg, const LogPathOptions *path_options)
{
if (!context)
return;
if (!filterx_scope_is_dirty(context->scope))
return;
log_msg_make_writable(pmsg, path_options);
filterx_scope_sync(context->scope, *pmsg);
}
static inline void
filterx_eval_prepare_for_fork(FilterXEvalContext *context, LogMessage **pmsg, const LogPathOptions *path_options)
{
filterx_eval_sync_message(context, pmsg, path_options);
if (context)
filterx_scope_write_protect(context->scope);
}
/*
* This is not a real weakref implementation as we will never get rid off
* weak references until the very end of a scope. If this wasn't the case
* we would have to:
* 1) run a proper GC
* 2) notify weak references once the object is detroyed
*
* None of that exists now and I doubt ever will (but never say never).
* Right now a weak ref is destroyed as a part of the scope finalization
* process at which point circular references will be broken so the rest can
* go too.
*/
static inline void
filterx_eval_store_weak_ref(FilterXObject *object)
{
/* Frozen objects do not need weak refs. */
if (object && filterx_object_is_frozen(object))
return;
if (object && !object->weak_referenced)
{
FilterXEvalContext *context = filterx_eval_get_context();
/* avoid putting object to the list multiple times */
object->weak_referenced = TRUE;
g_assert(context->weak_refs);
g_ptr_array_add(context->weak_refs, filterx_object_ref(object));
}
}
#endif