2014-12-10 09:03:13 +00:00
|
|
|
/* $Id: upnpglobalvars.c,v 1.38 2014/12/10 09:02:15 nanard Exp $ */
|
2011-09-28 19:13:20 +00:00
|
|
|
/* MiniUPnP project
|
|
|
|
* http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/
|
2014-02-03 09:47:47 +00:00
|
|
|
* (c) 2006-2014 Thomas Bernard
|
2011-09-28 19:13:20 +00:00
|
|
|
* This software is subject to the conditions detailed
|
|
|
|
* in the LICENCE file provided within the distribution */
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
#include "upnpglobalvars.h"
|
2013-10-20 21:02:19 +00:00
|
|
|
#include "upnpdescstrings.h"
|
2011-09-28 19:13:20 +00:00
|
|
|
|
|
|
|
/* network interface for internet */
|
|
|
|
const char * ext_if_name = 0;
|
|
|
|
|
|
|
|
/* file to store leases */
|
|
|
|
#ifdef ENABLE_LEASEFILE
|
|
|
|
const char* lease_file = 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* forced ip address to use for this interface
|
|
|
|
* when NULL, getifaddr() is used */
|
|
|
|
const char * use_ext_ip_addr = 0;
|
|
|
|
|
|
|
|
unsigned long downstream_bitrate = 0;
|
|
|
|
unsigned long upstream_bitrate = 0;
|
|
|
|
|
|
|
|
/* startup time */
|
|
|
|
time_t startup_time = 0;
|
|
|
|
|
2014-02-03 09:47:47 +00:00
|
|
|
#ifdef ENABLE_PCP
|
|
|
|
/* for PCP */
|
2013-07-09 13:36:53 +00:00
|
|
|
unsigned long int min_lifetime = 120;
|
|
|
|
unsigned long int max_lifetime = 86400;
|
2014-02-03 09:47:47 +00:00
|
|
|
#endif
|
2013-07-09 13:36:53 +00:00
|
|
|
|
2011-09-28 19:13:20 +00:00
|
|
|
int runtime_flags = 0;
|
|
|
|
|
|
|
|
const char * pidfilename = "/var/run/miniupnpd.pid";
|
|
|
|
|
2013-06-13 14:03:36 +00:00
|
|
|
char uuidvalue_igd[] = "uuid:00000000-0000-0000-0000-000000000000";
|
|
|
|
char uuidvalue_wan[] = "uuid:00000000-0000-0000-0000-000000000000";
|
|
|
|
char uuidvalue_wcd[] = "uuid:00000000-0000-0000-0000-000000000000";
|
2011-09-28 19:13:20 +00:00
|
|
|
char serialnumber[SERIALNUMBER_MAX_LEN] = "00000000";
|
|
|
|
|
|
|
|
char modelnumber[MODELNUMBER_MAX_LEN] = "1";
|
|
|
|
|
|
|
|
/* presentation url :
|
|
|
|
* http://nnn.nnn.nnn.nnn:ppppp/ => max 30 bytes including terminating 0 */
|
2012-03-01 01:44:38 +00:00
|
|
|
char presentationurl[PRESENTATIONURL_MAX_LEN];
|
2012-02-04 23:24:13 +00:00
|
|
|
|
2013-12-13 11:03:28 +00:00
|
|
|
#ifdef ENABLE_MANUFACTURER_INFO_CONFIGURATION
|
2012-02-04 23:24:13 +00:00
|
|
|
/* friendly name for root devices in XML description */
|
|
|
|
char friendly_name[FRIENDLY_NAME_MAX_LEN] = OS_NAME " router";
|
2011-09-28 19:13:20 +00:00
|
|
|
|
2013-10-20 21:02:19 +00:00
|
|
|
/* manufacturer name for root devices in XML description */
|
|
|
|
char manufacturer_name[MANUFACTURER_NAME_MAX_LEN] = ROOTDEV_MANUFACTURER;
|
|
|
|
|
|
|
|
/* manufacturer url for root devices in XML description */
|
|
|
|
char manufacturer_url[MANUFACTURER_URL_MAX_LEN] = ROOTDEV_MANUFACTURERURL;
|
|
|
|
|
|
|
|
/* model name for root devices in XML description */
|
|
|
|
char model_name[MODEL_NAME_MAX_LEN] = ROOTDEV_MODELNAME;
|
|
|
|
|
|
|
|
/* model description for root devices in XML description */
|
|
|
|
char model_description[MODEL_DESCRIPTION_MAX_LEN] = ROOTDEV_MODELDESCRIPTION;
|
|
|
|
|
|
|
|
/* model url for root devices in XML description */
|
|
|
|
char model_url[MODEL_URL_MAX_LEN] = ROOTDEV_MODELURL;
|
2013-12-13 11:03:28 +00:00
|
|
|
#endif
|
2013-10-20 21:02:19 +00:00
|
|
|
|
2011-09-28 19:13:20 +00:00
|
|
|
/* UPnP permission rules : */
|
|
|
|
struct upnpperm * upnppermlist = 0;
|
|
|
|
unsigned int num_upnpperm = 0;
|
|
|
|
|
2013-07-09 13:36:53 +00:00
|
|
|
#ifdef PCP_SADSCP
|
|
|
|
struct dscp_values* dscp_values_list = 0;
|
|
|
|
unsigned int num_dscp_values = 0;
|
2013-12-13 16:01:41 +00:00
|
|
|
#endif /*PCP_SADSCP*/
|
2011-09-28 19:13:20 +00:00
|
|
|
|
|
|
|
/* For automatic removal of expired rules (with LeaseDuration) */
|
|
|
|
unsigned int nextruletoclean_timestamp = 0;
|
|
|
|
|
|
|
|
#ifdef USE_PF
|
2012-02-03 12:14:10 +00:00
|
|
|
const char * anchor_name = "miniupnpd";
|
2011-09-28 19:13:20 +00:00
|
|
|
const char * queue = 0;
|
|
|
|
const char * tag = 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef USE_NETFILTER
|
|
|
|
/* chain name to use, both in the nat table
|
|
|
|
* and the filter table */
|
|
|
|
const char * miniupnpd_nat_chain = "MINIUPNPD";
|
2013-07-09 13:36:53 +00:00
|
|
|
const char * miniupnpd_peer_chain = "MINIUPNPD-PCP-PEER";
|
2011-09-28 19:13:20 +00:00
|
|
|
const char * miniupnpd_forward_chain = "MINIUPNPD";
|
2014-05-10 11:09:48 +00:00
|
|
|
#ifdef ENABLE_UPNPPINHOLE
|
2012-04-26 14:08:39 +00:00
|
|
|
const char * miniupnpd_v6_filter_chain = "MINIUPNPD";
|
|
|
|
#endif
|
|
|
|
|
2011-09-28 19:13:20 +00:00
|
|
|
#endif
|
|
|
|
#ifdef ENABLE_NFQUEUE
|
|
|
|
int nfqueue = -1;
|
|
|
|
int n_nfqix = 0;
|
|
|
|
unsigned nfqix[MAX_LAN_ADDR];
|
|
|
|
#endif
|
|
|
|
struct lan_addr_list lan_addrs;
|
|
|
|
|
|
|
|
#ifdef ENABLE_IPV6
|
|
|
|
/* ipv6 address used for HTTP */
|
|
|
|
char ipv6_addr_for_http_with_brackets[64];
|
2014-05-20 12:43:47 +00:00
|
|
|
|
|
|
|
/* address used to bind local services */
|
|
|
|
struct in6_addr ipv6_bind_addr;
|
2011-09-28 19:13:20 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Path of the Unix socket used to communicate with MiniSSDPd */
|
|
|
|
const char * minissdpdsocketpath = "/var/run/minissdpd.sock";
|
|
|
|
|
|
|
|
/* BOOTID.UPNP.ORG and CONFIGID.UPNP.ORG */
|
2014-12-10 09:03:13 +00:00
|
|
|
/* See UPnP Device Architecture v1.1 section 1.2 Advertisement :
|
|
|
|
* The field value of the BOOTID.UPNP.ORG header field MUST be increased
|
|
|
|
* each time a device (re)joins the network and sends an initial announce
|
|
|
|
* (a "reboot" in UPnP terms), or adds a UPnP-enabled interface.
|
|
|
|
* Unless the device explicitly announces a change in the BOOTID.UPNP.ORG
|
|
|
|
* field value using an SSDP message, as long as the device remains
|
|
|
|
* continuously available in the network, the same BOOTID.UPNP.ORG field
|
|
|
|
* value MUST be used in all repeat announcements, search responses,
|
|
|
|
* update messages and eventually bye-bye messages. */
|
|
|
|
unsigned int upnp_bootid = 1; /* BOOTID.UPNP.ORG */
|
|
|
|
/* The field value of the CONFIGID.UPNP.ORG header field identifies the
|
|
|
|
* current set of device and service descriptions; control points can
|
|
|
|
* parse this header field to detect whether they need to send new
|
|
|
|
* description query messages. */
|
|
|
|
unsigned int upnp_configid = 1337; /* CONFIGID.UPNP.ORG */
|
2011-09-28 19:13:20 +00:00
|
|
|
|