summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Crispin2024-11-12 06:49:22 +0000
committerJohn Crispin2024-11-13 06:53:47 +0000
commitb902284290b846423ca30d8f4f69eda6bb2c9ee2 (patch)
tree92c524345b5b39997d7993ef988753712e36e69b
parent4c65359af49b6ccecd98987f842db5eba985f64b (diff)
downloadopenwrt-b902284290b846423ca30d8f4f69eda6bb2c9ee2.tar.gz
base-files: improve default root-passwd script
The script was not exiting cleanly causing it to not be removed from the uci-defaults folder. Signed-off-by: John Crispin <john@phrozen.org>
-rw-r--r--package/base-files/files/etc/uci-defaults/50-root-passwd18
1 files changed, 12 insertions, 6 deletions
diff --git a/package/base-files/files/etc/uci-defaults/50-root-passwd b/package/base-files/files/etc/uci-defaults/50-root-passwd
index 9eddf1559b..f0bb519aec 100644
--- a/package/base-files/files/etc/uci-defaults/50-root-passwd
+++ b/package/base-files/files/etc/uci-defaults/50-root-passwd
@@ -3,10 +3,16 @@
json_init
json_load "$(cat /etc/board.json)"
-json_select credentials
- json_get_vars root_password_hash root_password_hash
- [ -z "$root_password_hash" ] || sed -i "s|^root:[^:]*|root:$root_password_hash|g" /etc/shadow
+if json_is_a credentials object; then
+ json_select credentials
+ json_get_vars root_password_hash root_password_hash
+ if [ -n "$root_password_hash" ]; then
+ sed -i "s|^root:[^:]*|root:$root_password_hash|g" /etc/shadow
+ fi
- json_get_vars root_password_plain root_password_plain
- [ -z "$root_password_plain" ] || { (echo "$root_password_plain"; sleep 1; echo "$root_password_plain") | passwd root }
-json_select ..
+ json_get_vars root_password_plain root_password_plain
+ if [ -n "$root_password_plain" ]; then
+ (echo "$root_password_plain"; sleep 1; echo "$root_password_plain") | passwd root
+ fi
+ json_select ..
+fi