[package] ez-ipudate: fix config generator to permit default server
authorFlorian Fainelli <florian@openwrt.org>
Sat, 10 Apr 2010 18:33:10 +0000 (18:33 +0000)
committerFlorian Fainelli <florian@openwrt.org>
Sat, 10 Apr 2010 18:33:10 +0000 (18:33 +0000)
This patch allows ez-ipupdate to use the default server for the specified DDNS
service type when no server hostname is supplied by the user.

In detail:

The default config file supplied in the ez-ipupdate package does not include a
"server" line, and ez-ipupdate itself does not require an explicit server
(since it will select a server based on the service type).

Unfortunately, if the user simply fills in the blanks in the OpenWrt-supplied
ez-ipupdate config, the service will silently fail to start because the hotplug
 script inserts a line in the generated config which states "server=", and
ez-ipupdate doesn't like a blank server setting.

The above scenario doesn't seem like a good user experience, so this is a
small patch to the hotplug script to omit the "server" line (and let
ez-ipupdate select its own default) in the event that the user has not
specified a server.

Signed-off-by: Scott Dudley <spmsink@hotmail.com>
SVN-Revision: 20783

net/ez-ipupdate/files/ez-ipupdate.hotplug

index 8f924f154fce49fe093c8288c6ba0f9ba02fe539..f07542f4f10b639e5f64300dd1d6cc8de93dc73f 100644 (file)
@@ -25,7 +25,7 @@ case "$ACTION" in
 
                    config_get pidfile $cfg pidfile
                    pidfile=${pidfile:-/var/run/$NAME-$service-$dev.pid}
-                           
+
                    case "$ACTION" in
                        ifdown)
                            cleanup $pidfile
@@ -36,7 +36,7 @@ case "$ACTION" in
                                    [ ! -e $pidfile ] && {
                                        config_get cache $cfg cache
                                        [ -z "$cache" ] && cache=/tmp/$NAME-$service-$dev.cache
-                                       
+
                                        config_get config $cfg config
                                        [ -z "$config" ] && {
                                            config=/var/run/$NAME-$service-$dev.conf
@@ -45,9 +45,13 @@ case "$ACTION" in
                                            config_get hostname $cfg hostname
                                            service=${service:-"dyndns"}
                                            config_get server   $cfg server
+                                           server_line=""
+                                           [ -n "$server" ] && {
+                                               server_line="server=$server"
+                                           }
                                            cat > $config <<EOF
 service-type=$service
-${server:+server=$server}
+$server_line
 user=$username:$password
 host=$hostname
 cache-file=$cache
@@ -56,7 +60,7 @@ interface=$dev
 quiet
 EOF
                                        }
-                                       
+
                                        $COMMAND -c $config 2>&1 | logger -t $NAME &
                                    }
                                    ;;
@@ -68,12 +72,12 @@ EOF
                }
            }
        }
-       
-       
+
+
        include /lib/network
        scan_interfaces
        config_load ddns
-       
+
        config_foreach ddns ddns
        ;;
 esac