• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

OISF / suricata / 22550902417

01 Mar 2026 07:32PM UTC coverage: 68.401% (-5.3%) from 73.687%
22550902417

Pull #14922

github

web-flow
github-actions: bump actions/upload-artifact from 6.0.0 to 7.0.0

Bumps [actions/upload-artifact](https://github.com/actions/upload-artifact) from 6.0.0 to 7.0.0.
- [Release notes](https://github.com/actions/upload-artifact/releases)
- [Commits](https://github.com/actions/upload-artifact/compare/v6...v7)

---
updated-dependencies:
- dependency-name: actions/upload-artifact
  dependency-version: 7.0.0
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
Pull Request #14922: github-actions: bump actions/upload-artifact from 6.0.0 to 7.0.0

218243 of 319063 relevant lines covered (68.4%)

3284926.58 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

84.16
/src/detect-http-method.c
1
/* Copyright (C) 2007-2019 Open Information Security Foundation
2
 *
3
 * You can copy, redistribute or modify this Program under the terms of
4
 * the GNU General Public License version 2 as published by the Free
5
 * Software Foundation.
6
 *
7
 * This program is distributed in the hope that it will be useful,
8
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10
 * GNU General Public License for more details.
11
 *
12
 * You should have received a copy of the GNU General Public License
13
 * version 2 along with this program; if not, write to the Free Software
14
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
15
 * 02110-1301, USA.
16
 */
17

18
/**
19
 * \ingroup httplayer
20
 *
21
 * @{
22
 */
23

24

25
/**
26
 * \file
27
 *
28
 * \author Brian Rectanus <brectanu@gmail.com>
29
 *
30
 * Implements the http_method keyword
31
 */
32

33
#include "suricata-common.h"
34
#include "threads.h"
35
#include "decode.h"
36
#include "detect.h"
37

38
#include "detect-parse.h"
39
#include "detect-engine.h"
40
#include "detect-engine-buffer.h"
41
#include "detect-engine-mpm.h"
42
#include "detect-engine-prefilter.h"
43
#include "detect-content.h"
44
#include "detect-pcre.h"
45

46
#include "flow.h"
47
#include "flow-var.h"
48
#include "flow-util.h"
49

50
#include "util-debug.h"
51
#include "util-unittest.h"
52
#include "util-unittest-helper.h"
53
#include "util-spm.h"
54

55
#include "app-layer.h"
56
#include "app-layer-parser.h"
57

58
#include "app-layer-htp.h"
59
#include "detect-http-method.h"
60
#include "stream-tcp.h"
61

62
static int g_http_method_buffer_id = 0;
63
static int DetectHttpMethodSetup(DetectEngineCtx *, Signature *, const char *);
64
static int DetectHttpMethodSetupSticky(DetectEngineCtx *de_ctx, Signature *s, const char *str);
65
#ifdef UNITTESTS
66
void DetectHttpMethodRegisterTests(void);
67
#endif
68
void DetectHttpMethodFree(void *);
69
static bool DetectHttpMethodValidateCallback(
70
        const Signature *s, const char **sigerror, const DetectBufferType *dbt);
71
static InspectionBuffer *GetData(DetectEngineThreadCtx *det_ctx,
72
        const DetectEngineTransforms *transforms, Flow *_f,
73
        const uint8_t _flow_flags, void *txv, const int list_id);
74
static InspectionBuffer *GetData2(DetectEngineThreadCtx *det_ctx,
75
        const DetectEngineTransforms *transforms, Flow *_f, const uint8_t _flow_flags, void *txv,
76
        const int list_id);
77

78
/**
79
 * \brief Registration function for keyword: http_method
80
 */
81
void DetectHttpMethodRegister(void)
82
{
37✔
83
    /* http_method content modifier */
84
    sigmatch_table[DETECT_HTTP_METHOD_CM].name = "http_method";
37✔
85
    sigmatch_table[DETECT_HTTP_METHOD_CM].desc =
37✔
86
            "content modifier to match only on the HTTP method-buffer";
37✔
87
    sigmatch_table[DETECT_HTTP_METHOD_CM].url = "/rules/http-keywords.html#http-method";
37✔
88
    sigmatch_table[DETECT_HTTP_METHOD_CM].Match = NULL;
37✔
89
    sigmatch_table[DETECT_HTTP_METHOD_CM].Setup = DetectHttpMethodSetup;
37✔
90
#ifdef UNITTESTS
3✔
91
    sigmatch_table[DETECT_HTTP_METHOD_CM].RegisterTests = DetectHttpMethodRegisterTests;
3✔
92
#endif
3✔
93
    sigmatch_table[DETECT_HTTP_METHOD_CM].flags |= SIGMATCH_NOOPT | SIGMATCH_INFO_CONTENT_MODIFIER;
37✔
94
    sigmatch_table[DETECT_HTTP_METHOD_CM].alternative = DETECT_HTTP_METHOD;
37✔
95

96
    /* http.method sticky buffer */
97
    sigmatch_table[DETECT_HTTP_METHOD].name = "http.method";
37✔
98
    sigmatch_table[DETECT_HTTP_METHOD].desc = "sticky buffer to match specifically and only on the HTTP method buffer";
37✔
99
    sigmatch_table[DETECT_HTTP_METHOD].url = "/rules/http-keywords.html#http-method";
37✔
100
    sigmatch_table[DETECT_HTTP_METHOD].Setup = DetectHttpMethodSetupSticky;
37✔
101
    sigmatch_table[DETECT_HTTP_METHOD].flags |= SIGMATCH_NOOPT|SIGMATCH_INFO_STICKY_BUFFER;
37✔
102

103
    DetectAppLayerInspectEngineRegister("http_method", ALPROTO_HTTP1, SIG_FLAG_TOSERVER,
37✔
104
            HTP_REQUEST_PROGRESS_LINE, DetectEngineInspectBufferGeneric, GetData);
37✔
105

106
    DetectAppLayerMpmRegister("http_method", SIG_FLAG_TOSERVER, 4, PrefilterGenericMpmRegister,
37✔
107
            GetData, ALPROTO_HTTP1, HTP_REQUEST_PROGRESS_LINE);
37✔
108

109
    DetectAppLayerInspectEngineRegister("http_method", ALPROTO_HTTP2, SIG_FLAG_TOSERVER,
37✔
110
            HTTP2StateDataClient, DetectEngineInspectBufferGeneric, GetData2);
37✔
111

112
    DetectAppLayerMpmRegister("http_method", SIG_FLAG_TOSERVER, 4, PrefilterGenericMpmRegister,
37✔
113
            GetData2, ALPROTO_HTTP2, HTTP2StateDataClient);
37✔
114

115
    DetectBufferTypeSetDescriptionByName("http_method",
37✔
116
            "http request method");
37✔
117

118
    DetectBufferTypeRegisterValidateCallback("http_method",
37✔
119
            DetectHttpMethodValidateCallback);
37✔
120

121
    g_http_method_buffer_id = DetectBufferTypeGetByName("http_method");
37✔
122

123
    SCLogDebug("registering http_method rule option");
37✔
124
}
37✔
125

126
/**
127
 * \brief This function is used to add the parsed "http_method" option
128
 *        into the current signature.
129
 *
130
 * \param de_ctx Pointer to the Detection Engine Context.
131
 * \param s      Pointer to the Current Signature.
132
 * \param str    Pointer to the user provided option string.
133
 *
134
 * \retval  0 on Success.
135
 * \retval -1 on Failure.
136
 */
137
static int DetectHttpMethodSetup(DetectEngineCtx *de_ctx, Signature *s, const char *str)
138
{
111✔
139
    return DetectEngineContentModifierBufferSetup(
111✔
140
            de_ctx, s, str, DETECT_HTTP_METHOD_CM, g_http_method_buffer_id, ALPROTO_HTTP1);
111✔
141
}
111✔
142

143
/**
144
 * \brief this function setup the http.method keyword used in the rule
145
 *
146
 * \param de_ctx   Pointer to the Detection Engine Context
147
 * \param s        Pointer to the Signature to which the current keyword belongs
148
 * \param str      Should hold an empty string always
149
 *
150
 * \retval 0       On success
151
 */
152
static int DetectHttpMethodSetupSticky(DetectEngineCtx *de_ctx, Signature *s, const char *str)
153
{
7,201✔
154
    if (SCDetectBufferSetActiveList(de_ctx, s, g_http_method_buffer_id) < 0)
7,201✔
155
        return -1;
×
156

157
    if (SCDetectSignatureSetAppProto(s, ALPROTO_HTTP) < 0)
7,201✔
158
        return -1;
×
159

160
    return 0;
7,201✔
161
}
7,201✔
162

163
/**
164
 *  \retval 1 valid
165
 *  \retval 0 invalid
166
 */
167
static bool DetectHttpMethodValidateCallback(
168
        const Signature *s, const char **sigerror, const DetectBufferType *dbt)
169
{
7,259✔
170
    for (uint32_t x = 0; x < s->init_data->buffer_index; x++) {
29,327✔
171
        if (s->init_data->buffers[x].id != (uint32_t)dbt->id)
22,068✔
172
            continue;
14,809✔
173
        const SigMatch *sm = s->init_data->buffers[x].head;
7,259✔
174
        for (; sm != NULL; sm = sm->next) {
14,557✔
175
            if (sm->type != DETECT_CONTENT)
7,298✔
176
                continue;
38✔
177
            const DetectContentData *cd = (const DetectContentData *)sm->ctx;
7,260✔
178
            if (cd->content && cd->content_len) {
7,260✔
179
                if (cd->content[cd->content_len - 1] == 0x20) {
7,260✔
180
                    *sigerror = "http_method pattern with trailing space";
×
181
                    SCLogError("%s", *sigerror);
×
182
                    return false;
×
183
                } else if (cd->content[0] == 0x20) {
7,260✔
184
                    *sigerror = "http_method pattern with leading space";
×
185
                    SCLogError("%s", *sigerror);
×
186
                    return false;
×
187
                } else if (cd->content[cd->content_len - 1] == 0x09) {
7,260✔
188
                    *sigerror = "http_method pattern with trailing tab";
×
189
                    SCLogError("%s", *sigerror);
×
190
                    return false;
×
191
                } else if (cd->content[0] == 0x09) {
7,260✔
192
                    *sigerror = "http_method pattern with leading tab";
×
193
                    SCLogError("%s", *sigerror);
×
194
                    return false;
×
195
                }
×
196
            }
7,260✔
197
        }
7,260✔
198
    }
7,259✔
199
    return true;
7,259✔
200
}
7,259✔
201

202
static InspectionBuffer *GetData(DetectEngineThreadCtx *det_ctx,
203
        const DetectEngineTransforms *transforms, Flow *_f,
204
        const uint8_t _flow_flags, void *txv, const int list_id)
205
{
5,672✔
206
    InspectionBuffer *buffer = InspectionBufferGet(det_ctx, list_id);
5,672✔
207
    if (buffer->inspect == NULL) {
5,672✔
208
        htp_tx_t *tx = (htp_tx_t *)txv;
2,402✔
209

210
        if (htp_tx_request_method(tx) == NULL)
2,402✔
211
            return NULL;
79✔
212

213
        const uint32_t data_len = (uint32_t)bstr_len(htp_tx_request_method(tx));
2,323✔
214
        const uint8_t *data = bstr_ptr(htp_tx_request_method(tx));
2,323✔
215

216
        InspectionBufferSetupAndApplyTransforms(
2,323✔
217
                det_ctx, list_id, buffer, data, data_len, transforms);
2,323✔
218
    }
2,323✔
219

220
    return buffer;
5,593✔
221
}
5,672✔
222

223
static InspectionBuffer *GetData2(DetectEngineThreadCtx *det_ctx,
224
        const DetectEngineTransforms *transforms, Flow *_f, const uint8_t _flow_flags, void *txv,
225
        const int list_id)
226
{
202✔
227
    InspectionBuffer *buffer = InspectionBufferGet(det_ctx, list_id);
202✔
228
    if (buffer->inspect == NULL) {
202✔
229
        uint32_t b_len = 0;
168✔
230
        const uint8_t *b = NULL;
168✔
231

232
        if (SCHttp2TxGetMethod(txv, &b, &b_len) != 1)
168✔
233
            return NULL;
99✔
234
        if (b == NULL || b_len == 0)
69✔
235
            return NULL;
×
236

237
        InspectionBufferSetupAndApplyTransforms(det_ctx, list_id, buffer, b, b_len, transforms);
69✔
238
    }
69✔
239

240
    return buffer;
103✔
241
}
202✔
242

243
#ifdef UNITTESTS
244
#include "tests/detect-http-method.c"
245
#endif
246

247
/**
248
 * @}
249
 */
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc