mirror of
https://github.com/nmap/nmap.git
synced 2025-12-14 19:59:02 +00:00
Assign scope id in nmap_route_dst.
This is done for all IPv6 addresses when the -e option is used.
This commit is contained in:
24
tcpip.cc
24
tcpip.cc
@@ -1972,16 +1972,34 @@ pcap_if_t *getpcapinterfaces() {
|
||||
|
||||
|
||||
|
||||
/* Assign the sin6_scope_id member of a sockaddr_in6, based on a device name.
|
||||
This is used to assign scope to all addresses with the -e option is used. */
|
||||
static void assign_scope_id(struct sockaddr_in6 *sin6, const char *devname) {
|
||||
struct interface_info *ii;
|
||||
|
||||
if (devname == NULL || devname[0] == '\0')
|
||||
return;
|
||||
ii = getInterfaceByName(devname, sin6->sin6_family);
|
||||
if (ii != NULL)
|
||||
sin6->sin6_scope_id = ii->ifindex;
|
||||
}
|
||||
|
||||
|
||||
int nmap_route_dst(const struct sockaddr_storage *dst, struct route_nfo *rnfo) {
|
||||
struct sockaddr_storage spoofss;
|
||||
struct sockaddr_storage dst_mod, spoofss;
|
||||
size_t spoofsslen;
|
||||
|
||||
/* Make a copy that we may modify (only to possibly add a sin6_scope_id). */
|
||||
dst_mod = *dst;
|
||||
|
||||
if (dst_mod.ss_family == AF_INET6)
|
||||
assign_scope_id((struct sockaddr_in6 *) &dst_mod, o.device);
|
||||
|
||||
if (o.spoofsource) {
|
||||
o.SourceSockAddr(&spoofss, &spoofsslen);
|
||||
return route_dst(dst, rnfo, o.device, &spoofss);
|
||||
return route_dst(&dst_mod, rnfo, o.device, &spoofss);
|
||||
} else {
|
||||
return route_dst(dst, rnfo, o.device, NULL);
|
||||
return route_dst(&dst_mod, rnfo, o.device, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user