[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] Refactor parse-addr-mask-and-port-range into a separate fun...
- To: or-cvs@freehaven.net
- Subject: [or-cvs] Refactor parse-addr-mask-and-port-range into a separate fun...
- From: nickm@seul.org (Nick Mathewson)
- Date: Sat, 16 Oct 2004 17:41:15 -0400 (EDT)
- Delivered-to: archiver@seul.org
- Delivered-to: or-cvs-outgoing@seul.org
- Delivered-to: or-cvs@seul.org
- Delivery-date: Sat, 16 Oct 2004 17:41:37 -0400
- Reply-to: or-dev@freehaven.net
- Sender: owner-or-cvs@freehaven.net
Update of /home/or/cvsroot/src/common
In directory moria.mit.edu:/tmp/cvs-serv23815/src/common
Modified Files:
util.c util.h
Log Message:
Refactor parse-addr-mask-and-port-range into a separate function
Index: util.c
===================================================================
RCS file: /home/or/cvsroot/src/common/util.c,v
retrieving revision 1.147
retrieving revision 1.148
diff -u -d -r1.147 -r1.148
--- util.c 15 Oct 2004 03:55:02 -0000 1.147
+++ util.c 16 Oct 2004 21:41:12 -0000 1.148
@@ -2117,6 +2117,106 @@
return ok ? 0 : -1;
}
+/** Parse a string <b>s</b> in the format of
+ * (IP(/mask|/mask-bits)?|*):(*|port(-maxport)?), setting the various
+ * *out pointers as appropriate. Return 0 on success, -1 on failure.
+ */
+int
+parse_addr_and_port_range(const char *s, uint32_t *addr_out,
+ uint32_t *mask_out, uint16_t *port_min_out,
+ uint16_t *port_max_out)
+{
+ char *address;
+ char *mask, *port, *endptr;
+ struct in_addr in;
+ int bits;
+
+ tor_assert(s && addr_out && mask_out && port_min_out && port_max_out);
+
+ address = tor_strdup(s);
+ /* Break 'address' into separate strings.
+ */
+ mask = strchr(address,'/');
+ port = strchr(mask?mask:address,':');
+ if (mask)
+ *mask++ = '\0';
+ if (port)
+ *port++ = '\0';
+ /* Now "address" is the IP|'*' part...
+ * "mask" is the Mask|Maskbits part...
+ * and "port" is the *|port|min-max part.
+ */
+
+ if (strcmp(address,"*")==0) {
+ *addr_out = 0;
+ } else if (tor_inet_aton(address, &in) != 0) {
+ *addr_out = ntohl(in.s_addr);
+ } else {
+ log_fn(LOG_WARN, "Malformed IP %s in address pattern; rejecting.",address);
+ goto err;
+ }
+
+ if (!mask) {
+ if (strcmp(address,"*")==0)
+ *mask_out = 0;
+ else
+ *mask_out = 0xFFFFFFFFu;
+ } else {
+ endptr = NULL;
+ bits = (int) strtol(mask, &endptr, 10);
+ if (!*endptr) {
+ /* strtol handled the whole mask. */
+ if (bits < 0 || bits > 32) {
+ log_fn(LOG_WARN, "Bad number of mask bits on address range; rejecting.");
+ goto err;
+ }
+ *mask_out = ~((1<<(32-bits))-1);
+ } else if (tor_inet_aton(mask, &in) != 0) {
+ *mask_out = ntohl(in.s_addr);
+ } else {
+ log_fn(LOG_WARN, "Malformed mask %s on address range; rejecting.",
+ mask);
+ goto err;
+ }
+ }
+
+ if (!port || strcmp(port, "*") == 0) {
+ *port_min_out = 1;
+ *port_max_out = 65535;
+ } else {
+ endptr = NULL;
+ *port_min_out = (uint16_t) tor_parse_long(port, 10, 1, 65535,
+ NULL, &endptr);
+ if (*endptr == '-') {
+ port = endptr+1;
+ endptr = NULL;
+ *port_max_out = (uint16_t) tor_parse_long(port, 10, 1, 65535, NULL,
+ &endptr);
+ if (*endptr || !*port_max_out) {
+ log_fn(LOG_WARN, "Malformed port %s on address range rejecting.",
+ port);
+ }
+ } else if (*endptr || !*port_min_out) {
+ log_fn(LOG_WARN, "Malformed port %s on address range; rejecting.",
+ port);
+ goto err;
+ } else {
+ *port_max_out = *port_min_out;
+ }
+ if (*port_min_out > *port_max_out) {
+ log_fn(LOG_WARN,"Insane port range on address policy; rejecting.");
+ goto err;
+ }
+ }
+
+ tor_free(address);
+ return 0;
+ err:
+ tor_free(address);
+ return -1;
+}
+
+
/** Extract a long from the start of s, in the given numeric base. If
* there is unconverted data and next is provided, set *next to the
* first unconverted character. An error has occurred if no characters
Index: util.h
===================================================================
RCS file: /home/or/cvsroot/src/common/util.h,v
retrieving revision 1.101
retrieving revision 1.102
diff -u -d -r1.101 -r1.102
--- util.h 16 Oct 2004 20:26:12 -0000 1.101
+++ util.h 16 Oct 2004 21:41:12 -0000 1.102
@@ -248,6 +248,10 @@
int parse_addr_port(const char *addrport, char **address, uint32_t *addr,
uint16_t *port);
+int parse_addr_and_port_range(const char *s, uint32_t *addr_out,
+ uint32_t *mask_out, uint16_t *port_min_out,
+ uint16_t *port_max_out);
+
/* For stupid historical reasons, windows sockets have an independent
* set of errnos, and an independent way to get them. Also, you can't
* always believe WSAEWOULDBLOCK. Use the macros below to compare