diff options
Diffstat (limited to 'meta')
-rw-r--r-- | meta/classes/rootfs-postcommands.bbclass | 5 | ||||
-rwxr-xr-x | meta/recipes-core/dropbear/dropbear/init | 26 |
2 files changed, 9 insertions, 22 deletions
diff --git a/meta/classes/rootfs-postcommands.bbclass b/meta/classes/rootfs-postcommands.bbclass index 5522209534..221869e04c 100644 --- a/meta/classes/rootfs-postcommands.bbclass +++ b/meta/classes/rootfs-postcommands.bbclass | |||
@@ -112,14 +112,11 @@ read_only_rootfs_hook () { | |||
112 | 112 | ||
113 | # Also tweak the key location for dropbear in the same way. | 113 | # Also tweak the key location for dropbear in the same way. |
114 | if [ -d ${IMAGE_ROOTFS}/etc/dropbear ]; then | 114 | if [ -d ${IMAGE_ROOTFS}/etc/dropbear ]; then |
115 | if [ -e ${IMAGE_ROOTFS}/etc/dropbear/dropbear_rsa_host_key ]; then | 115 | if [ ! -e ${IMAGE_ROOTFS}/etc/dropbear/dropbear_rsa_host_key ]; then |
116 | echo "DROPBEAR_RSAKEY_DIR=/etc/dropbear" >> ${IMAGE_ROOTFS}/etc/default/dropbear | ||
117 | else | ||
118 | echo "DROPBEAR_RSAKEY_DIR=/var/lib/dropbear" >> ${IMAGE_ROOTFS}/etc/default/dropbear | 116 | echo "DROPBEAR_RSAKEY_DIR=/var/lib/dropbear" >> ${IMAGE_ROOTFS}/etc/default/dropbear |
119 | fi | 117 | fi |
120 | fi | 118 | fi |
121 | 119 | ||
122 | |||
123 | if ${@bb.utils.contains("DISTRO_FEATURES", "sysvinit", "true", "false", d)}; then | 120 | if ${@bb.utils.contains("DISTRO_FEATURES", "sysvinit", "true", "false", d)}; then |
124 | # Change the value of ROOTFS_READ_ONLY in /etc/default/rcS to yes | 121 | # Change the value of ROOTFS_READ_ONLY in /etc/default/rcS to yes |
125 | if [ -e ${IMAGE_ROOTFS}/etc/default/rcS ]; then | 122 | if [ -e ${IMAGE_ROOTFS}/etc/default/rcS ]; then |
diff --git a/meta/recipes-core/dropbear/dropbear/init b/meta/recipes-core/dropbear/dropbear/init index f6e1c462fa..ffab7a2362 100755 --- a/meta/recipes-core/dropbear/dropbear/init +++ b/meta/recipes-core/dropbear/dropbear/init | |||
@@ -17,8 +17,11 @@ NAME=dropbear | |||
17 | DESC="Dropbear SSH server" | 17 | DESC="Dropbear SSH server" |
18 | PIDFILE=/var/run/dropbear.pid | 18 | PIDFILE=/var/run/dropbear.pid |
19 | 19 | ||
20 | # These values may be replaced by those from /etc/default/dropbear | ||
21 | DROPBEAR_RSAKEY_DIR="/etc/dropbear" | ||
20 | DROPBEAR_PORT=22 | 22 | DROPBEAR_PORT=22 |
21 | DROPBEAR_EXTRA_ARGS= | 23 | DROPBEAR_EXTRA_ARGS= |
24 | DROPBEAR_RSAKEY_ARGS= | ||
22 | NO_START=0 | 25 | NO_START=0 |
23 | 26 | ||
24 | set -e | 27 | set -e |
@@ -28,32 +31,19 @@ test "$NO_START" = "0" || exit 0 | |||
28 | test -x "$DAEMON" || exit 0 | 31 | test -x "$DAEMON" || exit 0 |
29 | test ! -h /var/service/dropbear || exit 0 | 32 | test ! -h /var/service/dropbear || exit 0 |
30 | 33 | ||
31 | readonly_rootfs=0 | ||
32 | for flag in `awk '{ if ($2 == "/") { split($4,FLAGS,",") } }; END { for (f in FLAGS) print FLAGS[f] }' </proc/mounts`; do | ||
33 | case $flag in | ||
34 | ro) | ||
35 | readonly_rootfs=1 | ||
36 | ;; | ||
37 | esac | ||
38 | done | ||
39 | |||
40 | if [ $readonly_rootfs = "1" ]; then | ||
41 | mkdir -p /var/lib/dropbear | ||
42 | DROPBEAR_RSAKEY_DEFAULT="/var/lib/dropbear/dropbear_rsa_host_key" | ||
43 | else | ||
44 | DROPBEAR_RSAKEY_DEFAULT="/etc/dropbear/dropbear_rsa_host_key" | ||
45 | fi | ||
46 | |||
47 | test -z "$DROPBEAR_BANNER" || \ | 34 | test -z "$DROPBEAR_BANNER" || \ |
48 | DROPBEAR_EXTRA_ARGS="$DROPBEAR_EXTRA_ARGS -b $DROPBEAR_BANNER" | 35 | DROPBEAR_EXTRA_ARGS="$DROPBEAR_EXTRA_ARGS -b $DROPBEAR_BANNER" |
49 | test -n "$DROPBEAR_RSAKEY" || \ | 36 | test -n "$DROPBEAR_RSAKEY" || \ |
50 | DROPBEAR_RSAKEY=$DROPBEAR_RSAKEY_DEFAULT | 37 | DROPBEAR_RSAKEY="${DROPBEAR_RSAKEY_DIR}/dropbear_rsa_host_key" |
51 | 38 | ||
52 | gen_keys() { | 39 | gen_keys() { |
53 | if [ -f "$DROPBEAR_RSAKEY" -a ! -s "$DROPBEAR_RSAKEY" ]; then | 40 | if [ -f "$DROPBEAR_RSAKEY" -a ! -s "$DROPBEAR_RSAKEY" ]; then |
54 | rm $DROPBEAR_RSAKEY || true | 41 | rm $DROPBEAR_RSAKEY || true |
55 | fi | 42 | fi |
56 | test -f $DROPBEAR_RSAKEY || dropbearkey -t rsa -f $DROPBEAR_RSAKEY $DROPBEAR_RSAKEY_ARGS | 43 | if [ ! -f "$DROPBEAR_RSAKEY" ]; then |
44 | mkdir -p ${DROPBEAR_RSAKEY%/*} | ||
45 | dropbearkey -t rsa -f $DROPBEAR_RSAKEY $DROPBEAR_RSAKEY_ARGS | ||
46 | fi | ||
57 | } | 47 | } |
58 | 48 | ||
59 | case "$1" in | 49 | case "$1" in |