#include "version.h"
char system_string[64], version_string[64];
+int bindport;
+char *bindaddr;
void lockfile(const char *pidfile)
{
printf(" -p <pidfile> - Write PID to this file\n");
printf(" -c <conf file> - Specify configuration file\n");
printf(" -r - Run with realtime priority\n");
+ printf(" -a <address> - Bind to IP address\n");
+ printf(" -b <port> - Bind to port\n");
printf(" -h - Print this help\n");
exit(0);
}
struct utsname utsbuf;
/* Arguments */
- while ((c = getopt(argc, argv, "drp:c:h")) != EOF) {
+ while ((c = getopt(argc, argv, "drp:c:a:b:h")) != EOF) {
switch(c) {
case 'c':
conffile = optarg;
case 'p':
pidfile = optarg;
break;
+ case 'a':
+ bindaddr = optarg;
+ break;
+ case 'b':
+ bindport = atoi(optarg);
+ break;
case 'd':
nodaemon = true;
break;
/* globals */
int udpsock;
bool_t shutdown_server;
+extern char *bindaddr;
+extern int bindport;
void Server_run()
{
struct sockaddr_in sin;
int val, clientcount;
etimer_t janitorTimer;
-
+ unsigned short port;
+ in_addr_t inet_address;
+
/* max clients + listen sock + udp sock + client connecting that will be disconnected */
pollfds = malloc((getIntConf(MAX_CLIENTS) + 3) * sizeof(struct pollfd));
if (pollfds == NULL)
Log_fatal("out of memory");
+
+ /* Figure out bind address and port */
+ if (bindport != 0)
+ port = htons(bindport);
+ else
+ port = htons(getIntConf(BINDPORT));
+
+ if (bindaddr != NULL && inet_addr(bindaddr) != -1)
+ inet_address = inet_addr(bindaddr);
+ else if (inet_addr(getStrConf(BINDADDR)) != -1)
+ inet_address = inet_addr(getStrConf(BINDADDR));
+ else
+ inet_address = inet_addr("0.0.0.0");
+ Log_info("Bind to %s:%hu", inet_address == 0 ? "*" : inet_ntoa(*((struct in_addr *)&inet_address)), ntohs(port));
/* Prepare TCP socket */
memset(&sin, 0, sizeof(sin));
if (setsockopt(tcpsock, SOL_SOCKET, SO_REUSEADDR, &sockopt, sizeof(int)) != 0)
Log_fatal("setsockopt: %s", strerror(errno));
sin.sin_family = AF_INET;
- sin.sin_port = htons(getIntConf(BINDPORT));
- sin.sin_addr.s_addr = inet_addr(getStrConf(BINDADDR)) == -1 ? inet_addr("0.0.0.0") : inet_addr(getStrConf(BINDADDR));
+ sin.sin_port = port;
+ sin.sin_addr.s_addr = inet_address;
+
rc = bind(tcpsock, (struct sockaddr *) &sin, sizeof (struct sockaddr_in));
if (rc < 0) Log_fatal("bind: %s", strerror(errno));
rc = listen(tcpsock, 3);
memset(&sin, 0, sizeof(sin));
udpsock = socket(PF_INET, SOCK_DGRAM, 0);
sin.sin_family = AF_INET;
- sin.sin_port = htons(getIntConf(BINDPORT));
- sin.sin_addr.s_addr = inet_addr(getStrConf(BINDADDR)) == -1 ? inet_addr("0.0.0.0") : inet_addr(getStrConf(BINDADDR));
+ sin.sin_port = port;
+ sin.sin_addr.s_addr = inet_address;
+
rc = bind(udpsock, (struct sockaddr *) &sin, sizeof (struct sockaddr_in));
if (rc < 0)
Log_fatal("bind %d %s: %s", getIntConf(BINDPORT), getStrConf(BINDADDR), strerror(errno));