diff options
Diffstat (limited to 'example')
-rw-r--r-- | example/ndpiReader.c | 4 | ||||
-rw-r--r-- | example/reader_util.c | 9 | ||||
-rw-r--r-- | example/reader_util.h | 5 |
3 files changed, 17 insertions, 1 deletions
diff --git a/example/ndpiReader.c b/example/ndpiReader.c index 1a54b59d4..c22a6d496 100644 --- a/example/ndpiReader.c +++ b/example/ndpiReader.c @@ -1138,6 +1138,10 @@ static void printFlow(u_int16_t id, struct ndpi_flow_info *flow, u_int16_t threa } } + if(flow->http.url[0] != '\0') + fprintf(out, "[URL: %s][StatusCode: %u]", + flow->http.url, flow->http.response_status_code); + if(flow->ssh_tls.ssl_version != 0) fprintf(out, "[%s]", ndpi_ssl_version2str(flow->ssh_tls.ssl_version)); if(flow->ssh_tls.client_info[0] != '\0') fprintf(out, "[Client: %s]", flow->ssh_tls.client_info); if(flow->ssh_tls.client_hassh[0] != '\0') fprintf(out, "[HASSH-C: %s]", flow->ssh_tls.client_hassh); diff --git a/example/reader_util.c b/example/reader_util.c index db25099a2..1cfedf1a6 100644 --- a/example/reader_util.c +++ b/example/reader_util.c @@ -976,7 +976,14 @@ void process_ndpi_collected_info(struct ndpi_workflow * workflow, struct ndpi_fl else if(flow->detected_protocol.app_protocol == NDPI_PROTOCOL_UBNTAC2) { snprintf(flow->info, sizeof(flow->info), "%s", flow->ndpi_flow->protos.ubntac2.version); } - if(flow->detected_protocol.app_protocol != NDPI_PROTOCOL_DNS) { + /* HTTP */ + else if(flow->detected_protocol.master_protocol == NDPI_PROTOCOL_HTTP) { + if(flow->ndpi_flow->http.url != NULL) { + snprintf(flow->http.url, sizeof(flow->http.url), "%s", flow->ndpi_flow->http.url); + flow->http.response_status_code = flow->ndpi_flow->http.response_status_code; + } + } + else if(flow->detected_protocol.app_protocol != NDPI_PROTOCOL_DNS) { /* SSH */ if(flow->detected_protocol.app_protocol == NDPI_PROTOCOL_SSH) { snprintf(flow->ssh_tls.client_info, sizeof(flow->ssh_tls.client_info), "%s", diff --git a/example/reader_util.h b/example/reader_util.h index 2055d7156..309e51d08 100644 --- a/example/reader_util.h +++ b/example/reader_util.h @@ -167,6 +167,11 @@ typedef struct ndpi_flow_info { u_int16_t server_cipher; ndpi_cipher_weakness client_unsafe_cipher, server_unsafe_cipher; } ssh_tls; + + struct { + char url[256]; + u_int response_status_code; + } http; void *src_id, *dst_id; |