hc
2023-05-26 a23f51ed7a39e452c1037343a84d7db1ca2c5bd7
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
Upstream-Status: Backport
 
diff -ruN tcp_wrappers_7.6.orig/hosts_access.5 tcp_wrappers_7.6/hosts_access.5
--- tcp_wrappers_7.6.orig/hosts_access.5    2003-08-21 03:15:36.000000000 +0200
+++ tcp_wrappers_7.6/hosts_access.5    2003-08-21 03:15:31.000000000 +0200
@@ -90,6 +90,10 @@
 pattern `131.155.72.0/255.255.254.0\' matches every address in the
 range `131.155.72.0\' through `131.155.73.255\'.
 .IP \(bu
+An expression of the form `n.n.n.n/mm' is interpreted as a
+`net/masklength' pair, where `mm' is the number of consecutive `1'
+bits in the netmask applied to the `n.n.n.n' address.
+.IP \(bu
 An expression of the form `[n:n:n:n:n:n:n:n]/m\' is interpreted as a
 `[net]/prefixlen\' pair. An IPv6 host address is matched if
 `prefixlen\' bits of `net\' is equal to the `prefixlen\' bits of the
diff -ruN tcp_wrappers_7.6.orig/hosts_access.c tcp_wrappers_7.6/hosts_access.c
--- tcp_wrappers_7.6.orig/hosts_access.c    2003-08-21 03:15:36.000000000 +0200
+++ tcp_wrappers_7.6/hosts_access.c    2003-08-21 03:09:30.000000000 +0200
@@ -417,7 +417,8 @@
     if ((addr = dot_quad_addr(string)) == INADDR_NONE)
     return (NO);
     if ((net = dot_quad_addr(net_tok)) == INADDR_NONE
-    || (mask = dot_quad_addr(mask_tok)) == INADDR_NONE) {
+    || ((mask = dot_quad_addr(mask_tok)) == INADDR_NONE
+        && (mask = cidr_mask_addr(mask_tok)) == 0)) {
 #ifndef INET6
     tcpd_warn("bad net/mask expression: %s/%s", net_tok, mask_tok);
 #endif
diff -ruN tcp_wrappers_7.6.orig/misc.c tcp_wrappers_7.6/misc.c
--- tcp_wrappers_7.6.orig/misc.c    2003-08-21 03:15:36.000000000 +0200
+++ tcp_wrappers_7.6/misc.c    2003-08-21 03:09:30.000000000 +0200
@@ -107,3 +107,17 @@
     }
     return (runs == 4 ? inet_addr(str) : INADDR_NONE);
 }
+
+/* cidr_mask_addr - convert cidr netmask length to internal form */
+
+unsigned long cidr_mask_addr(str)
+char   *str;
+{
+    int     maskbits;
+
+    maskbits = atoi(str);
+    if (maskbits < 1 || maskbits > 32)
+    return (0);
+    return htonl(0xFFFFFFFF << (32 - maskbits));
+}
+
diff -ruN tcp_wrappers_7.6.orig/tcpdchk.c tcp_wrappers_7.6/tcpdchk.c
--- tcp_wrappers_7.6.orig/tcpdchk.c    2003-08-21 03:15:36.000000000 +0200
+++ tcp_wrappers_7.6/tcpdchk.c    2003-08-21 03:09:30.000000000 +0200
@@ -497,12 +497,12 @@
     int mask_len;
 
     if ((dot_quad_addr(pat) == INADDR_NONE
-        || dot_quad_addr(mask) == INADDR_NONE)
+        || dot_quad_addr(mask) == INADDR_NONE && cidr_mask_addr(mask) == 0)
         && (!is_inet6_addr(pat)
         || ((mask_len = atoi(mask)) < 0 || mask_len > 128)))
 #else
     if (dot_quad_addr(pat) == INADDR_NONE
-        || dot_quad_addr(mask) == INADDR_NONE)
+        || dot_quad_addr(mask) == INADDR_NONE && cidr_mask_addr(mask) == 0)
 #endif
         tcpd_warn("%s/%s: bad net/mask pattern", pat, mask);
     } else if (STR_EQ(pat, "FAIL")) {        /* obsolete */