package/dropbear: Fix symlink only if pointing to the right directory
authorPaul Cercueil <paul@crapouillou.net>
Tue, 28 Jul 2015 08:21:31 +0000 (10:21 +0200)
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Thu, 30 Jul 2015 21:36:02 +0000 (23:36 +0200)
This commit ensures that the /etc/dropbear symlink won't be removed if
it points elsewhere than /var/run/dropbear.

[Thomas:
 - fix indentation / too long lines as suggested by Yann E. Morin.]

Signed-off-by: Paul Cercueil <paul@crapouillou.net>
Reviewed-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
package/dropbear/S50dropbear
package/dropbear/dropbear.service

index af50ccf254afdc01e481a747f9e8d046a70a3596..893878950916b2ea1f656a96df3ad23565d02266 100644 (file)
@@ -12,12 +12,14 @@ start() {
        echo -n "Starting dropbear sshd: "
        umask 077
 
-       # If /etc/dropbear is not a directory, and
+       # If /etc/dropbear is a symlink to /var/run/dropbear, and
        #   - the filesystem is RO (i.e. we can not rm the symlink),
        #     create the directory pointed to by the symlink.
        #   - the filesystem is RW (i.e. we can rm the symlink),
        #     replace the symlink with an actual directory
-       if ! [ -d /etc/dropbear ]; then
+       if [ -L /etc/dropbear \
+            -a "$(readlink -f /etc/dropbear)" = "/var/run/dropbear" ]
+       then
                if rm -f /etc/dropbear; then
                        mkdir -p /etc/dropbear
                else
index 0e2cf548d3e3ab547baf2ac76bc3b901732d9e9e..52c77024f5ae38c086bcded156a464856fee2949 100644 (file)
@@ -3,13 +3,14 @@ Description=Dropbear SSH daemon
 After=syslog.target network.target auditd.service
 
 [Service]
-# If /etc/dropbear is not a directory, and
+# If /etc/dropbear is a symlink to /var/run/dropbear, and
 #   - the filesystem is RO (i.e. we can not rm the symlink),
 #     create the directory pointed to by the symlink.
 #   - the filesystem is RW (i.e. we can rm the symlink),
 #     replace the symlink with an actual directory
 ExecStartPre=/bin/sh -c '\
-if ! [ -d /etc/dropbear ]; then \
+if [ -L /etc/dropbear \
+     -a "$(readlink -f /etc/dropbear)" = "/var/run/dropbear" ]; then \
     if rm -f /etc/dropbear; then \
         mkdir -p /etc/dropbear; \
     else \