summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul Cercueil <paul@crapouillou.net>2015-07-28 10:21:31 +0200
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>2015-07-30 23:36:02 +0200
commit6dc5c7ffea3c309e3402e6c1e4cab42b8b44f421 (patch)
tree48e9bd874d3e25e437d88de478f13bcebc2ca3af
parent2d0a5e5cea8986d753fcde79102d475eca9c0275 (diff)
downloadbuildroot-6dc5c7ffea3c309e3402e6c1e4cab42b8b44f421.tar.gz
buildroot-6dc5c7ffea3c309e3402e6c1e4cab42b8b44f421.zip
package/dropbear: Fix symlink only if pointing to the right directory
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>
-rw-r--r--package/dropbear/S50dropbear6
-rw-r--r--package/dropbear/dropbear.service5
2 files changed, 7 insertions, 4 deletions
diff --git a/package/dropbear/S50dropbear b/package/dropbear/S50dropbear
index af50ccf254..8938789509 100644
--- a/package/dropbear/S50dropbear
+++ b/package/dropbear/S50dropbear
@@ -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
diff --git a/package/dropbear/dropbear.service b/package/dropbear/dropbear.service
index 0e2cf548d3..52c77024f5 100644
--- a/package/dropbear/dropbear.service
+++ b/package/dropbear/dropbear.service
@@ -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 \
OpenPOWER on IntegriCloud