1
0
Fork 0
mirror of https://github.com/yarrick/iodine.git synced 2025-04-04 13:53:34 +03:00

fix #38: responds to NS/A with IP from -n argument

As described in issue #38, DNS type NS requests to iodined got responses with additional IP that was incorrect (always 2.0.0.0) if the -n argument switch was used to specify a custom IP address. The same applied to A requests (for ns.topdomain); the IP was always 2.0.0.0 because of wrong memory copying.

This commit fix solves this issue by correctly memory copying ns_ip to query destination (&q->destination).
This commit is contained in:
Anton Luka Šijanec 2020-07-23 20:22:38 +02:00 committed by GitHub
parent d09c3e4f0b
commit a2d1ffa150
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1548,8 +1548,9 @@ handle_ns_request(int dns_fd, struct query *q)
if (ns_ip != INADDR_ANY) {
/* If ns_ip set, overwrite destination addr with it.
* Destination addr will be sent as additional record (A, IN) */
struct sockaddr_in *addr = (struct sockaddr_in *) &q->destination;
memcpy(&addr->sin_addr, &ns_ip, sizeof(ns_ip));
struct sockaddr_in *addr = (struct sockaddr_in *) &q->destination; /* probably not needed */
memcpy(&q->destination, &ns_ip, sizeof(ns_ip));
memcpy(&addr->sin_addr, &ns_ip, sizeof(ns_ip)); /* probably not needed */
}
len = dns_encode_ns_response(buf, sizeof(buf), q, topdomain);
@ -1582,8 +1583,9 @@ handle_a_request(int dns_fd, struct query *q, int fakeip)
} else if (ns_ip != INADDR_ANY) {
/* If ns_ip set, overwrite destination addr with it.
* Destination addr will be sent as additional record (A, IN) */
struct sockaddr_in *addr = (struct sockaddr_in *) &q->destination;
memcpy(&addr->sin_addr, &ns_ip, sizeof(ns_ip));
struct sockaddr_in *addr = (struct sockaddr_in *) &q->destination; /* probably not needed */
memcpy(&q->destination, &ns_ip, sizeof(ns_ip));
memcpy(&addr->sin_addr, &ns_ip, sizeof(ns_ip)); /* probably not needed */
}
len = dns_encode_a_response(buf, sizeof(buf), q);