Go to the documentation of this file.
54 #define PARSE_REGEX "^\\s*(<|>)?\\s*([ -:TW0-9]+)\\s*(?:(<>)\\s*([ -:TW0-9]+))?\\s*$"
58 uint8_t,
void *,
void *,
const Signature *,
61 static time_t DateStringToEpoch (
char *);
75 static int g_tls_validity_buffer_id = 0;
153 if (ssl_state == NULL) {
161 if (
flags & STREAM_TOSERVER)
168 time_t cert_epoch = 0;
184 cert_epoch >= dd->
epoch && cert_epoch <= dd->epoch2)
203 static time_t StringIsEpoch (
char *
string)
205 if (strlen(
string) == 0)
212 if (isdigit(*sp++) == 0)
216 return strtol(
string, NULL, 10);
228 static time_t DateStringToEpoch (
char *
string)
232 const char *patterns[] = {
247 while (isspace(*
string))
250 size_t inlen, oldlen;
252 oldlen = inlen = strlen(
string);
255 while (inlen > 0 && isspace(
string[inlen - 1]))
260 if (inlen < oldlen) {
261 strlcpy(tmp,
string, inlen + 1);
265 time_t epoch = StringIsEpoch(
string);
266 if (epoch != LONG_MIN) {
291 char value1[20] =
"";
292 char value2[20] =
"";
295 pcre2_match_data *match = NULL;
297 if (ret < 3 || ret > 5) {
302 size_t pcre2len =
sizeof(mode);
305 SCLogError(
"pcre2_substring_copy_bynumber failed");
310 pcre2len =
sizeof(value1);
311 res = pcre2_substring_copy_bynumber(match, 2, (PCRE2_UCHAR8 *)value1, &pcre2len);
313 SCLogError(
"pcre2_substring_copy_bynumber failed");
319 pcre2len =
sizeof(range);
320 res = pcre2_substring_copy_bynumber(match, 3, (PCRE2_UCHAR8 *)range, &pcre2len);
322 SCLogError(
"pcre2_substring_copy_bynumber failed");
328 pcre2len =
sizeof(value2);
329 res = pcre2_substring_copy_bynumber(match, 4, (PCRE2_UCHAR8 *)value2, &pcre2len);
331 SCLogError(
"pcre2_substring_copy_bynumber failed");
346 if (strlen(mode) > 0) {
349 else if (mode[0] ==
'>')
353 if (strlen(range) > 0) {
354 if (strcmp(
"<>", range) == 0)
358 if (strlen(range) != 0 && strlen(mode) != 0) {
359 SCLogError(
"Range specified but mode also set");
368 dd->
epoch = DateStringToEpoch(value1);
369 if (dd->
epoch == LONG_MIN)
373 if (strlen(value2) > 0) {
375 SCLogError(
"Multiple tls validity values specified but mode is not range");
379 dd->
epoch2 = DateStringToEpoch(value2);
380 if (dd->
epoch2 == LONG_MIN)
384 SCLogError(
"Second value in range must not be smaller than the first");
388 pcre2_match_data_free(match);
393 pcre2_match_data_free(match);
422 SCLogError(
"Allocation \'%s\' failed", rawstr);
435 g_tls_validity_buffer_id) == NULL) {
441 DetectTlsValidityFree(
de_ctx, dd);
467 SCLogError(
"Allocation \'%s\' failed", rawstr);
486 DetectTlsValidityFree(
de_ctx, dd);
504 int r = DetectTlsValiditySetup(
de_ctx, s, rawstr,
type);
523 int r = DetectTlsValiditySetup(
de_ctx, s, rawstr,
type);
540 const char *rawstr, uint8_t
type)
549 dd = DetectTlsValidityParse(rawstr);
569 g_tls_validity_buffer_id) == NULL) {
575 DetectTlsValidityFree(
de_ctx, dd);
int DetectSignatureSetAppProto(Signature *s, AppProto alproto)
SSLv[2.0|3.[0|1|2|3]] state structure.
SigTableElmt * sigmatch_table
#define DETECT_TLS_TYPE_NOTAFTER
void(* Free)(DetectEngineCtx *, void *)
SSLStateConnp client_connp
#define DETECT_TLS_VALIDITY_EQ
void TlsNotBeforeRegisterTests(void)
Register unit tests for tls_cert_notbefore.
SSLStateConnp server_connp
void TlsNotAfterRegisterTests(void)
Register unit tests for tls_cert_notafter.
main detection engine ctx
time_t SCMkTimeUtc(struct tm *tp)
Convert broken-down time to seconds since Unix epoch.
#define DETECT_TLS_VALIDITY_RA
int(* AppLayerTxMatch)(DetectEngineThreadCtx *, Flow *, uint8_t flags, void *alstate, void *txv, const Signature *, const SigMatchCtx *)
void DetectTlsValidityRegister(void)
Registration function for tls validity keywords.
int DetectParsePcreExec(DetectParseRegex *parse_regex, pcre2_match_data **match, const char *str, int start_offset, int options)
int(* Setup)(DetectEngineCtx *, Signature *, const char *)
int DetectBufferTypeGetByName(const char *name)
size_t strlcpy(char *dst, const char *src, size_t siz)
void DetectSetupParseRegexes(const char *parse_str, DetectParseRegex *detect_parse)
Used to start a pointer to SigMatch context Should never be dereferenced without casting to something...
#define DETECT_TLS_VALIDITY_LT
#define DETECT_TLS_VALIDITY_EX
#define DETECT_TLS_VALIDITY_GT
#define DETECT_TLS_VALIDITY_VA
#define SCLogError(...)
Macro used to log ERROR messages.
void TlsValidRegisterTests(void)
Register unit tests for tls_cert_valid.
#define DETECT_TLS_TYPE_NOTBEFORE
int SC_Pcre2SubstringCopy(pcre2_match_data *match_data, uint32_t number, PCRE2_UCHAR *buffer, PCRE2_SIZE *bufflen)
SigMatch * SigMatchAppendSMToList(DetectEngineCtx *de_ctx, Signature *s, uint16_t type, SigMatchCtx *ctx, const int list)
Append a SigMatch to the list type.
int SCStringPatternToTime(char *string, const char **patterns, int num_patterns, struct tm *tp)
Parse a date string based on specified patterns.
void TlsExpiredRegisterTests(void)
Register unit tests for tls_cert_expired.
void(* RegisterTests)(void)