mirror of
https://github.com/status-im/miniupnp.git
synced 2025-01-11 22:54:17 +00:00
Added ipv6_listening_ip option to override it from in6addr_any.
This way IPv6 services can be selectively enabled on one IP too.
This commit is contained in:
parent
1213033912
commit
c038146cee
@ -116,13 +116,18 @@ OpenAndConfSSDPReceiveSocket(int ipv6)
|
|||||||
}
|
}
|
||||||
|
|
||||||
memset(&sockname, 0, sizeof(struct sockaddr_storage));
|
memset(&sockname, 0, sizeof(struct sockaddr_storage));
|
||||||
if(ipv6) {
|
#ifdef ENABLE_IPV6
|
||||||
|
if(ipv6)
|
||||||
|
{
|
||||||
struct sockaddr_in6 * saddr = (struct sockaddr_in6 *)&sockname;
|
struct sockaddr_in6 * saddr = (struct sockaddr_in6 *)&sockname;
|
||||||
saddr->sin6_family = AF_INET6;
|
saddr->sin6_family = AF_INET6;
|
||||||
saddr->sin6_port = htons(SSDP_PORT);
|
saddr->sin6_port = htons(SSDP_PORT);
|
||||||
saddr->sin6_addr = in6addr_any;
|
saddr->sin6_addr = ipv6_bind_addr;
|
||||||
sockname_len = sizeof(struct sockaddr_in6);
|
sockname_len = sizeof(struct sockaddr_in6);
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
#endif /* ENABLE_IPV6 */
|
||||||
|
{
|
||||||
struct sockaddr_in * saddr = (struct sockaddr_in *)&sockname;
|
struct sockaddr_in * saddr = (struct sockaddr_in *)&sockname;
|
||||||
saddr->sin_family = AF_INET;
|
saddr->sin_family = AF_INET;
|
||||||
saddr->sin_port = htons(SSDP_PORT);
|
saddr->sin_port = htons(SSDP_PORT);
|
||||||
|
@ -164,7 +164,7 @@ OpenAndConfHTTPSocket(unsigned short port)
|
|||||||
memset(&listenname6, 0, sizeof(struct sockaddr_in6));
|
memset(&listenname6, 0, sizeof(struct sockaddr_in6));
|
||||||
listenname6.sin6_family = AF_INET6;
|
listenname6.sin6_family = AF_INET6;
|
||||||
listenname6.sin6_port = htons(port);
|
listenname6.sin6_port = htons(port);
|
||||||
listenname6.sin6_addr = in6addr_any;
|
listenname6.sin6_addr = ipv6_bind_addr;
|
||||||
listenname_len = sizeof(struct sockaddr_in6);
|
listenname_len = sizeof(struct sockaddr_in6);
|
||||||
} else {
|
} else {
|
||||||
memset(&listenname4, 0, sizeof(struct sockaddr_in));
|
memset(&listenname4, 0, sizeof(struct sockaddr_in));
|
||||||
@ -833,6 +833,9 @@ init(int argc, char * * argv, struct runtime_vars * v)
|
|||||||
|
|
||||||
/* set initial values */
|
/* set initial values */
|
||||||
SETFLAG(ENABLEUPNPMASK); /* UPnP is enabled by default */
|
SETFLAG(ENABLEUPNPMASK); /* UPnP is enabled by default */
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
ipv6_bind_addr = in6addr_any;
|
||||||
|
#endif /* ENABLE_IPV6 */
|
||||||
|
|
||||||
LIST_INIT(&lan_addrs);
|
LIST_INIT(&lan_addrs);
|
||||||
v->port = -1;
|
v->port = -1;
|
||||||
@ -878,6 +881,14 @@ init(int argc, char * * argv, struct runtime_vars * v)
|
|||||||
}
|
}
|
||||||
LIST_INSERT_HEAD(&lan_addrs, lan_addr, list);
|
LIST_INSERT_HEAD(&lan_addrs, lan_addr, list);
|
||||||
break;
|
break;
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
case UPNPIPV6_LISTENING_IP:
|
||||||
|
if (inet_pton(AF_INET6, ary_options[i].value, &ipv6_bind_addr) < 1)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "can't parse \"%s\" as valid IPv6 listening address", ary_options[i].value);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
#endif /* ENABLE_IPV6 */
|
||||||
case UPNPPORT:
|
case UPNPPORT:
|
||||||
v->port = atoi(ary_options[i].value);
|
v->port = atoi(ary_options[i].value);
|
||||||
break;
|
break;
|
||||||
|
@ -31,6 +31,9 @@ static const struct {
|
|||||||
{ UPNPEXT_IFNAME, "ext_ifname" },
|
{ UPNPEXT_IFNAME, "ext_ifname" },
|
||||||
{ UPNPEXT_IP, "ext_ip" },
|
{ UPNPEXT_IP, "ext_ip" },
|
||||||
{ UPNPLISTENING_IP, "listening_ip" },
|
{ UPNPLISTENING_IP, "listening_ip" },
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
{ UPNPIPV6_LISTENING_IP, "ipv6_listening_ip" },
|
||||||
|
#endif /* ENABLE_IPV6 */
|
||||||
{ UPNPPORT, "port" },
|
{ UPNPPORT, "port" },
|
||||||
{ UPNPPORT, "http_port" }, /* "port" and "http_port" are synonims */
|
{ UPNPPORT, "http_port" }, /* "port" and "http_port" are synonims */
|
||||||
#ifdef ENABLE_HTTPS
|
#ifdef ENABLE_HTTPS
|
||||||
|
@ -18,6 +18,9 @@ enum upnpconfigoptions {
|
|||||||
UPNPEXT_IFNAME = 1, /* ext_ifname */
|
UPNPEXT_IFNAME = 1, /* ext_ifname */
|
||||||
UPNPEXT_IP, /* ext_ip */
|
UPNPEXT_IP, /* ext_ip */
|
||||||
UPNPLISTENING_IP, /* listening_ip */
|
UPNPLISTENING_IP, /* listening_ip */
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
UPNPIPV6_LISTENING_IP, /* listening address for IPv6 */
|
||||||
|
#endif /* ENABLE_IPV6 */
|
||||||
UPNPPORT, /* "port" / "http_port" */
|
UPNPPORT, /* "port" / "http_port" */
|
||||||
#ifdef ENABLE_HTTPS
|
#ifdef ENABLE_HTTPS
|
||||||
UPNPHTTPSPORT, /* "https_port" */
|
UPNPHTTPSPORT, /* "https_port" */
|
||||||
|
@ -1642,7 +1642,7 @@ int OpenAndConfPCPv6Socket(void)
|
|||||||
memset(&addr, 0, sizeof(addr));
|
memset(&addr, 0, sizeof(addr));
|
||||||
addr.sin6_family = AF_INET6;
|
addr.sin6_family = AF_INET6;
|
||||||
addr.sin6_port = htons(NATPMP_PORT);
|
addr.sin6_port = htons(NATPMP_PORT);
|
||||||
addr.sin6_addr = in6addr_any;
|
addr.sin6_addr = ipv6_bind_addr;
|
||||||
if(bind(s, (struct sockaddr *)&addr, sizeof(addr)) < 0) {
|
if(bind(s, (struct sockaddr *)&addr, sizeof(addr)) < 0) {
|
||||||
syslog(LOG_ERR, "%s: bind(): %m", "OpenAndConfPCPv6Socket");
|
syslog(LOG_ERR, "%s: bind(): %m", "OpenAndConfPCPv6Socket");
|
||||||
close(s);
|
close(s);
|
||||||
|
@ -110,6 +110,9 @@ struct lan_addr_list lan_addrs;
|
|||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
/* ipv6 address used for HTTP */
|
/* ipv6 address used for HTTP */
|
||||||
char ipv6_addr_for_http_with_brackets[64];
|
char ipv6_addr_for_http_with_brackets[64];
|
||||||
|
|
||||||
|
/* address used to bind local services */
|
||||||
|
struct in6_addr ipv6_bind_addr;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Path of the Unix socket used to communicate with MiniSSDPd */
|
/* Path of the Unix socket used to communicate with MiniSSDPd */
|
||||||
|
@ -140,6 +140,10 @@ extern struct lan_addr_list lan_addrs;
|
|||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
/* ipv6 address used for HTTP */
|
/* ipv6 address used for HTTP */
|
||||||
extern char ipv6_addr_for_http_with_brackets[64];
|
extern char ipv6_addr_for_http_with_brackets[64];
|
||||||
|
|
||||||
|
/* address used to bind local services */
|
||||||
|
extern struct in6_addr ipv6_bind_addr;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern const char * minissdpdsocketpath;
|
extern const char * minissdpdsocketpath;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user