ssb: Workaround: Need subsys_initcall to be able to register a PCI bus.
[openwrt.git] / package / dropbear / files / dropbear.init
index 6f35672..f671df7 100755 (executable)
@@ -1,14 +1,15 @@
 #!/bin/sh /etc/rc.common
 # Copyright (C) 2006 OpenWrt.org
 #!/bin/sh /etc/rc.common
 # Copyright (C) 2006 OpenWrt.org
+START=50
 # Copyright (C) 2006 Carlos Sobrinho
 
 config_cb() {
        local cfg="$CONFIG_SECTION"
        local nopasswd
 # Copyright (C) 2006 Carlos Sobrinho
 
 config_cb() {
        local cfg="$CONFIG_SECTION"
        local nopasswd
-       local type
-       config_get cfgtype "$cfg" TYPE
+       local cfgt
+       config_get cfgt "$cfg" TYPE
 
 
-       case "$cfgtype" in
+       case "$cfgt" in
                dropbear)
                        config_get passauth $cfg PasswordAuth
                        config_get port $cfg Port
                dropbear)
                        config_get passauth $cfg PasswordAuth
                        config_get port $cfg Port
@@ -16,20 +17,20 @@ config_cb() {
                        case "$passauth" in
                                no|off|disabled|0) nopasswd=1;;
                        esac
                        case "$passauth" in
                                no|off|disabled|0) nopasswd=1;;
                        esac
-                       DROPBEAR_ARGS="${port:+-p $port} ${nopasswd:+-s}"
+                       DROPBEAR_ARGS="${nopasswd:+-s }${port:+-p $port}"
                ;;
        esac
 }
 
                ;;
        esac
 }
 
-start() {
+keygen() {
        for keytype in rsa dss; do
                # check for keys
        for keytype in rsa dss; do
                # check for keys
-               key=/tmp/dropbear/dropbear_${keytype}_host_key
-               [ ! -f $key ] && {
+               key=dropbear/dropbear_${keytype}_host_key
+               [ -f /tmp/$key -o -f /etc/$key ] || {
                        # generate missing keys
                        mkdir -p /tmp/dropbear
                        [ -x /usr/bin/dropbearkey ] && {
                        # generate missing keys
                        mkdir -p /tmp/dropbear
                        [ -x /usr/bin/dropbearkey ] && {
-                               /usr/bin/dropbearkey -t $keytype -f $key 2>&- >&- && exec /etc/rc.common "$initscript" start
+                               /usr/bin/dropbearkey -t $keytype -f /tmp/$key 2>&- >&- && exec /etc/rc.common "$initscript" start
                        } &
                exit 0
                }
                        } &
                exit 0
                }
@@ -39,9 +40,14 @@ start() {
        mkdir -p /etc/dropbear
        mv /tmp/dropbear/dropbear_* /etc/dropbear/
        lock -u /tmp/.switch2jffs
        mkdir -p /etc/dropbear
        mv /tmp/dropbear/dropbear_* /etc/dropbear/
        lock -u /tmp/.switch2jffs
-       
        chown root /etc/dropbear
        chmod 0700 /etc/dropbear
        chown root /etc/dropbear
        chmod 0700 /etc/dropbear
+}
+
+start() {
+       [ -f /etc/dropbear/dropbear_rsa_host_key -a \
+         -f /etc/dropbear/dropbear_dss_host_key ] || keygen
+       
        config_load dropbear
        /usr/sbin/dropbear $DROPBEAR_ARGS
 }
        config_load dropbear
        /usr/sbin/dropbear $DROPBEAR_ARGS
 }
This page took 0.023486 seconds and 4 git commands to generate.