2009-04-07 13:31:46 -04:00
|
|
|
|
2010-09-18 10:29:06 -04:00
|
|
|
#ifndef __MDNS_H__
|
|
|
|
#define __MDNS_H__
|
2009-04-07 13:31:46 -04:00
|
|
|
|
2010-09-18 11:16:29 -04:00
|
|
|
#include "misc.h"
|
2010-01-15 13:40:17 -05:00
|
|
|
|
2018-10-14 16:10:28 -04:00
|
|
|
enum mdns_options
|
|
|
|
{
|
|
|
|
// Test connection to device and only call back if successful
|
|
|
|
MDNS_CONNECTION_TEST = (1 << 1),
|
2021-02-26 16:16:04 -05:00
|
|
|
// Only browse for ipv4 services
|
|
|
|
MDNS_IPV4ONLY = (1 << 2),
|
2018-10-14 16:10:28 -04:00
|
|
|
};
|
|
|
|
|
2010-09-18 11:16:29 -04:00
|
|
|
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);
|
2010-01-15 13:40:17 -05:00
|
|
|
|
2016-10-12 16:24:58 -04:00
|
|
|
/*
|
|
|
|
* Start a mDNS client
|
|
|
|
* Call only from the main thread!
|
|
|
|
*
|
|
|
|
* @return 0 on success, -1 on error
|
|
|
|
*/
|
2009-04-07 13:31:46 -04:00
|
|
|
int
|
|
|
|
mdns_init(void);
|
|
|
|
|
2016-10-12 16:24:58 -04:00
|
|
|
/*
|
|
|
|
* Removes registered services, stops service browsers and stop the mDNS client
|
|
|
|
* Call only from the main thread!
|
|
|
|
*
|
|
|
|
*/
|
2009-04-07 13:31:46 -04:00
|
|
|
void
|
|
|
|
mdns_deinit(void);
|
|
|
|
|
2016-10-12 16:24:58 -04:00
|
|
|
/*
|
|
|
|
* Register (announce) a service with mDNS
|
|
|
|
* Call only from the main thread!
|
|
|
|
*
|
|
|
|
* @in name Name of service, e.g. "My Music on Debian"
|
|
|
|
* @in type Type of service to announce, e.g. "_daap._tcp"
|
|
|
|
* @in port Port of the service
|
|
|
|
* @in txt Pointer to array of strings with txt key/values ("Version=1")
|
|
|
|
* for DNS-SD TXT. The array must be terminated by a NULL pointer.
|
|
|
|
* @return 0 on success, -1 on error
|
|
|
|
*/
|
2009-04-07 13:31:46 -04:00
|
|
|
int
|
2009-04-08 10:35:59 -04:00
|
|
|
mdns_register(char *name, char *type, int port, char **txt);
|
2009-04-07 13:31:46 -04:00
|
|
|
|
2016-11-05 08:31:13 -04:00
|
|
|
/*
|
|
|
|
* Register a CNAME record, it will be an alias for hostname
|
|
|
|
* Call only from the main thread!
|
|
|
|
*
|
|
|
|
* @in name The CNAME alias, e.g. "forked-daapd.local"
|
|
|
|
* @return 0 on success, -1 on error
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
mdns_cname(char *name);
|
|
|
|
|
2016-10-12 16:24:58 -04:00
|
|
|
/*
|
|
|
|
* Start a service browser, a callback will be made when the service changes state
|
|
|
|
* Call only from the main thread!
|
|
|
|
*
|
|
|
|
* @in type Type of service to look for, e.g. "_raop._tcp"
|
2018-10-14 16:10:28 -04:00
|
|
|
* @in flags See mdns_options (only supported by Avahi implementation)
|
2016-10-12 16:24:58 -04:00
|
|
|
* @in cb Callback when service state changes (e.g. appears/disappears)
|
|
|
|
* @return 0 on success, -1 on error
|
|
|
|
*/
|
2010-01-15 13:40:17 -05:00
|
|
|
int
|
2021-02-26 16:16:04 -05:00
|
|
|
mdns_browse(char *type, mdns_browse_cb cb, enum mdns_options flags);
|
2010-01-15 13:40:17 -05:00
|
|
|
|
2010-09-18 10:29:06 -04:00
|
|
|
#endif /* !__MDNS_H__ */
|