Enable new mDNS backend

This commit is contained in:
Julien BLACHE 2009-04-07 19:32:47 +02:00
parent 97cb82faf7
commit 97faadf6dd
6 changed files with 51 additions and 91 deletions

View File

@ -23,6 +23,7 @@ mt_daapd_SOURCES = main.c daapd.h rend.h webserver.c \
webserver.h configfile.c configfile.h err.c err.h \ webserver.h configfile.c configfile.h err.c err.h \
mp3-scanner.h mp3-scanner.c \ mp3-scanner.h mp3-scanner.c \
filescanner_ffmpeg.c \ filescanner_ffmpeg.c \
mdns_avahi.c mdns_avahi.h \
db-generic.c db-generic.h ff-plugins.c ff-plugins.h \ db-generic.c db-generic.h ff-plugins.c ff-plugins.h \
rxml.c rxml.h redblack.c redblack.h \ rxml.c rxml.h redblack.c redblack.h \
scan-xml.c scan-wma.c scan-url.c \ scan-xml.c scan-wma.c scan-url.c \

View File

@ -57,7 +57,6 @@
#include "os.h" #include "os.h"
#include "xml-rpc.h" #include "xml-rpc.h"
#include "upnp.h" #include "upnp.h"
#include "rend.h"
/* /*
@ -667,8 +666,6 @@ void config_emit_literal(WS_CONNINFO *pwsc, void *value, char *arg) {
* \param arg any args passwd with the meta command. Also unused * \param arg any args passwd with the meta command. Also unused
*/ */
void config_emit_service_status(WS_CONNINFO *pwsc, void *value, char *arg) { void config_emit_service_status(WS_CONNINFO *pwsc, void *value, char *arg) {
int mdns_running;
char *html;
char buf[256]; char buf[256];
int r_days, r_hours, r_mins, r_secs; int r_days, r_hours, r_mins, r_secs;
int scanning; int scanning;
@ -677,23 +674,6 @@ void config_emit_service_status(WS_CONNINFO *pwsc, void *value, char *arg) {
ws_writefd(pwsc,"<table><tr><th align=\"left\">Service</th>"); ws_writefd(pwsc,"<table><tr><th align=\"left\">Service</th>");
ws_writefd(pwsc,"<th align=\"left\">Status</th><th align=\"left\">Control</th></tr>\n"); ws_writefd(pwsc,"<th align=\"left\">Status</th><th align=\"left\">Control</th></tr>\n");
ws_writefd(pwsc,"<tr><td>Rendezvous</td>");
if(config.use_mdns) {
mdns_running=!rend_running();
if(mdns_running) {
html="<a href=\"config-update.html?action=stopmdns\">Stop MDNS Server</a>";
} else {
html="<a href=\"config-update.html?action=startmdns\">Start MDNS Server</a>";
}
ws_writefd(pwsc,"<td>%s</td><td>%s</td></tr>\n",mdns_running ? "Running":"Stopped",
html);
} else {
ws_writefd(pwsc,"<td>Not configured</td><td>&nbsp;</td></tr>\n");
}
ws_writefd(pwsc,"<tr><td>DAAP Server</td><td>%s</td>",config.stop ? "Stopping":"Running"); ws_writefd(pwsc,"<tr><td>DAAP Server</td><td>%s</td>",config.stop ? "Stopping":"Running");
if(config.stop) { if(config.stop) {
ws_writefd(pwsc,"<td>Wait...</td></tr>\n"); ws_writefd(pwsc,"<td>Wait...</td></tr>\n");

View File

@ -87,9 +87,10 @@
#include "plugin.h" #include "plugin.h"
#include "util.h" #include "util.h"
#include "upnp.h" #include "upnp.h"
#include "rend.h"
#include "io.h" #include "io.h"
#include "mdns_avahi.h"
#ifdef HAVE_GETOPT_H #ifdef HAVE_GETOPT_H
# include "getopt.h" # include "getopt.h"
#endif #endif
@ -185,7 +186,6 @@ void usage(char *program) {
printf(" -a Set cwd to app dir before starting\n"); printf(" -a Set cwd to app dir before starting\n");
printf(" -d <number> Debug level (0-9)\n"); printf(" -d <number> Debug level (0-9)\n");
printf(" -D <mod,mod..> Debug modules\n"); printf(" -D <mod,mod..> Debug modules\n");
printf(" -m Disable mDNS\n");
printf(" -c <file> Use configfile specified\n"); printf(" -c <file> Use configfile specified\n");
printf(" -P <file> Write the PID to specified file\n"); printf(" -P <file> Write the PID to specified file\n");
printf(" -f Run in foreground\n"); printf(" -f Run in foreground\n");
@ -363,7 +363,7 @@ int main(int argc, char *argv[]) {
int convert_conf=0; int convert_conf=0;
char *db_type,*db_parms,*web_root,*runas, *tmp; char *db_type,*db_parms,*web_root,*runas, *tmp;
char **mp3_dir_array; char **mp3_dir_array;
char *servername, *iface; char *servername;
char *ffid = NULL; char *ffid = NULL;
int appdir = 0; int appdir = 0;
char *perr=NULL; char *perr=NULL;
@ -372,6 +372,7 @@ int main(int argc, char *argv[]) {
char *plugindir; char *plugindir;
struct event *main_timer; struct event *main_timer;
struct timeval tv; struct timeval tv;
int ret;
int err; int err;
char *apppath; char *apppath;
@ -379,7 +380,6 @@ int main(int argc, char *argv[]) {
int debuglevel=0; int debuglevel=0;
int plugins_loaded = 0; int plugins_loaded = 0;
config.use_mdns=1;
err_setlevel(2); err_setlevel(2);
config.foreground=0; config.foreground=0;
@ -414,10 +414,6 @@ int main(int argc, char *argv[]) {
configfile=optarg; configfile=optarg;
break; break;
case 'm':
config.use_mdns=0;
break;
case 'P': case 'P':
os_set_pidfile(optarg); os_set_pidfile(optarg);
break; break;
@ -560,17 +556,18 @@ int main(int argc, char *argv[]) {
os_deinit(); os_deinit();
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
if(config.use_mdns) {
DPRINTF(E_LOG,L_MAIN,"Starting rendezvous daemon\n");
if(rend_init(runas)) {
DPRINTF(E_FATAL,L_MAIN|L_REND,"Error in rend_init: %s\n",
strerror(errno));
}
}
free(runas); free(runas);
DPRINTF(E_LOG, L_MAIN, "mDNS init\n");
ret = mdns_init();
if (ret != 0)
{
DPRINTF(E_FATAL, L_MAIN | L_REND, "mDNS init failed\n");
os_deinit();
exit(EXIT_FAILURE);
}
#ifdef UPNP #ifdef UPNP
upnp_init(); upnp_init();
#endif #endif
@ -582,9 +579,8 @@ int main(int argc, char *argv[]) {
if(err) { if(err) {
DPRINTF(E_LOG,L_MAIN|L_DB,"Error opening db: %s\n",perr); DPRINTF(E_LOG,L_MAIN|L_DB,"Error opening db: %s\n",perr);
if(config.use_mdns) {
rend_stop(); mdns_deinit();
}
os_deinit(); os_deinit();
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
@ -648,7 +644,7 @@ int main(int argc, char *argv[]) {
ws_registerhandler(config.server, "/",main_handler,main_auth, ws_registerhandler(config.server, "/",main_handler,main_auth,
0,1); 0,1);
if(config.use_mdns) { /* register services */ /* Register mDNS services */
servername = conf_get_servername(); servername = conf_get_servername();
memset(txtrecord,0,sizeof(txtrecord)); memset(txtrecord,0,sizeof(txtrecord));
@ -674,15 +670,12 @@ int main(int argc, char *argv[]) {
} }
DPRINTF(E_LOG,L_MAIN|L_REND,"Registering rendezvous names\n"); DPRINTF(E_LOG,L_MAIN|L_REND,"Registering rendezvous names\n");
iface = conf_alloc_string("general","interface",""); /* Register main service */
mdns_register(servername, "_http._tcp", ws_config.port, txtrecord);
rend_register(servername,"_http._tcp",ws_config.port,iface,txtrecord); /* Register plugin services */
plugin_rend_register(servername, ws_config.port, txtrecord);
plugin_rend_register(servername,ws_config.port,iface,txtrecord);
free(servername); free(servername);
free(iface);
}
end_time=(int) time(NULL); end_time=(int) time(NULL);
@ -710,10 +703,8 @@ int main(int argc, char *argv[]) {
DPRINTF(E_LOG,L_MAIN,"Stopping gracefully\n"); DPRINTF(E_LOG,L_MAIN,"Stopping gracefully\n");
if(config.use_mdns) { DPRINTF(E_LOG, L_MAIN | L_REND, "mDNS deinit\n");
DPRINTF(E_LOG,L_MAIN|L_REND,"Stopping rendezvous daemon\n"); mdns_deinit();
rend_stop();
}
#ifdef UPNP #ifdef UPNP
upnp_deinit(); upnp_deinit();

View File

@ -57,13 +57,14 @@
#include "io.h" #include "io.h"
#include "os.h" #include "os.h"
#include "plugin.h" #include "plugin.h"
#include "rend.h"
#include "smart-parser.h" #include "smart-parser.h"
#include "xml-rpc.h" #include "xml-rpc.h"
#include "webserver.h" #include "webserver.h"
#include "ff-plugins.h" #include "ff-plugins.h"
#include "io.h" #include "io.h"
#include "mdns_avahi.h"
typedef struct tag_pluginentry { typedef struct tag_pluginentry {
void *phandle; void *phandle;
PLUGIN_INFO *pinfo; PLUGIN_INFO *pinfo;
@ -338,7 +339,7 @@ void plugin_url_handle(WS_CONNINFO *pwsc) {
* walk through the plugins and register whatever rendezvous * walk through the plugins and register whatever rendezvous
* names the clients want * names the clients want
*/ */
int plugin_rend_register(char *name, int port, char *iface, char *txt) { int plugin_rend_register(char *name, int port, char *txt) {
PLUGIN_ENTRY *ppi; PLUGIN_ENTRY *ppi;
PLUGIN_REND_INFO *pri; PLUGIN_REND_INFO *pri;
char *supplied_txt; char *supplied_txt;
@ -355,7 +356,7 @@ int plugin_rend_register(char *name, int port, char *iface, char *txt) {
supplied_txt = txt; supplied_txt = txt;
DPRINTF(E_DBG,L_PLUG,"Registering %s\n",pri->type); DPRINTF(E_DBG,L_PLUG,"Registering %s\n",pri->type);
rend_register(name,pri->type,port,iface,supplied_txt); mdns_register(name, pri->type, port, supplied_txt);
pri++; pri++;
} }
} }

View File

@ -34,7 +34,7 @@ extern int plugin_deinit(void);
extern int plugin_url_candispatch(WS_CONNINFO *pwsc); extern int plugin_url_candispatch(WS_CONNINFO *pwsc);
extern void plugin_url_handle(WS_CONNINFO *pwsc); extern void plugin_url_handle(WS_CONNINFO *pwsc);
extern int plugin_auth_handle(WS_CONNINFO *pwsc, char *username, char *pw); extern int plugin_auth_handle(WS_CONNINFO *pwsc, char *username, char *pw);
extern int plugin_rend_register(char *name, int port, char *iface, char *txt); extern int plugin_rend_register(char *name, int port, char *txt);
extern void plugin_event_dispatch(int event_id, int intval, void *vp, int len); extern void plugin_event_dispatch(int event_id, int intval, void *vp, int len);
extern void *plugin_enum(void *); extern void *plugin_enum(void *);

View File

@ -36,7 +36,6 @@
#include "mp3-scanner.h" #include "mp3-scanner.h"
#include "os.h" #include "os.h"
#include "plugin.h" #include "plugin.h"
#include "rend.h"
#include "webserver.h" #include "webserver.h"
#include "xml-rpc.h" #include "xml-rpc.h"
@ -520,18 +519,6 @@ void xml_get_stats(WS_CONNINFO *pwsc) {
xml_push(pxml,"service_status"); xml_push(pxml,"service_status");
xml_push(pxml,"service");
xml_output(pxml,"name","Rendezvous");
if(config.use_mdns) {
xml_output(pxml,"status",rend_running() ? "Running" : "Stopped"); /* ??? */
} else {
xml_output(pxml,"status","Disabled");
}
xml_pop(pxml); /* service */
xml_push(pxml,"service"); xml_push(pxml,"service");
xml_output(pxml,"name","DAAP Server"); xml_output(pxml,"name","DAAP Server");
xml_output(pxml,"status",config.stop ? "Stopping" : "Running"); xml_output(pxml,"status",config.stop ? "Stopping" : "Running");