mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-27 14:43:21 -05:00
Introduce mDNS browser flags for address type selection
Allow each user to specify the address types that should be returned through the mDNS browse callback.
This commit is contained in:
parent
4f59533ccb
commit
6cd59a1240
@ -4,6 +4,13 @@
|
|||||||
|
|
||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
|
|
||||||
|
#define MDNS_WANT_V4 (1 << 0)
|
||||||
|
#define MDNS_WANT_V4LL (1 << 1)
|
||||||
|
#define MDNS_WANT_V6 (1 << 2)
|
||||||
|
#define MDNS_WANT_V6LL (1 << 3)
|
||||||
|
|
||||||
|
#define MDNS_WANT_DEFAULT (MDNS_WANT_V4 | MDNS_WANT_V6 | MDNS_WANT_V6LL)
|
||||||
|
|
||||||
typedef void (* mdns_browse_cb)(const char *name, const char *type, const char *domain, const char *hostname, int family, const char *address, int port, struct keyval *txt);
|
typedef void (* mdns_browse_cb)(const char *name, const char *type, const char *domain, const char *hostname, int family, const char *address, int port, struct keyval *txt);
|
||||||
|
|
||||||
/* mDNS interface functions */
|
/* mDNS interface functions */
|
||||||
@ -18,6 +25,6 @@ int
|
|||||||
mdns_register(char *name, char *type, int port, char **txt);
|
mdns_register(char *name, char *type, int port, char **txt);
|
||||||
|
|
||||||
int
|
int
|
||||||
mdns_browse(char *type, mdns_browse_cb cb);
|
mdns_browse(char *type, int flags, mdns_browse_cb cb);
|
||||||
|
|
||||||
#endif /* !__MDNS_H__ */
|
#endif /* !__MDNS_H__ */
|
||||||
|
@ -315,6 +315,8 @@ struct mdns_browser
|
|||||||
char *type;
|
char *type;
|
||||||
mdns_browse_cb cb;
|
mdns_browse_cb cb;
|
||||||
|
|
||||||
|
int flags;
|
||||||
|
|
||||||
struct mdns_browser *next;
|
struct mdns_browser *next;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -367,6 +369,7 @@ browse_record_callback_v4(AvahiRecordBrowser *b, AvahiIfIndex intf, AvahiProtoco
|
|||||||
char address[INET_ADDRSTRLEN];
|
char address[INET_ADDRSTRLEN];
|
||||||
struct in_addr addr;
|
struct in_addr addr;
|
||||||
struct mdns_record_browser *rb_data;
|
struct mdns_record_browser *rb_data;
|
||||||
|
int ll;
|
||||||
|
|
||||||
rb_data = (struct mdns_record_browser *)userdata;
|
rb_data = (struct mdns_record_browser *)userdata;
|
||||||
|
|
||||||
@ -382,10 +385,15 @@ browse_record_callback_v4(AvahiRecordBrowser *b, AvahiIfIndex intf, AvahiProtoco
|
|||||||
|
|
||||||
memcpy(&addr.s_addr, rdata, sizeof(addr.s_addr));
|
memcpy(&addr.s_addr, rdata, sizeof(addr.s_addr));
|
||||||
|
|
||||||
if (is_v4ll(&addr))
|
ll = is_v4ll(&addr);
|
||||||
|
if (ll && !(rb_data->mb->flags & MDNS_WANT_V4LL))
|
||||||
{
|
{
|
||||||
DPRINTF(E_DBG, L_MDNS, "Discarding IPv4 LL address\n");
|
DPRINTF(E_DBG, L_MDNS, "Discarding IPv4 LL, not interested (service %s)\n", rb_data->name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else if (!ll && !(rb_data->mb->flags & MDNS_WANT_V4))
|
||||||
|
{
|
||||||
|
DPRINTF(E_DBG, L_MDNS, "Discarding IPv4, not interested (service %s)\n", rb_data->name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,6 +446,7 @@ browse_record_callback_v6(AvahiRecordBrowser *b, AvahiIfIndex intf, AvahiProtoco
|
|||||||
char ifname[IF_NAMESIZE];
|
char ifname[IF_NAMESIZE];
|
||||||
struct in6_addr addr;
|
struct in6_addr addr;
|
||||||
struct mdns_record_browser *rb_data;
|
struct mdns_record_browser *rb_data;
|
||||||
|
int ll;
|
||||||
int len;
|
int len;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -455,6 +464,18 @@ browse_record_callback_v6(AvahiRecordBrowser *b, AvahiIfIndex intf, AvahiProtoco
|
|||||||
|
|
||||||
memcpy(&addr.s6_addr, rdata, sizeof(addr.s6_addr));
|
memcpy(&addr.s6_addr, rdata, sizeof(addr.s6_addr));
|
||||||
|
|
||||||
|
ll = is_v6ll(&addr);
|
||||||
|
if (ll && !(rb_data->mb->flags & MDNS_WANT_V6LL))
|
||||||
|
{
|
||||||
|
DPRINTF(E_DBG, L_MDNS, "Discarding IPv6 LL, not interested (service %s)\n", rb_data->name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else if (!ll && !(rb_data->mb->flags & MDNS_WANT_V6))
|
||||||
|
{
|
||||||
|
DPRINTF(E_DBG, L_MDNS, "Discarding IPv6, not interested (service %s)\n", rb_data->name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!inet_ntop(AF_INET6, &addr.s6_addr, address, sizeof(address)))
|
if (!inet_ntop(AF_INET6, &addr.s6_addr, address, sizeof(address)))
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_MDNS, "Could not print IPv6 address: %s\n", strerror(errno));
|
DPRINTF(E_LOG, L_MDNS, "Could not print IPv6 address: %s\n", strerror(errno));
|
||||||
@ -462,7 +483,7 @@ browse_record_callback_v6(AvahiRecordBrowser *b, AvahiIfIndex intf, AvahiProtoco
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_v6ll(&addr))
|
if (ll)
|
||||||
{
|
{
|
||||||
if (!if_indextoname(intf, ifname))
|
if (!if_indextoname(intf, ifname))
|
||||||
{
|
{
|
||||||
@ -980,7 +1001,7 @@ mdns_register(char *name, char *type, int port, char **txt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
mdns_browse(char *type, mdns_browse_cb cb)
|
mdns_browse(char *type, int flags, mdns_browse_cb cb)
|
||||||
{
|
{
|
||||||
struct mdns_browser *mb;
|
struct mdns_browser *mb;
|
||||||
AvahiServiceBrowser *b;
|
AvahiServiceBrowser *b;
|
||||||
@ -994,6 +1015,8 @@ mdns_browse(char *type, mdns_browse_cb cb)
|
|||||||
mb->type = strdup(type);
|
mb->type = strdup(type);
|
||||||
mb->cb = cb;
|
mb->cb = cb;
|
||||||
|
|
||||||
|
mb->flags = (flags) ? flags : MDNS_WANT_DEFAULT;
|
||||||
|
|
||||||
mb->next = browser_list;
|
mb->next = browser_list;
|
||||||
browser_list = mb;
|
browser_list = mb;
|
||||||
|
|
||||||
|
@ -3834,7 +3834,7 @@ player_init(void)
|
|||||||
goto raop_fail;
|
goto raop_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = mdns_browse("_raop._tcp", raop_device_cb);
|
ret = mdns_browse("_raop._tcp", 0, raop_device_cb);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_FATAL, L_PLAYER, "Could not add mDNS browser for AirTunes devices\n");
|
DPRINTF(E_FATAL, L_PLAYER, "Could not add mDNS browser for AirTunes devices\n");
|
||||||
|
@ -899,7 +899,7 @@ remote_pairing_init(void)
|
|||||||
# endif
|
# endif
|
||||||
#endif /* USE_EVENTFD */
|
#endif /* USE_EVENTFD */
|
||||||
|
|
||||||
ret = mdns_browse("_touch-remote._tcp", touch_remote_cb);
|
ret = mdns_browse("_touch-remote._tcp", 0, touch_remote_cb);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_FATAL, L_REMOTE, "Could not browse for Remote services\n");
|
DPRINTF(E_FATAL, L_REMOTE, "Could not browse for Remote services\n");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user