* [Buildroot] [PATCH alternative 2] dropbear: add support for custom arguments through config file
@ 2014-01-02 12:34 Thomas De Schampheleire
2014-01-02 13:27 ` Yann E. MORIN
2014-01-02 14:07 ` Thomas Petazzoni
0 siblings, 2 replies; 3+ messages in thread
From: Thomas De Schampheleire @ 2014-01-02 12:34 UTC (permalink / raw)
To: buildroot
The default port 22 used by dropbear for its SSH connections is not always
desired. Dropbear accepts an option '-p' to set the port, but doing this was
not possible from the buildroot-provided init script.
One way to fix this is by adding a custom S50dropbear in a project-specific
rootfs overlay. However, this approach has the big disadvantage that bug
fixes or improvements in the default init script (i.e. in newer buildroot
releases) are not available (unless you manually port these changes each
time you upgrade buildroot).
Another solution is to modify the default init script from a
project-specific post-build script. However, this is fragile because you'd
have to sed some line but this line may change in later buildroot releases.
Yet another solution is to change the default port at build time, by
patching the options.h header file in the dropbear sources. This was
proposed with a patch [1] before, but not accepted.
This patch implements another solution, hinted from the discussion in [1]:
the default init script now sources a config file /etc/default/dropbear, in
which the user can set the variable DROPBEAR_ARGS. This is similar to the
S81named init script in the bind package. The config file would be added to
a project-specific rootfs overlay, a custom skeleton, or created from a
post-build script.
This approach has the advantage of being simple and non-intrusive, without
any code duplication or fragile script modifications.
[1] http://lists.busybox.net/pipermail/buildroot/2013-November/083165.html
Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>
---
package/dropbear/S50dropbear | 10 ++++++++--
1 files changed, 8 insertions(+), 2 deletions(-)
NOTE: this is alternative 2, using one variable for all config knobs.
diff --git a/package/dropbear/S50dropbear b/package/dropbear/S50dropbear
--- a/package/dropbear/S50dropbear
+++ b/package/dropbear/S50dropbear
@@ -3,14 +3,20 @@
# Starts dropbear sshd.
#
+# Allow a few customizations from a config file
+test -r /etc/default/dropbear && . /etc/default/dropbear
+
start() {
- echo -n "Starting dropbear sshd: "
+ DROPBEAR_ARGS="$DROPBEAR_ARGS -R"
+
+ echo -n "Starting dropbear sshd: "
# Make sure dropbear directory exists
if [ ! -d /etc/dropbear ] ; then
mkdir -p /etc/dropbear
fi
umask 077
- start-stop-daemon -S -q -p /var/run/dropbear.pid --exec /usr/sbin/dropbear -- -R
+ start-stop-daemon -S -q -p /var/run/dropbear.pid \
+ --exec /usr/sbin/dropbear -- $DROPBEAR_ARGS
[ $? == 0 ] && echo "OK" || echo "FAIL"
}
stop() {
^ permalink raw reply [flat|nested] 3+ messages in thread* [Buildroot] [PATCH alternative 2] dropbear: add support for custom arguments through config file
2014-01-02 12:34 [Buildroot] [PATCH alternative 2] dropbear: add support for custom arguments through config file Thomas De Schampheleire
@ 2014-01-02 13:27 ` Yann E. MORIN
2014-01-02 14:07 ` Thomas Petazzoni
1 sibling, 0 replies; 3+ messages in thread
From: Yann E. MORIN @ 2014-01-02 13:27 UTC (permalink / raw)
To: buildroot
Thomas, All,
On 2014-01-02 13:34 +0100, Thomas De Schampheleire spake thusly:
> The default port 22 used by dropbear for its SSH connections is not always
> desired. Dropbear accepts an option '-p' to set the port, but doing this was
> not possible from the buildroot-provided init script.
[--SNIP--]
> Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>
Reviewed-by: "Yann E. MORIN" <yann.morin.1998@free.fr>
I prefer this second solution: let's keep it simple.
Regards,
Yann E. MORIN.
> ---
> package/dropbear/S50dropbear | 10 ++++++++--
> 1 files changed, 8 insertions(+), 2 deletions(-)
>
> NOTE: this is alternative 2, using one variable for all config knobs.
>
> diff --git a/package/dropbear/S50dropbear b/package/dropbear/S50dropbear
> --- a/package/dropbear/S50dropbear
> +++ b/package/dropbear/S50dropbear
> @@ -3,14 +3,20 @@
> # Starts dropbear sshd.
> #
>
> +# Allow a few customizations from a config file
> +test -r /etc/default/dropbear && . /etc/default/dropbear
> +
> start() {
> - echo -n "Starting dropbear sshd: "
> + DROPBEAR_ARGS="$DROPBEAR_ARGS -R"
> +
> + echo -n "Starting dropbear sshd: "
> # Make sure dropbear directory exists
> if [ ! -d /etc/dropbear ] ; then
> mkdir -p /etc/dropbear
> fi
> umask 077
> - start-stop-daemon -S -q -p /var/run/dropbear.pid --exec /usr/sbin/dropbear -- -R
> + start-stop-daemon -S -q -p /var/run/dropbear.pid \
> + --exec /usr/sbin/dropbear -- $DROPBEAR_ARGS
> [ $? == 0 ] && echo "OK" || echo "FAIL"
> }
> stop() {
--
.-----------------.--------------------.------------------.--------------------.
| 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 alternative 2] dropbear: add support for custom arguments through config file
2014-01-02 12:34 [Buildroot] [PATCH alternative 2] dropbear: add support for custom arguments through config file Thomas De Schampheleire
2014-01-02 13:27 ` Yann E. MORIN
@ 2014-01-02 14:07 ` Thomas Petazzoni
1 sibling, 0 replies; 3+ messages in thread
From: Thomas Petazzoni @ 2014-01-02 14:07 UTC (permalink / raw)
To: buildroot
Dear Thomas De Schampheleire,
On Thu, 02 Jan 2014 13:34:42 +0100, Thomas De Schampheleire wrote:
> The default port 22 used by dropbear for its SSH connections is not always
> desired. Dropbear accepts an option '-p' to set the port, but doing this was
> not possible from the buildroot-provided init script.
>
> One way to fix this is by adding a custom S50dropbear in a project-specific
> rootfs overlay. However, this approach has the big disadvantage that bug
> fixes or improvements in the default init script (i.e. in newer buildroot
> releases) are not available (unless you manually port these changes each
> time you upgrade buildroot).
>
> Another solution is to modify the default init script from a
> project-specific post-build script. However, this is fragile because you'd
> have to sed some line but this line may change in later buildroot releases.
>
> Yet another solution is to change the default port at build time, by
> patching the options.h header file in the dropbear sources. This was
> proposed with a patch [1] before, but not accepted.
>
> This patch implements another solution, hinted from the discussion in [1]:
> the default init script now sources a config file /etc/default/dropbear, in
> which the user can set the variable DROPBEAR_ARGS. This is similar to the
> S81named init script in the bind package. The config file would be added to
> a project-specific rootfs overlay, a custom skeleton, or created from a
> post-build script.
> This approach has the advantage of being simple and non-intrusive, without
> any code duplication or fragile script modifications.
>
> [1] http://lists.busybox.net/pipermail/buildroot/2013-November/083165.html
>
>
> Signed-off-by: Thomas De Schampheleire <thomas.de.schampheleire@gmail.com>
>
> ---
> package/dropbear/S50dropbear | 10 ++++++++--
> 1 files changed, 8 insertions(+), 2 deletions(-)
Applied, 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:[~2014-01-02 14:07 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-01-02 12:34 [Buildroot] [PATCH alternative 2] dropbear: add support for custom arguments through config file Thomas De Schampheleire
2014-01-02 13:27 ` Yann E. MORIN
2014-01-02 14:07 ` Thomas Petazzoni
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox