All of lore.kernel.org
 help / color / mirror / Atom feed
* [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory
@ 2015-07-15  9:55 paul at crapouillou.net
  2015-07-18 14:08 ` Yann E. MORIN
  2015-07-26 17:36 ` Thomas Petazzoni
  0 siblings, 2 replies; 3+ messages in thread
From: paul at crapouillou.net @ 2015-07-15  9:55 UTC (permalink / raw)
  To: buildroot

From: Paul Cercueil <paul@crapouillou.net>

This commit ensures that the /etc/dropbear symlink won't be removed if
it points elsewhere than /var/run/dropbear.

Signed-off-by: Paul Cercueil <paul@crapouillou.net>
---
 package/dropbear/S50dropbear      | 4 ++--
 package/dropbear/dropbear.service | 4 ++--
 2 files changed, 4 insertions(+), 4 deletions(-)

diff --git a/package/dropbear/S50dropbear b/package/dropbear/S50dropbear
index af50ccf..d42fb60 100644
--- a/package/dropbear/S50dropbear
+++ b/package/dropbear/S50dropbear
@@ -12,12 +12,12 @@ 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 [ "$(readlink /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 0e2cf54..62ade1f 100644
--- a/package/dropbear/dropbear.service
+++ b/package/dropbear/dropbear.service
@@ -3,13 +3,13 @@ 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 [ "$(readlink /etc/dropbear)" = "/var/run/dropbear" ]; then \
     if rm -f /etc/dropbear; then \
         mkdir -p /etc/dropbear; \
     else \
-- 
2.1.4

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory
  2015-07-15  9:55 [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory paul at crapouillou.net
@ 2015-07-18 14:08 ` Yann E. MORIN
  2015-07-26 17:36 ` Thomas Petazzoni
  1 sibling, 0 replies; 3+ messages in thread
From: Yann E. MORIN @ 2015-07-18 14:08 UTC (permalink / raw)
  To: buildroot

Paul, All,

On 2015-07-15 11:55 +0200, paul at crapouillou.net spake thusly:
> From: Paul Cercueil <paul@crapouillou.net>
> 
> This commit ensures that the /etc/dropbear symlink won't be removed if
> it points elsewhere than /var/run/dropbear.
> 
> Signed-off-by: Paul Cercueil <paul@crapouillou.net>
> ---
>  package/dropbear/S50dropbear      | 4 ++--
>  package/dropbear/dropbear.service | 4 ++--
>  2 files changed, 4 insertions(+), 4 deletions(-)
> 
> diff --git a/package/dropbear/S50dropbear b/package/dropbear/S50dropbear
> index af50ccf..d42fb60 100644
> --- a/package/dropbear/S50dropbear
> +++ b/package/dropbear/S50dropbear
> @@ -12,12 +12,12 @@ 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 [ "$(readlink /etc/dropbear)" = "/var/run/dropbear" ]; then

/etc/dropbear is a relative symlink, so readlink (at least from
coreutils) would return the relative path, not the absolute path.

So, I can't see a way this can work as-is. However, what about this:

    if [    -L /etc/dropbear \
         -a "$(readlink -f /etc/dropbear)" = "/var/run/dropbear" ]
    then
        # trick-trac on .etc.dropbear
    fi

(Ditto the unit file, of course! ;-)

Care to fix and resend, please?

Regards,
Yann E. MORIN.

>  		if rm -f /etc/dropbear; then
>  			mkdir -p /etc/dropbear
>  		else
> diff --git a/package/dropbear/dropbear.service b/package/dropbear/dropbear.service
> index 0e2cf54..62ade1f 100644
> --- a/package/dropbear/dropbear.service
> +++ b/package/dropbear/dropbear.service
> @@ -3,13 +3,13 @@ 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 [ "$(readlink /etc/dropbear)" = "/var/run/dropbear" ]; then \
>      if rm -f /etc/dropbear; then \
>          mkdir -p /etc/dropbear; \
>      else \
> -- 
> 2.1.4
> 
> _______________________________________________
> buildroot mailing list
> buildroot at busybox.net
> http://lists.busybox.net/mailman/listinfo/buildroot

-- 
.-----------------.--------------------.------------------.--------------------.
|  Yann E. MORIN  | Real-Time Embedded | /"\ ASCII RIBBON | Erics' conspiracy: |
| +33 662 376 056 | Software  Designer | \ / CAMPAIGN     |  ___               |
| +33 223 225 172 `------------.-------:  X  AGAINST      |  \e/  There is no  |
| http://ymorin.is-a-geek.org/ | _/*\_ | / \ HTML MAIL    |   v   conspiracy.  |
'------------------------------^-------^------------------^--------------------'

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory
  2015-07-15  9:55 [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory paul at crapouillou.net
  2015-07-18 14:08 ` Yann E. MORIN
@ 2015-07-26 17:36 ` Thomas Petazzoni
  1 sibling, 0 replies; 3+ messages in thread
From: Thomas Petazzoni @ 2015-07-26 17:36 UTC (permalink / raw)
  To: buildroot

Paul,

On Wed, 15 Jul 2015 11:55:03 +0200, paul at crapouillou.net wrote:
> From: Paul Cercueil <paul@crapouillou.net>
> 
> This commit ensures that the /etc/dropbear symlink won't be removed if
> it points elsewhere than /var/run/dropbear.
> 
> Signed-off-by: Paul Cercueil <paul@crapouillou.net>
> ---
>  package/dropbear/S50dropbear      | 4 ++--
>  package/dropbear/dropbear.service | 4 ++--
>  2 files changed, 4 insertions(+), 4 deletions(-)

Following the comments from Yann E. Morin, I've marked your patch as
Changes Requested. Can you respin a new version?

Thanks!

Thomas
-- 
Thomas Petazzoni, CTO, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2015-07-26 17:36 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-07-15  9:55 [Buildroot] [PATCH] package/dropbear: Fix symlink only if pointing to the right directory paul at crapouillou.net
2015-07-18 14:08 ` Yann E. MORIN
2015-07-26 17:36 ` Thomas Petazzoni

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.