V1.2.2 优化硬盘检测代码、Samba 共享逻辑
This commit is contained in:
parent
858f8dd4d3
commit
33636bb38a
|
@ -3,18 +3,16 @@
|
|||
# AutoBuild Module by Hyy2001
|
||||
# AutoBuild_Tools for Openwrt
|
||||
|
||||
Version=V1.2.1-BETA
|
||||
Version=V1.2.2
|
||||
|
||||
AutoBuild_Tools() {
|
||||
while :
|
||||
do
|
||||
clear
|
||||
echo -e "AutoBuild 固件工具箱 ${Version}\n"
|
||||
echo "1.内部空间扩展"
|
||||
echo "2.Samba 共享"
|
||||
echo "3.挂载硬盘"
|
||||
echo "4.查看挂载点"
|
||||
echo "5.安装软件包"
|
||||
echo "1.USB 空间扩展"
|
||||
echo "2.Samba 一键共享"
|
||||
echo "3.软件包安装"
|
||||
echo -e "\nq.退出\n"
|
||||
read -p "请从上方选择一个操作:" Choose
|
||||
case $Choose in
|
||||
|
@ -24,34 +22,26 @@ AutoBuild_Tools() {
|
|||
exit
|
||||
;;
|
||||
1)
|
||||
|
||||
uci set fstab.@global[0].auto_mount='0'
|
||||
uci set fstab.@global[0].auto_swap='0'
|
||||
uci commit fstab
|
||||
AutoExpand_UI
|
||||
;;
|
||||
2)
|
||||
Samba_UI
|
||||
AutoSamba_UI
|
||||
;;
|
||||
3)
|
||||
block mount
|
||||
;;
|
||||
4)
|
||||
clear && mount
|
||||
Enter
|
||||
;;
|
||||
5)
|
||||
Install_UI
|
||||
AutoInstall_UI
|
||||
;;
|
||||
esac
|
||||
done
|
||||
}
|
||||
|
||||
AutoExpand_UI() {
|
||||
uci set fstab.@global[0].auto_mount='0'
|
||||
uci set fstab.@global[0].auto_swap='0'
|
||||
uci commit fstab
|
||||
clear
|
||||
echo -e "Newifi-D2 一键扩展内部空间\n"
|
||||
echo -e "一键 USB 扩展内部空间\n"
|
||||
USB_Check_Core
|
||||
if [[ ! -z "${Check_Disk}" ]];then
|
||||
[[ -n "${Check_Disk}" ]] && {
|
||||
for ((i=1;i<=${Disk_Number};i++));
|
||||
do
|
||||
Disk_info=$(sed -n ${i}p ${Disk_Processed_List})
|
||||
|
@ -59,10 +49,10 @@ AutoExpand_UI() {
|
|||
done
|
||||
echo -e "\nq.返回"
|
||||
echo "r.重新载入列表"
|
||||
else
|
||||
} || {
|
||||
echo "未检测到外接硬盘!" && sleep 2
|
||||
return
|
||||
fi
|
||||
}
|
||||
echo ""
|
||||
read -p "请输入要操作的硬盘编号[1-${Disk_Number}]:" Choose
|
||||
echo ""
|
||||
|
@ -71,22 +61,22 @@ AutoExpand_UI() {
|
|||
return
|
||||
;;
|
||||
r)
|
||||
block mount
|
||||
AutoExpand_UI
|
||||
;;
|
||||
*)
|
||||
if [ ${Choose} -gt 0 ] > /dev/null 2>&1 && [ ${Choose} -le ${Disk_Number} ] > /dev/null 2>&1;then
|
||||
|
||||
[[ "${Choose}" -gt 0 ]] > /dev/null 2>&1 && [[ "${Choose}" -le "${Disk_Number}" ]] > /dev/null 2>&1 && {
|
||||
which mkfs.ext4 > /dev/null 2>&1
|
||||
if [ "$?" -eq 0 ];then
|
||||
[[ $? -eq 0 ]] && {
|
||||
AutoExpand_Core
|
||||
else
|
||||
} || {
|
||||
echo "请先安装 [e2fsprogs] !" && sleep 3
|
||||
fi
|
||||
else
|
||||
}
|
||||
} || {
|
||||
echo "选择错误,请输入正确的选项!"
|
||||
sleep 2 && AutoExpand_UI
|
||||
exit
|
||||
fi
|
||||
}
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
@ -96,44 +86,45 @@ USB_Check_Core() {
|
|||
rm -rf ${AutoExpend_Tmp}/*
|
||||
echo "$(block info)" > ${Block_Info}
|
||||
Check_Disk="$(cat ${Block_Info} | awk -F ':' '/sd/{print $1}')"
|
||||
if [ ! -z "${Check_Disk}" ];then
|
||||
[[ -n "${Check_Disk}" ]] && {
|
||||
echo "${Check_Disk}" > ${Disk_List}
|
||||
Disk_Number=$(sed -n '$=' ${Disk_List})
|
||||
for Disk_Name in $(cat ${Disk_List})
|
||||
do
|
||||
Mounted_on="$(df -h | grep "${Disk_Name}" | awk '{print $6}')"
|
||||
Disk_Available="$(df -m | grep "${Disk_Name}" | awk '{print $4}')"
|
||||
Mounted_Point=$(grep "${Disk_Name}" ${Block_Info} | egrep -o 'MOUNT="/[a-z].+' | awk -F '["]' '/MOUNT/{print $2}')
|
||||
#Mounted_Point=$(grep "${Disk_Name}" ${Block_Info} | egrep -o 'MOUNT=.*' | awk '{print $1}' | sed -r 's/MOUNT="(.*)"/\1/')
|
||||
[[ -z "${Mounted_Point}" ]] && Mounted_Point="$(df -h | grep "${Disk_Name}" | awk '{print $6}' | awk 'NR==1')"
|
||||
Disk_Available="$(df -m | grep "${Disk_Name}" | awk '{print $4}' | awk 'NR==1')"
|
||||
[[ -z "${Disk_Available}" ]] && Disk_Available=0
|
||||
Disk_Format="$(cat ${Block_Info} | grep "${Disk_Name}" | egrep -o 'TYPE="[a-z].+' | awk -F '["]' '/TYPE/{print $2}')"
|
||||
touch ${Disk_Processed_List}
|
||||
if [ ! -z "$Mounted_on" ];then
|
||||
echo "${Disk_Name} ${Mounted_on} ${Disk_Format} ${Disk_Available}MB" >> ${Disk_Processed_List}
|
||||
else
|
||||
[[ -n "${Mounted_Point}" ]] && {
|
||||
echo "${Disk_Name} ${Mounted_Point} ${Disk_Format} ${Disk_Available}MB" >> ${Disk_Processed_List}
|
||||
} || {
|
||||
echo "${Disk_Name} ${Disk_Format}" >> ${Disk_Processed_List}
|
||||
fi
|
||||
}
|
||||
done
|
||||
fi
|
||||
}
|
||||
}
|
||||
|
||||
AutoExpand_Core() {
|
||||
Choosed_Disk="$(sed -n ${Choose}p ${Disk_Processed_List} | awk '{print $1}')"
|
||||
echo "警告: 本次操作将把硬盘: '${Choosed_Disk}' 格式化为 'ext4' 格式,请提前做好数据备份工作!"
|
||||
read -p "是否继续本次操作?[Y/n]:" Choose
|
||||
if [ ${Choose} == Y ] || [ ${Choose} == y ];then
|
||||
sleep 3 && echo ""
|
||||
else
|
||||
[[ "${Choose}" == Y ]] || [[ "${Choose}" == y ]] && sleep 3 && echo "" || {
|
||||
sleep 3
|
||||
echo "用户已取消操作."
|
||||
break
|
||||
fi
|
||||
if [[ "$(mount)" =~ "${Choosed_Disk}" ]] > /dev/null 2>&1 ;then
|
||||
}
|
||||
[[ "$(mount)" =~ "${Choosed_Disk}" ]] > /dev/null 2>&1 && {
|
||||
Choosed_Disk_Mounted="$(mount | grep "${Choosed_Disk}" | awk '{print $3}')"
|
||||
echo "取消挂载: '${Choosed_Disk}' on '${Choosed_Disk_Mounted}' ..."
|
||||
umount -l ${Choosed_Disk_Mounted} > /dev/null 2>&1
|
||||
if [ "$(mount)" =~ "${Choosed_Disk_Mounted}" ] > /dev/null 2>&1 ;then
|
||||
[[ "$(mount)" =~ "${Choosed_Disk_Mounted}" ]] > /dev/null 2>&1 && {
|
||||
echo "取消挂载: '${Choosed_Disk_Mounted}' 失败 !"
|
||||
exit
|
||||
fi
|
||||
fi
|
||||
}
|
||||
}
|
||||
echo "正在格式化硬盘: '${Choosed_Disk}' 为 'ext4' 格式 ..."
|
||||
mkfs.ext4 -F ${Choosed_Disk} > /dev/null 2>&1
|
||||
echo "格式化完成! 挂载硬盘: '${Choosed_Disk}' 到 ' /tmp/extroot' ..."
|
||||
|
@ -159,37 +150,31 @@ AutoExpand_Core() {
|
|||
umount -l /mnt/bak
|
||||
echo -e "操作结束,外接硬盘: '${Choosed_Disk}' 已挂载到 '/'.\n"
|
||||
read -p "挂载完成后需要重启生效,是否立即重启路由器?[Y/n]:" Choose
|
||||
if [ ${Choose} == Y ] || [ ${Choose} == y ];then
|
||||
[[ ${Choose} == Y ]] || [[ ${Choose} == y ]] && {
|
||||
sleep 3 && echo -e "\n正在重启路由器,请耐心等待 ..."
|
||||
sync
|
||||
reboot
|
||||
else
|
||||
} || {
|
||||
echo "用户已取消重启操作."
|
||||
sleep 3
|
||||
break
|
||||
fi
|
||||
}
|
||||
}
|
||||
|
||||
List_Disk() {
|
||||
if [[ ${2} == "/" ]];then
|
||||
_Type="[不可用]"
|
||||
else
|
||||
_Type="[可用]"
|
||||
fi
|
||||
if [[ ! -z ${3} ]];then
|
||||
echo "${i}.${_Type}硬盘: '${1}' 挂载点: '${2}' 格式: '${3}' 可用空间: ${4}"
|
||||
else
|
||||
echo "${i}.硬盘: '${1}' 格式: '${2}' 未挂载"
|
||||
fi
|
||||
[[ -n "${3}" ]] && {
|
||||
echo "${i}. '${1}' 挂载点: '${2}' 格式: '${3}' 可用空间: ${4}"
|
||||
} || echo "${i}. '${1}' 格式: '${2}' 未挂载"
|
||||
}
|
||||
|
||||
Samba_UI() {
|
||||
AutoSamba_UI() {
|
||||
while :
|
||||
do
|
||||
clear
|
||||
echo -e "Samba 工具箱\n"
|
||||
echo "1.删除所有 Samba 挂载点"
|
||||
echo "2.自动共享所有已连接的硬盘"
|
||||
echo "2.自动生成 Samba 共享"
|
||||
echo "3.关闭/开启自动共享"
|
||||
echo -e "\nq.返回\n"
|
||||
read -p "请从上方选择一个操作:" Choose
|
||||
case $Choose in
|
||||
|
@ -199,6 +184,19 @@ Samba_UI() {
|
|||
2)
|
||||
Mount_Samba_Devices
|
||||
;;
|
||||
3)
|
||||
autosamba="$(uci get samba.@samba[0].autoshare)"
|
||||
[[ ${autosamba} == 0 ]] && {
|
||||
uci set samba.@samba[0].autoshare='1'
|
||||
autosamba_mode="开启"
|
||||
} || {
|
||||
uci set samba.@samba[0].autoshare='0'
|
||||
autosamba_mode="关闭"
|
||||
}
|
||||
echo -e "\n已${autosamba_mode} Samba 自动共享!"
|
||||
uci commit samba
|
||||
sleep 3
|
||||
;;
|
||||
q)
|
||||
break
|
||||
;;
|
||||
|
@ -210,31 +208,31 @@ Remove_Samba_Settings() {
|
|||
while :
|
||||
do
|
||||
Samba_config="$(grep "sambashare" /etc/config/samba | wc -l)"
|
||||
[ "${Samba_config}" -eq 0 ] && break
|
||||
[[ "${Samba_config}" -eq 0 ]] && break
|
||||
uci delete samba.@sambashare[0]
|
||||
uci commit
|
||||
done
|
||||
echo -e "\n已删除所有共享挂载点!"
|
||||
echo -e "\n已删除所有 Samba 挂载点!"
|
||||
sleep 2
|
||||
}
|
||||
|
||||
Mount_Samba_Devices() {
|
||||
echo "$(cat /proc/mounts | awk -F ':' '/sd/{print $1}')" > ${Disk_List}
|
||||
Disk_Number=$(sed -n '$=' ${Disk_List})
|
||||
echo "$(cat /proc/mounts | awk -F ':' '/sd/{print $1}')" > ${Samba_Disk_List}
|
||||
Disk_Number=$(sed -n '$=' ${Samba_Disk_List})
|
||||
echo ""
|
||||
for ((i=1;i<=${Disk_Number};i++));
|
||||
do
|
||||
Disk_Name=$(sed -n ${i}p ${Disk_List} | awk '{print $1}')
|
||||
Disk_Mounted_on=$(sed -n ${i}p ${Disk_List} | awk '{print $2}')
|
||||
Samba_Name=${Disk_Mounted_on#*/mnt/}
|
||||
Disk_Name=$(sed -n ${i}p ${Samba_Disk_List} | awk '{print $1}')
|
||||
Disk_Mounted_Point=$(sed -n ${i}p ${Samba_Disk_List} | awk '{print $2}')
|
||||
Samba_Name=${Disk_Mounted_Point#*/mnt/}
|
||||
uci show 2>&1 | grep "sambashare" > ${UCI_Show_List}
|
||||
if [[ ! "$(cat ${UCI_Show_List})" =~ "${Disk_Name}" ]] > /dev/null 2>&1 ;then
|
||||
echo "共享硬盘: '${Disk_Name}' on '${Disk_Mounted_on}' 到 '${Samba_Name}' ..."
|
||||
echo "共享硬盘: '${Disk_Name}' on '${Disk_Mounted_Point}' 到 '${Samba_Name}' ..."
|
||||
echo -e "\nconfig sambashare" >> ${Samba_Config_File}
|
||||
echo -e "\toption auto '1'" >> ${Samba_Config_File}
|
||||
echo -e "\toption name '${Samba_Name}'" >> ${Samba_Config_File}
|
||||
echo -e "\toption device '${Disk_Name}'" >> ${Samba_Config_File}
|
||||
echo -e "\toption path '${Disk_Mounted_on}'" >> ${Samba_Config_File}
|
||||
echo -e "\toption path '${Disk_Mounted_Point}'" >> ${Samba_Config_File}
|
||||
echo -e "\toption read_only 'no'" >> ${Samba_Config_File}
|
||||
echo -e "\toption guest_ok 'yes'" >> ${Samba_Config_File}
|
||||
echo -e "\toption create_mask '0666'" >> ${Samba_Config_File}
|
||||
|
@ -244,17 +242,17 @@ Mount_Samba_Devices() {
|
|||
fi
|
||||
done
|
||||
/etc/init.d/samba restart
|
||||
sleep 2
|
||||
sleep 3
|
||||
}
|
||||
|
||||
Install_UI() {
|
||||
AutoInstall_UI() {
|
||||
while :
|
||||
do
|
||||
clear
|
||||
echo -e "安装软件包\n"
|
||||
echo "1.更新软件包列表"
|
||||
Install_UI_Mod 2 block-mount
|
||||
Install_UI_Mod 3 e2fsprogs
|
||||
AutoInstall_UI_Mod 2 block-mount
|
||||
AutoInstall_UI_Mod 3 e2fsprogs
|
||||
echo "x.自定义软件包名"
|
||||
echo -e "\nq.返回\n"
|
||||
read -p "请从上方选择一个操作:" Choose
|
||||
|
@ -284,21 +282,17 @@ while :
|
|||
done
|
||||
}
|
||||
|
||||
Install_UI_Mod() {
|
||||
if [[ "$(opkg list | awk '{print $1}')" =~ "${2}" ]] > /dev/null 2>&1 ;then
|
||||
AutoInstall_UI_Mod() {
|
||||
[[ "$(opkg list | awk '{print $1}')" =~ "${2}" ]] > /dev/null 2>&1 && {
|
||||
echo "${1}.安装 [${2}] [已安装]"
|
||||
else
|
||||
echo "${1}.未安装 [${2}] [已安装]"
|
||||
fi
|
||||
} || echo "${1}.未安装 [${2}] [已安装]"
|
||||
}
|
||||
|
||||
Install_opkg_mod() {
|
||||
opkg install ${*}
|
||||
if [[ "$(opkg list | awk '{print $1}')" =~ "${1}" ]] > /dev/null 2>&1 ;then
|
||||
[[ "$(opkg list | awk '{print $1}')" =~ "${1}" ]] > /dev/null 2>&1 && {
|
||||
echo -e "\n${1} 安装成功!"
|
||||
else
|
||||
echo -e "\n${1} 安装失败!"
|
||||
fi
|
||||
} || echo -e "\n${1} 安装失败!"
|
||||
sleep 2
|
||||
}
|
||||
|
||||
|
@ -310,15 +304,13 @@ AutoExpend_Tmp="/tmp/AutoExpand"
|
|||
Disk_List="${AutoExpend_Tmp}/Disk_List"
|
||||
Block_Info="${AutoExpend_Tmp}/Block_Info"
|
||||
Disk_Processed_List="${AutoExpend_Tmp}/Disk_Processed_List"
|
||||
[ ! -d ${AutoExpend_Tmp} ] && mkdir -p ${AutoExpend_Tmp}
|
||||
[ ! -d "${AutoExpend_Tmp}" ] && mkdir -p ${AutoExpend_Tmp}
|
||||
Samba_Config_File="/etc/config/samba"
|
||||
Samba_Tmp="/tmp/AutoSamba"
|
||||
Disk_List="${Samba_Tmp}/Disk_List"
|
||||
Samba_Disk_List="${Samba_Tmp}/Disk_List"
|
||||
UCI_Show_List="${Samba_Tmp}/UCI_List"
|
||||
[ ! -d ${Samba_Tmp} ] && mkdir -p ${Samba_Tmp}
|
||||
[ ! -d "${Samba_Tmp}" ] && mkdir -p "${Samba_Tmp}"
|
||||
which block > /dev/null 2>&1
|
||||
if [ "$?" -eq 0 ];then
|
||||
AutoBuild_Tools
|
||||
else
|
||||
[[ $? -eq 0 ]] && AutoBuild_Tools || {
|
||||
echo -e "\nAutoBuild_Tools 不适用于此固件,请先安装 [block-mount] !"
|
||||
fi
|
||||
}
|
Loading…
Reference in New Issue