aboutsummaryrefslogtreecommitdiff
path: root/src/lib/protocols/ipp.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/protocols/ipp.c')
-rw-r--r--src/lib/protocols/ipp.c81
1 files changed, 13 insertions, 68 deletions
diff --git a/src/lib/protocols/ipp.c b/src/lib/protocols/ipp.c
index 57edee6ad..546bfaea3 100644
--- a/src/lib/protocols/ipp.c
+++ b/src/lib/protocols/ipp.c
@@ -30,83 +30,28 @@
static void ndpi_int_ipp_add_connection(struct ndpi_detection_module_struct *ndpi_struct,
- struct ndpi_flow_struct *flow/* , ndpi_protocol_type_t protocol_type */)
+ struct ndpi_flow_struct *flow)
{
- ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_IPP, NDPI_PROTOCOL_UNKNOWN, NDPI_CONFIDENCE_DPI);
+ ndpi_set_detected_protocol(ndpi_struct, flow, NDPI_PROTOCOL_HTTP, NDPI_PROTOCOL_IPP, NDPI_CONFIDENCE_DPI);
}
void ndpi_search_ipp(struct ndpi_detection_module_struct *ndpi_struct, struct ndpi_flow_struct *flow)
{
- struct ndpi_packet_struct *packet = &ndpi_struct->packet;
- u_int8_t i;
+ struct ndpi_packet_struct *packet = &ndpi_struct->packet;
- NDPI_LOG_DBG(ndpi_struct, "search ipp\n");
+ NDPI_LOG_DBG(ndpi_struct, "search ipp\n");
- if (packet->payload_packet_len > 20) {
+ /* Treat IPP as a HTTP sub-protocol */
- NDPI_LOG_DBG2(ndpi_struct,
- "searching for a payload with a pattern like 'number(1to8)blanknumber(1to3)ipp://.\n");
- /* this pattern means that there is a printer saying that his state is idle,
- * means that he is not printing anything at the moment */
- i = 0;
+ if(flow->detected_protocol_stack[0] == NDPI_PROTOCOL_HTTP &&
+ flow->http.method == NDPI_HTTP_METHOD_POST &&
+ LINE_STARTS(packet->http_url_name, "/ipp/") == 1) {
+ NDPI_LOG_INFO(ndpi_struct, "found ipp\n");
+ ndpi_int_ipp_add_connection(ndpi_struct, flow);
+ return;
+ }
- if (packet->payload[i] < '0' || packet->payload[i] > '9') {
- NDPI_LOG_DBG2(ndpi_struct, "payload does not begin with a number\n");
- goto search_for_next_pattern;
- }
-
- for (;;) {
- i++;
- if (!((packet->payload[i] >= '0' && packet->payload[i] <= '9') ||
- (packet->payload[i] >= 'a' && packet->payload[i] <= 'f') ||
- (packet->payload[i] >= 'A' && packet->payload[i] <= 'F')) || i > 8) {
- NDPI_LOG_DBG2(ndpi_struct,
- "read symbols while the symbol is a number.\n");
- break;
- }
- }
-
- if (packet->payload[i++] != ' ') {
- NDPI_LOG_DBG2(ndpi_struct, "there is no blank following the number\n");
- goto search_for_next_pattern;
- }
-
- if (packet->payload[i] < '0' || packet->payload[i] > '9') {
- NDPI_LOG_DBG2(ndpi_struct, "no number following the blank\n");
- goto search_for_next_pattern;
- }
-
- for (;;) {
- i++;
- if (packet->payload[i] < '0' || packet->payload[i] > '9' || i > 12) {
- NDPI_LOG_DBG2(ndpi_struct,
- "read symbols while the symbol is a number.\n");
- break;
- }
- }
-
- if (memcmp(&packet->payload[i], " ipp://", 7) != 0) {
- NDPI_LOG_DBG2(ndpi_struct, "the string ' ipp://' does not follow\n");
- goto search_for_next_pattern;
- }
-
- NDPI_LOG_INFO(ndpi_struct, "found ipp\n");
- ndpi_int_ipp_add_connection(ndpi_struct, flow);
- return;
- }
-
- search_for_next_pattern:
-
- if (packet->payload_packet_len > 3 && memcmp(packet->payload, "POST", 4) == 0) {
- ndpi_parse_packet_line_info(ndpi_struct, flow);
- if (packet->content_line.ptr != NULL && packet->content_line.len > 14
- && memcmp(packet->content_line.ptr, "application/ipp", 15) == 0) {
- NDPI_LOG_INFO(ndpi_struct, "found ipp via POST ... application/ipp\n");
- ndpi_int_ipp_add_connection(ndpi_struct, flow);
- return;
- }
- }
- NDPI_EXCLUDE_PROTO(ndpi_struct, flow);
+ NDPI_EXCLUDE_PROTO(ndpi_struct, flow);
}