58 lines
1.9 KiB
C
58 lines
1.9 KiB
C
--- main.c.orig 2010-11-26 17:45:26.000000000 +0300
|
|
+++ main.c 2010-11-26 17:47:46.000000000 +0300
|
|
@@ -1,13 +1,16 @@
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
+#include <string.h>
|
|
#include <unistd.h>
|
|
#include <syslog.h>
|
|
+#include <pthread.h>
|
|
#include <signal.h>
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
#include <sys/stat.h>
|
|
#include <sys/resource.h>
|
|
#include <time.h>
|
|
+#include <sys/socket.h>
|
|
#include <net/if.h>
|
|
#include <upnp/upnp.h>
|
|
#include "globals.h"
|
|
@@ -22,7 +25,6 @@
|
|
int main (int argc, char** argv)
|
|
{
|
|
char descDocUrl[7+15+1+5+1+sizeof(g_vars.descDocName)+1]; // http://ipaddr:port/docName<null>
|
|
- char intIpAddress[16]; // Server internal ip address
|
|
sigset_t sigsToCatch;
|
|
int ret, signum, arg = 1, foreground = 0;
|
|
|
|
@@ -46,11 +48,17 @@
|
|
strncpy(g_vars.intInterfaceName, argv[arg++], IFNAMSIZ);
|
|
|
|
// Get the internal ip address to start the daemon on
|
|
- if (GetIpAddressStr(intIpAddress, g_vars.intInterfaceName) == 0) {
|
|
+ if (GetIpAddressStr(g_vars.intIpAddress, g_vars.intInterfaceName) == 0) {
|
|
fprintf(stderr, "Invalid internal interface name '%s'\n", g_vars.intInterfaceName);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
|
|
+ // Get the external ip address to start the daemon on
|
|
+ if (GetIpAddressStr(g_vars.extIpAddress, g_vars.extInterfaceName) == 0) {
|
|
+ fprintf(stderr, "Invalid external interface name '%s'\n", g_vars.extInterfaceName);
|
|
+ exit(EXIT_FAILURE);
|
|
+ }
|
|
+
|
|
if (!foreground) {
|
|
struct rlimit resourceLimit = { 0, 0 };
|
|
pid_t pid, sid;
|
|
@@ -114,9 +122,9 @@
|
|
|
|
// Initialize UPnP SDK on the internal Interface
|
|
trace(3, "Initializing UPnP SDK ... ");
|
|
- if ( (ret = UpnpInit(intIpAddress,0) ) != UPNP_E_SUCCESS)
|
|
+ if ( (ret = UpnpInit(g_vars.intIpAddress,0) ) != UPNP_E_SUCCESS)
|
|
{
|
|
- syslog (LOG_ERR, "Error Initializing UPnP SDK on IP %s ",intIpAddress);
|
|
+ syslog (LOG_ERR, "Error Initializing UPnP SDK on IP %s ",g_vars.intIpAddress);
|
|
syslog (LOG_ERR, " UpnpInit returned %d", ret);
|
|
UpnpFinish();
|
|
exit(1);
|