mirror of
https://github.com/RROrg/rr.git
synced 2025-06-21 05:51:05 +08:00
add "Force enable telnet of DSM system"
This commit is contained in:
parent
01b4595902
commit
33a1b6a8f0
@ -1069,6 +1069,7 @@ function advancedMenu() {
|
|||||||
echo "a \"$(TEXT "Allow downgrade installation")\"" >>"${TMP_PATH}/menu"
|
echo "a \"$(TEXT "Allow downgrade installation")\"" >>"${TMP_PATH}/menu"
|
||||||
echo "f \"$(TEXT "Format disk(s) # Without loader disk")\"" >>"${TMP_PATH}/menu"
|
echo "f \"$(TEXT "Format disk(s) # Without loader disk")\"" >>"${TMP_PATH}/menu"
|
||||||
echo "x \"$(TEXT "Reset DSM system password")\"" >>"${TMP_PATH}/menu"
|
echo "x \"$(TEXT "Reset DSM system password")\"" >>"${TMP_PATH}/menu"
|
||||||
|
echo "z \"$(TEXT "Force enable telnet of DSM system")\"" >>"${TMP_PATH}/menu"
|
||||||
echo "p \"$(TEXT "Save modifications of '/opt/rr'")\"" >>"${TMP_PATH}/menu"
|
echo "p \"$(TEXT "Save modifications of '/opt/rr'")\"" >>"${TMP_PATH}/menu"
|
||||||
if [ -n "${MODEL}" -a "true" = "$(readModelKey "${MODEL}" "dt")" ]; then
|
if [ -n "${MODEL}" -a "true" = "$(readModelKey "${MODEL}" "dt")" ]; then
|
||||||
echo "d \"$(TEXT "Custom dts file # Need rebuild")\"" >>"${TMP_PATH}/menu"
|
echo "d \"$(TEXT "Custom dts file # Need rebuild")\"" >>"${TMP_PATH}/menu"
|
||||||
@ -1404,11 +1405,14 @@ function advancedMenu() {
|
|||||||
for I in $(ls /dev/sd*1 2>/dev/null | grep -v "${LOADER_DISK_PART1}"); do
|
for I in $(ls /dev/sd*1 2>/dev/null | grep -v "${LOADER_DISK_PART1}"); do
|
||||||
mount ${I} "${TMP_PATH}/sdX1"
|
mount ${I} "${TMP_PATH}/sdX1"
|
||||||
if [ -f "${TMP_PATH}/sdX1/etc/shadow" ]; then
|
if [ -f "${TMP_PATH}/sdX1/etc/shadow" ]; then
|
||||||
for U in $(cat "${TMP_PATH}/sdX1/etc/shadow" | awk -F ':' '{if ($2 != "*" && $2 != "!!") {print $1;}}'); do
|
while read L; do
|
||||||
|
U=$(echo "${L}" | awk -F ':' '{if ($2 != "*" && $2 != "!!") print $1;}')
|
||||||
|
[ -z "${U}" ] && continue
|
||||||
|
E=$(echo "${L}" | awk -F ':' '{if ($8 == "1") print "disabled"; else print " ";}')
|
||||||
grep -q "status=on" "${TMP_PATH}/sdX1/usr/syno/etc/packages/SecureSignIn/preference/${U}/method.config" 2>/dev/null
|
grep -q "status=on" "${TMP_PATH}/sdX1/usr/syno/etc/packages/SecureSignIn/preference/${U}/method.config" 2>/dev/null
|
||||||
[ $? -eq 0 ] && SS="SecureSignIn" || SS=" "
|
[ $? -eq 0 ] && S="SecureSignIn" || S=" "
|
||||||
printf "\"%-36s %-16s\"\n" "${U}" "${SS}" >>"${TMP_PATH}/menu"
|
printf "\"%-36s %-10s %-14s\"\n" "${U}" "${E}" "${S}" >>"${TMP_PATH}/menu"
|
||||||
done
|
done < <(cat "${TMP_PATH}/sdX1/etc/shadow")
|
||||||
fi
|
fi
|
||||||
umount "${I}"
|
umount "${I}"
|
||||||
[ -f "${TMP_PATH}/menu" ] && break
|
[ -f "${TMP_PATH}/menu" ] && break
|
||||||
@ -1441,7 +1445,10 @@ function advancedMenu() {
|
|||||||
for I in $(ls /dev/sd*1 2>/dev/null | grep -v "${LOADER_DISK_PART1}"); do
|
for I in $(ls /dev/sd*1 2>/dev/null | grep -v "${LOADER_DISK_PART1}"); do
|
||||||
mount "${I}" "${TMP_PATH}/sdX1"
|
mount "${I}" "${TMP_PATH}/sdX1"
|
||||||
OLDPASSWD="$(cat "${TMP_PATH}/sdX1/etc/shadow" | grep "^${USER}:" | awk -F ':' '{print $2}')"
|
OLDPASSWD="$(cat "${TMP_PATH}/sdX1/etc/shadow" | grep "^${USER}:" | awk -F ':' '{print $2}')"
|
||||||
[ -n "${NEWPASSWD}" -a -n "${OLDPASSWD}" ] && sed -i "s|${OLDPASSWD}|${NEWPASSWD}|g" "${TMP_PATH}/sdX1/etc/shadow"
|
if [ -n "${NEWPASSWD}" -a -n "${OLDPASSWD}" ]; then
|
||||||
|
sed -i "s|${OLDPASSWD}|${NEWPASSWD}|g" "${TMP_PATH}/sdX1/etc/shadow"
|
||||||
|
sed -i "/^${USER}:/ s/\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\):\([^:]*\)/\1:\2:\3:\4:\5:\6:\7::\9/" "${TMP_PATH}/sdX1/etc/shadow"
|
||||||
|
fi
|
||||||
sed -i "s|status=on|status=off|g" "${TMP_PATH}/sdX1/usr/syno/etc/packages/SecureSignIn/preference/${USER}/method.config" 2>/dev/null
|
sed -i "s|status=on|status=off|g" "${TMP_PATH}/sdX1/usr/syno/etc/packages/SecureSignIn/preference/${USER}/method.config" 2>/dev/null
|
||||||
sync
|
sync
|
||||||
umount "${I}"
|
umount "${I}"
|
||||||
@ -1452,6 +1459,26 @@ function advancedMenu() {
|
|||||||
DIALOG --title "$(TEXT "Advanced")" \
|
DIALOG --title "$(TEXT "Advanced")" \
|
||||||
--msgbox "$(TEXT "Password reset completed.")" 0 0
|
--msgbox "$(TEXT "Password reset completed.")" 0 0
|
||||||
;;
|
;;
|
||||||
|
z)
|
||||||
|
DIALOG --title "$(TEXT "Advanced")" \
|
||||||
|
--yesno "$(TEXT "Please insert all disks before continuing.\n")" 0 0
|
||||||
|
[ $? -ne 0 ] && return
|
||||||
|
(
|
||||||
|
mkdir -p "${TMP_PATH}/sdX1"
|
||||||
|
for I in $(ls /dev/sd*1 2>/dev/null | grep -v "${LOADER_DISK_PART1}"); do
|
||||||
|
mount "${I}" "${TMP_PATH}/sdX1"
|
||||||
|
echo '#telnet stream tcp nowait root /usr/bin/telnetd telnetd' >"${TMP_PATH}/sdX1/etc/inetd.conf"
|
||||||
|
echo 'telnet stream tcp6 nowait root /usr/bin/telnetd telnetd -h' >>"${TMP_PATH}/sdX1/etc/inetd.conf"
|
||||||
|
echo 'telnet stream tcp nowait root /usr/bin/telnetd telnetd -h' >>"${TMP_PATH}/sdX1/etc/inetd.conf"
|
||||||
|
sync
|
||||||
|
umount "${I}"
|
||||||
|
done
|
||||||
|
rm -rf "${TMP_PATH}/sdX1"
|
||||||
|
) 2>&1 | DIALOG --title "$(TEXT "Advanced")" \
|
||||||
|
--progressbox "$(TEXT "Enabling ...")" 20 100
|
||||||
|
DIALOG --title "$(TEXT "Advanced")" \
|
||||||
|
--msgbox "$(TEXT "Telnet is enabled.")" 0 0
|
||||||
|
;;
|
||||||
p)
|
p)
|
||||||
DIALOG --title "$(TEXT "Advanced")" \
|
DIALOG --title "$(TEXT "Advanced")" \
|
||||||
--yesno "$(TEXT "Warning:\nDo not terminate midway, otherwise it may cause damage to the RR. Do you want to continue?")" 0 0
|
--yesno "$(TEXT "Warning:\nDo not terminate midway, otherwise it may cause damage to the RR. Do you want to continue?")" 0 0
|
||||||
@ -1585,7 +1612,7 @@ function advancedMenu() {
|
|||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
|
|
||||||
v)
|
v)
|
||||||
if [ -d "${PART1_PATH}/logs" ]; then
|
if [ -d "${PART1_PATH}/logs" ]; then
|
||||||
rm -f "${TMP_PATH}/logs.tar.gz"
|
rm -f "${TMP_PATH}/logs.tar.gz"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user