version 1.1.1.1, 2012/02/21 23:16:02
|
version 1.1.1.3.2.1, 2013/07/22 00:34:53
|
Line 2
|
Line 2
|
# $Id$ |
# $Id$ |
# miniupnp daemon |
# miniupnp daemon |
# http://miniupnp.free.fr or http://miniupnp.tuxfamily.org/ |
# http://miniupnp.free.fr or http://miniupnp.tuxfamily.org/ |
# (c) 2006-2010 Thomas Bernard | # (c) 2006-2012 Thomas Bernard |
# This software is subject to the conditions detailed in the |
# This software is subject to the conditions detailed in the |
# LICENCE file provided within the distribution |
# LICENCE file provided within the distribution |
|
|
|
for argv; do |
|
case "$argv" in |
|
--ipv6) IPV6=1 ;; |
|
--igd2) IGD2=1 ;; |
|
--strict) STRICT=1 ;; |
|
--leasefile) LEASEFILE=1 ;; |
|
--help|-h) |
|
echo "Usage : $0 [options]" |
|
echo " --ipv6 enable IPv6" |
|
echo " --igd2 build an IGDv2 instead of an IGDv1" |
|
echo " --strict be more strict regarding compliance with UPnP specifications" |
|
echo " --leasefile enable lease file" |
|
exit 1 |
|
;; |
|
*) |
|
echo "Option not recognized : $argv" |
|
echo "use -h option to display help" |
|
exit 1 |
|
;; |
|
esac |
|
done |
|
|
RM="rm -f" |
RM="rm -f" |
CONFIGFILE="config.h" |
CONFIGFILE="config.h" |
CONFIGMACRO="__CONFIG_H__" | CONFIGMACRO="CONFIG_H_INCLUDED" |
|
|
# version reported in XML descriptions |
# version reported in XML descriptions |
#UPNP_VERSION=20070827 |
#UPNP_VERSION=20070827 |
Line 28 if [ -f /etc/platform ]; then
|
Line 50 if [ -f /etc/platform ]; then
|
fi |
fi |
fi |
fi |
|
|
|
# OpenWRT special case |
|
if [ -f ./os.openwrt ]; then |
|
OS_NAME=OpenWRT |
|
OS_VERSION=$(cat ./os.openwrt) |
|
fi |
|
|
|
# AstLinux special case |
|
if [ -f ./os.astlinux ]; then |
|
OS_NAME=AstLinux |
|
OS_VERSION=$(cat ./os.astlinux) |
|
fi |
|
|
|
# Tomato USB special case |
|
if [ -f ../shared/tomato_version ]; then |
|
OS_NAME=Tomato |
|
OS_VERSION="Tomato $(cat ../shared/tomato_version)" |
|
fi |
|
|
${RM} ${CONFIGFILE} |
${RM} ${CONFIGFILE} |
|
|
echo "/* MiniUPnP Project" >> ${CONFIGFILE} |
echo "/* MiniUPnP Project" >> ${CONFIGFILE} |
echo " * http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/" >> ${CONFIGFILE} |
echo " * http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/" >> ${CONFIGFILE} |
echo " * (c) 2006-2010 Thomas Bernard" >> ${CONFIGFILE} | echo " * (c) 2006-2012 Thomas Bernard" >> ${CONFIGFILE} |
echo " * generated by $0 on `date` */" >> ${CONFIGFILE} | echo " * generated by $0 on `date`" >> ${CONFIGFILE} |
| echo " * using command line options $* */" >> ${CONFIGFILE} |
echo "#ifndef $CONFIGMACRO" >> ${CONFIGFILE} |
echo "#ifndef $CONFIGMACRO" >> ${CONFIGFILE} |
echo "#define $CONFIGMACRO" >> ${CONFIGFILE} |
echo "#define $CONFIGMACRO" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "#include <inttypes.h>" >> ${CONFIGFILE} |
echo "#include <inttypes.h>" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
echo "#define MINIUPNPD_VERSION \"`cat VERSION`\"" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
echo "#define UPNP_VERSION \"$UPNP_VERSION\"" >> ${CONFIGFILE} |
echo "#define UPNP_VERSION \"$UPNP_VERSION\"" >> ${CONFIGFILE} |
|
|
# OS Specific stuff |
# OS Specific stuff |
Line 59 case $OS_NAME in
|
Line 102 case $OS_NAME in
|
if [ \( $MAJORVER -ge 5 \) -o \( $MAJORVER -eq 4 -a $MINORVER -ge 7 \) ]; then |
if [ \( $MAJORVER -ge 5 \) -o \( $MAJORVER -eq 4 -a $MINORVER -ge 7 \) ]; then |
echo "#define PF_NEWSTYLE" >> ${CONFIGFILE} |
echo "#define PF_NEWSTYLE" >> ${CONFIGFILE} |
fi |
fi |
echo "#define USE_PF 1" >> ${CONFIGFILE} | # onrdomain was introduced in OpenBSD 5.0 |
| if [ $MAJORVER -ge 5 ]; then |
| echo "#define PFRULE_HAS_ONRDOMAIN" >> ${CONFIGFILE} |
| fi |
FW=pf |
FW=pf |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
OS_URL=http://www.openbsd.org/ |
OS_URL=http://www.openbsd.org/ |
;; |
;; |
FreeBSD) |
FreeBSD) |
Line 70 case $OS_NAME in
|
Line 117 case $OS_NAME in
|
fi |
fi |
# new way to see which one to use PF or IPF. |
# new way to see which one to use PF or IPF. |
# see http://miniupnp.tuxfamily.org/forum/viewtopic.php?p=957 |
# see http://miniupnp.tuxfamily.org/forum/viewtopic.php?p=957 |
# source file with handy subroutines like checkyesno | if [ -f /etc/rc.subr ] && [ -f /etc/rc.conf ] ; then |
. /etc/rc.subr | # source file with handy subroutines like checkyesno |
# source config file so we can probe vars | . /etc/rc.subr |
. /etc/rc.conf | # source config file so we can probe vars |
if checkyesno ipfilter_enable; then | . /etc/rc.conf |
echo "Using ipf" | if checkyesno ipfilter_enable; then |
| echo "Using ipf" |
FW=ipf |
FW=ipf |
echo "#define USE_IPF 1" >> ${CONFIGFILE} | elif checkyesno pf_enable; then |
elif checkyesno pf_enable; then | echo "Using pf" |
echo "Using pf" | FW=pf |
| elif checkyesno firewall_enable; then |
| echo "Using ifpw" |
| FW=ipfw |
| fi |
| fi |
| if [ -z $FW ] ; then |
| echo "Could not detect usage of ipf, pf, ipfw. Compiling for pf by default" |
FW=pf |
FW=pf |
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
# TODO : Add support for IPFW |
|
# echo "#define USE_IPFW 1" >> ${CONFIGFILE} |
|
# FW=ipfw |
|
else |
|
echo "Could not detect usage of ipf or pf. Compiling for pf by default" |
|
FW=pf |
|
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
fi |
fi |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
OS_URL=http://www.freebsd.org/ |
OS_URL=http://www.freebsd.org/ |
;; |
;; |
pfSense) |
pfSense) |
# we need to detect if PFRULE_INOUT_COUNTS macro is needed |
# we need to detect if PFRULE_INOUT_COUNTS macro is needed |
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
FW=pf |
FW=pf |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
OS_URL=http://www.pfsense.com/ |
OS_URL=http://www.pfsense.com/ |
;; |
;; |
NetBSD) |
NetBSD) |
# source file with handy subroutines like checkyesno | if [ -f /etc/rc.subr ] && [ -f /etc/rc.conf ] ; then |
. /etc/rc.subr | # source file with handy subroutines like checkyesno |
# source config file so we can probe vars | . /etc/rc.subr |
. /etc/rc.conf | # source config file so we can probe vars |
if checkyesno pf; then | . /etc/rc.conf |
echo "#define USE_PF 1" >> ${CONFIGFILE} | if checkyesno pf; then |
FW=pf | FW=pf |
elif checkyesno ipfilter; then | elif checkyesno ipfilter; then |
echo "#define USE_IPF 1" >> ${CONFIGFILE} | FW=ipf |
FW=ipf | fi |
else | fi |
| if [ -z $FW ] ; then |
echo "Could not detect ipf nor pf, defaulting to pf." |
echo "Could not detect ipf nor pf, defaulting to pf." |
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
FW=pf |
FW=pf |
fi |
fi |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
OS_URL=http://www.netbsd.org/ |
OS_URL=http://www.netbsd.org/ |
;; |
;; |
DragonFly) |
DragonFly) |
# source file with handy subroutines like checkyesno | if [ -f /etc/rc.subr ] && [ -f /etc/rc.conf ] ; then |
. /etc/rc.subr | # source file with handy subroutines like checkyesno |
# source config file so we can probe vars | . /etc/rc.subr |
. /etc/rc.conf | # source config file so we can probe vars |
if checkyesno pf; then | . /etc/rc.conf |
echo "#define USE_PF 1" >> ${CONFIGFILE} | if checkyesno pf; then |
FW=pf | FW=pf |
elif checkyesno ipfilter; then | elif checkyesno ipfilter; then |
echo "#define USE_IPF 1" >> ${CONFIGFILE} | FW=ipf |
FW=ipf | fi |
else | fi |
| if [ -z $FW ] ; then |
echo "Could not detect ipf nor pf, defaulting to pf." |
echo "Could not detect ipf nor pf, defaulting to pf." |
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
FW=pf |
FW=pf |
fi |
fi |
echo "#define USE_PF 1" >> ${CONFIGFILE} | echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
OS_URL=http://www.dragonflybsd.org/ |
OS_URL=http://www.dragonflybsd.org/ |
;; |
;; |
SunOS) |
SunOS) |
echo "#define USE_IPF 1" >> ${CONFIGFILE} | echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
FW=ipf |
FW=ipf |
echo "#define LOG_PERROR 0" >> ${CONFIGFILE} |
echo "#define LOG_PERROR 0" >> ${CONFIGFILE} |
echo "#define SOLARIS_KSTATS 1" >> ${CONFIGFILE} |
echo "#define SOLARIS_KSTATS 1" >> ${CONFIGFILE} |
|
# solaris 10 does not define u_int64_t ? |
|
# but it does define uint64_t |
|
echo "typedef uint64_t u_int64_t;" >> ${CONFIGFILE} |
OS_URL=http://www.sun.com/solaris/ |
OS_URL=http://www.sun.com/solaris/ |
;; |
;; |
Linux) |
Linux) |
Line 155 case $OS_NAME in
|
Line 207 case $OS_NAME in
|
OS_VERSION=`cat /etc/debian_version` |
OS_VERSION=`cat /etc/debian_version` |
OS_URL=http://www.debian.org/ |
OS_URL=http://www.debian.org/ |
fi |
fi |
|
# same thing for Gentoo linux |
|
if [ -f /etc/gentoo-release ]; then |
|
OS_NAME=Gentoo |
|
OS_VERSION=`cat /etc/gentoo-release` |
|
OS_URL=http://www.gentoo.org/ |
|
fi |
# use lsb_release (Linux Standard Base) when available |
# use lsb_release (Linux Standard Base) when available |
LSB_RELEASE=`which lsb_release` |
LSB_RELEASE=`which lsb_release` |
if [ 0 -eq $? ]; then |
if [ 0 -eq $? ]; then |
Line 169 case $OS_NAME in
|
Line 227 case $OS_NAME in
|
OS_URL=http://www.ubuntu.com/ |
OS_URL=http://www.ubuntu.com/ |
OS_VERSION=`${LSB_RELEASE} -c -s` |
OS_VERSION=`${LSB_RELEASE} -c -s` |
;; |
;; |
|
Gentoo) |
|
OS_URL=http://www.gentoo.org/ |
|
;; |
esac |
esac |
fi |
fi |
echo "#define USE_NETFILTER 1" >> ${CONFIGFILE} | echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
FW=netfilter |
FW=netfilter |
;; |
;; |
|
OpenWRT) |
|
OS_URL=http://www.openwrt.org/ |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
|
FW=netfilter |
|
;; |
|
AstLinux) |
|
OS_URL=http://www.astlinux.org/ |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
|
FW=netfilter |
|
;; |
|
Tomato) |
|
OS_NAME=UPnP |
|
OS_URL=http://tomatousb.org/ |
|
echo "" >> ${CONFIGFILE} |
|
echo "#include <tomato_config.h>" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
|
echo "#ifdef LINUX26" >> ${CONFIGFILE} |
|
echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
|
echo "#endif" >> ${CONFIGFILE} |
|
echo "#ifdef TCONFIG_IPV6" >> ${CONFIGFILE} |
|
echo "#define ENABLE_IPV6" >> ${CONFIGFILE} |
|
echo "#endif" >> ${CONFIGFILE} |
|
FW=netfilter |
|
;; |
Darwin) |
Darwin) |
echo "#define USE_IPFW 1" >> ${CONFIGFILE} | echo "#define USE_IFACEWATCHER 1" >> ${CONFIGFILE} |
FW=ipfw |
FW=ipfw |
OS_URL=http://developer.apple.com/macosx |
OS_URL=http://developer.apple.com/macosx |
;; |
;; |
Line 186 case $OS_NAME in
|
Line 271 case $OS_NAME in
|
;; |
;; |
esac |
esac |
|
|
|
case $FW in |
|
pf) |
|
echo "#define USE_PF 1" >> ${CONFIGFILE} |
|
;; |
|
ipf) |
|
echo "#define USE_IPF 1" >> ${CONFIGFILE} |
|
;; |
|
ipfw) |
|
echo "#define USE_IPFW 1" >> ${CONFIGFILE} |
|
;; |
|
netfilter) |
|
echo "#define USE_NETFILTER 1" >> ${CONFIGFILE} |
|
;; |
|
*) |
|
echo "Unknown Firewall/packet filtering software [$FW]" |
|
echo "Please contact the author at http://miniupnp.free.fr/ or http://miniupnp.tuxfamily.org/." |
|
exit 1 |
|
;; |
|
esac |
|
|
echo "Configuring compilation for [$OS_NAME] [$OS_VERSION] with [$FW] firewall software." |
echo "Configuring compilation for [$OS_NAME] [$OS_VERSION] with [$FW] firewall software." |
echo "Please edit config.h for more compilation options." |
echo "Please edit config.h for more compilation options." |
|
|
|
# define SUPPORT_REMOTEHOST if the FW related code really supports setting |
|
# a RemoteHost |
|
if [ \( "$FW" = "netfilter" \) -o \( "$FW" = "pf" \) -o \( "$FW" = "ipfw" \) ] ; then |
|
echo "#define SUPPORT_REMOTEHOST" >> ${CONFIGFILE} |
|
fi |
|
|
|
echo "" >> ${CONFIGFILE} |
echo "#define OS_NAME \"$OS_NAME\"" >> ${CONFIGFILE} |
echo "#define OS_NAME \"$OS_NAME\"" >> ${CONFIGFILE} |
echo "#define OS_VERSION \"$OS_NAME/$OS_VERSION\"" >> ${CONFIGFILE} |
echo "#define OS_VERSION \"$OS_NAME/$OS_VERSION\"" >> ${CONFIGFILE} |
echo "#define OS_URL \"${OS_URL}\"" >> ${CONFIGFILE} |
echo "#define OS_URL \"${OS_URL}\"" >> ${CONFIGFILE} |
Line 209 echo "" >> ${CONFIGFILE}
|
Line 321 echo "" >> ${CONFIGFILE}
|
|
|
echo "/* Uncomment the following line to enable generation of" >> ${CONFIGFILE} |
echo "/* Uncomment the following line to enable generation of" >> ${CONFIGFILE} |
echo " * filter rules with pf */" >> ${CONFIGFILE} |
echo " * filter rules with pf */" >> ${CONFIGFILE} |
echo "/*#define PF_ENABLE_FILTER_RULES*/">> ${CONFIGFILE} | echo "#define PF_ENABLE_FILTER_RULES">> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "/* Uncomment the following line to enable caching of results of" >> ${CONFIGFILE} |
echo "/* Uncomment the following line to enable caching of results of" >> ${CONFIGFILE} |
Line 232 echo "#define USE_DAEMON" >> ${CONFIGFILE}
|
Line 344 echo "#define USE_DAEMON" >> ${CONFIGFILE}
|
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "/* Uncomment the following line to enable lease file support */" >> ${CONFIGFILE} |
echo "/* Uncomment the following line to enable lease file support */" >> ${CONFIGFILE} |
echo "/*#define ENABLE_LEASEFILE*/" >> ${CONFIGFILE} | if [ -n "$LEASEFILE" ] ; then |
| echo "#define ENABLE_LEASEFILE" >> ${CONFIGFILE} |
| else |
| echo "/*#define ENABLE_LEASEFILE*/" >> ${CONFIGFILE} |
| fi |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "/* Define one or none of the two following macros in order to make some" >> ${CONFIGFILE} |
echo "/* Define one or none of the two following macros in order to make some" >> ${CONFIGFILE} |
Line 243 echo "/*#define HAS_DUMMY_SERVICE*/" >> ${CONFIGFILE}
|
Line 359 echo "/*#define HAS_DUMMY_SERVICE*/" >> ${CONFIGFILE}
|
echo "#define ENABLE_L3F_SERVICE" >> ${CONFIGFILE} |
echo "#define ENABLE_L3F_SERVICE" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "/* Experimental UPnP Events support. */" >> ${CONFIGFILE} | echo "/* Enable IP v6 support */" >> ${CONFIGFILE} |
echo "/*#define ENABLE_EVENTS*/" >> ${CONFIGFILE} | if [ -n "$IPV6" ]; then |
| echo "#define ENABLE_IPV6" >> ${CONFIGFILE} |
| else |
| echo "/*#define ENABLE_IPV6*/" >> ${CONFIGFILE} |
| fi |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
|
echo "/* Enable the support of IGD v2 specification." >> ${CONFIGFILE} |
|
echo " * This is not fully tested yet and can cause incompatibilities with some" >> ${CONFIGFILE} |
|
echo " * control points, so enable with care. */" >> ${CONFIGFILE} |
|
if [ -n "$IGD2" ]; then |
|
echo "#define IGD_V2" >> ${CONFIGFILE} |
|
else |
|
echo "/*#define IGD_V2*/" >> ${CONFIGFILE} |
|
fi |
|
echo "" >> ${CONFIGFILE} |
|
|
|
echo "#ifdef IGD_V2" >> ${CONFIGFILE} |
|
echo "/* Enable DeviceProtection service (IGDv2) */" >> ${CONFIGFILE} |
|
echo "#define ENABLE_DP_SERVICE" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
|
echo "/* Enable WANIPv6FirewallControl service (IGDv2). needs IPv6 */" >> ${CONFIGFILE} |
|
echo "#ifdef ENABLE_IPV6" >> ${CONFIGFILE} |
|
echo "#define ENABLE_6FC_SERVICE" >> ${CONFIGFILE} |
|
echo "#endif /* ENABLE_IPV6 */" >> ${CONFIGFILE} |
|
echo "#endif /* IGD_V2 */" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
|
|
|
echo "/* UPnP Events support. Working well enough to be enabled by default." >> ${CONFIGFILE} |
|
echo " * It can be disabled to save a few bytes. */" >> ${CONFIGFILE} |
|
echo "#define ENABLE_EVENTS" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
|
|
echo "/* include interface name in pf and ipf rules */" >> ${CONFIGFILE} |
echo "/* include interface name in pf and ipf rules */" >> ${CONFIGFILE} |
echo "#define USE_IFNAME_IN_RULES" >> ${CONFIGFILE} |
echo "#define USE_IFNAME_IN_RULES" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "/* Experimental NFQUEUE support. */" >> ${CONFIGFILE} |
echo "/* Experimental NFQUEUE support. */" >> ${CONFIGFILE} |
echo "/*#define ENABLE_NFQUEUE*/" >> ${CONFIGFILE} |
echo "/*#define ENABLE_NFQUEUE*/" >> ${CONFIGFILE} |
|
echo "" >> ${CONFIGFILE} |
|
|
|
echo "/* Enable to make MiniUPnPd more strict about UPnP conformance" >> ${CONFIGFILE} |
|
echo " * and the messages it receives from control points */" >> ${CONFIGFILE} |
|
if [ -n "$STRICT" ] ; then |
|
echo "#define UPNP_STRICT" >> ${CONFIGFILE} |
|
else |
|
echo "/*#define UPNP_STRICT*/" >> ${CONFIGFILE} |
|
fi |
|
echo "" >> ${CONFIGFILE} |
|
|
|
echo "/* Add the optional Date: header in all HTTP responses */" >> ${CONFIGFILE} |
|
if [ -n "$STRICT" ] ; then |
|
echo "#define ENABLE_HTTP_DATE" >> ${CONFIGFILE} |
|
else |
|
echo "/*#define ENABLE_HTTP_DATE*/" >> ${CONFIGFILE} |
|
fi |
|
echo "" >> ${CONFIGFILE} |
|
|
|
echo "/* disable reading and parsing of config file (miniupnpd.conf) */" >> ${CONFIGFILE} |
|
echo "/*#define DISABLE_CONFIG_FILE*/" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
echo "" >> ${CONFIGFILE} |
|
|
echo "#endif" >> ${CONFIGFILE} |
echo "#endif" >> ${CONFIGFILE} |