ar71xx: fix AR934X clock frequency calculation
[openwrt.git] / package / busybox / files / telnet
index f294c55..334523e 100755 (executable)
@@ -1,5 +1,6 @@
 #!/bin/sh /etc/rc.common
 # Copyright (C) 2006-2011 OpenWrt.org
+
 START=50
 
 has_root_pwd() {
@@ -10,9 +11,16 @@ has_root_pwd() {
        test -n "${pwd#!}"
 }
 
+get_root_home() {
+       local homedir=$([ -f "$1" ] && cat "$1")
+       homedir="${homedir#*:*:0:0:*:}"
+
+       echo "${homedir%%:*}"
+}
+
 has_ssh_pubkey() {
        ( /etc/init.d/dropbear enabled 2> /dev/null && grep -qs "^ssh-" /etc/dropbear/authorized_keys ) || \
-       ( /etc/init.d/sshd enabled 2> /dev/null && grep -qs "^ssh-" /root/.ssh/authorized_keys )
+       ( /etc/init.d/sshd enabled 2> /dev/null && grep -qs "^ssh-" "$(get_root_home /etc/passwd)"/.ssh/authorized_keys )
 }
 
 start() {
@@ -20,11 +28,10 @@ start() {
             ! has_root_pwd /etc/passwd && ! has_root_pwd /etc/shadow ) || \
           ( ! /etc/init.d/dropbear enabled 2> /dev/null && ! /etc/init.d/sshd enabled 2> /dev/null );
        then
-               telnetd -l /bin/login.sh
+               service_start /usr/sbin/telnetd -l /bin/login.sh
        fi
 }
 
 stop() {
-       killall telnetd 2>/dev/null
+       service_stop /usr/sbin/telnetd
 }
-
This page took 0.023459 seconds and 4 git commands to generate.