mounter improvements, old scripts removed
now checks fstab for info, also one less android prompt
This commit is contained in:
parent
a2e767e4f4
commit
b04d4c9ac8
3 changed files with 11 additions and 92 deletions
|
@ -1,67 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Gives a dmenu prompt to mount unmounted drives and Android phones. If
|
|
||||||
# they're in /etc/fstab, they'll be mounted automatically. Otherwise, you'll
|
|
||||||
# be prompted to give a mountpoint from already existsing directories. If you
|
|
||||||
# input a novel directory, it will prompt you to create that directory.
|
|
||||||
|
|
||||||
getmount() { \
|
|
||||||
[ -z "$chosen" ] && exit 1
|
|
||||||
# shellcheck disable=SC2086
|
|
||||||
mp="$(find $1 2>/dev/null | dmenu -i -p "Type in mount point.")" || exit 1
|
|
||||||
test -z "$mp" && exit 1
|
|
||||||
if [ ! -d "$mp" ]; then
|
|
||||||
mkdiryn=$(printf "No\\nYes" | dmenu -i -p "$mp does not exist. Create it?") || exit 1
|
|
||||||
[ "$mkdiryn" = "Yes" ] && (mkdir -p "$mp" || sudo -A mkdir -p "$mp")
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
mountusb() { \
|
|
||||||
chosen="$(echo "$usbdrives" | dmenu -i -p "Mount which drive?")" || exit 1
|
|
||||||
chosen="$(echo "$chosen" | awk '{print $1}')"
|
|
||||||
sudo -A mount "$chosen" 2>/dev/null && notify-send "💻 USB mounting" "$chosen mounted." && exit 0
|
|
||||||
alreadymounted=$(lsblk -nrpo "name,type,mountpoint" | awk '$3!~/\/boot|\/home$|SWAP/&&length($3)>1{printf "-not ( -path *%s -prune ) ",$3}')
|
|
||||||
getmount "/mnt /media /mount /home -maxdepth 5 -type d $alreadymounted"
|
|
||||||
partitiontype="$(lsblk -no "fstype" "$chosen")"
|
|
||||||
case "$partitiontype" in
|
|
||||||
"vfat") sudo -A mount -t vfat "$chosen" "$mp" -o rw,umask=0000;;
|
|
||||||
"exfat") sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)";;
|
|
||||||
*) sudo -A mount "$chosen" "$mp"; user="$(whoami)"; ug="$(groups | awk '{print $1}')"; sudo -A chown "$user":"$ug" "$mp";;
|
|
||||||
esac && notify-send "💻 USB mounting" "$chosen mounted to $mp." ||
|
|
||||||
notify-send "💻 Drive failed to mount." "Probably a permissions issue or drive is already mounted."
|
|
||||||
}
|
|
||||||
|
|
||||||
mountandroid() { \
|
|
||||||
chosen="$(echo "$anddrives" | dmenu -i -p "Which Android device?")" || exit 1
|
|
||||||
chosen="$(echo "$chosen" | cut -d : -f 1)"
|
|
||||||
getmount "$HOME -maxdepth 3 -type d"
|
|
||||||
echo "OK" | dmenu -i -p "Tap Allow on your phone if it asks for permission and then press enter" || exit 1
|
|
||||||
simple-mtpfs --device "$chosen" "$mp" &&
|
|
||||||
notify-send "🤖 Android Mounting" "Android device mounted to $mp." ||
|
|
||||||
notify-send "🤖 Android failed mounting." "Probably a permissions issue or phone is already mounted."
|
|
||||||
}
|
|
||||||
|
|
||||||
asktype() { \
|
|
||||||
choice="$(printf "USB\\nAndroid" | dmenu -i -p "Mount a USB drive or Android device?")" || exit 1
|
|
||||||
case $choice in
|
|
||||||
USB) mountusb ;;
|
|
||||||
Android) mountandroid ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
anddrives=$(simple-mtpfs -l 2>/dev/null)
|
|
||||||
usbdrives="$(lsblk -rpo "name,type,size,label,mountpoint,fstype" | grep -v crypto_LUKS | grep 'part\|rom' | sed 's/ /:/g' | awk -F':' '$5==""{printf "%s (%s) %s\n",$1,$3,$4}')"
|
|
||||||
|
|
||||||
if [ -z "$usbdrives" ]; then
|
|
||||||
[ -z "$anddrives" ] && echo "No USB drive or Android device detected" && exit
|
|
||||||
echo "Android device(s) detected."
|
|
||||||
mountandroid
|
|
||||||
else
|
|
||||||
if [ -z "$anddrives" ]; then
|
|
||||||
echo "USB drive(s) detected."
|
|
||||||
mountusb
|
|
||||||
else
|
|
||||||
echo "Mountable USB drive(s) and Android device(s) detected."
|
|
||||||
asktype
|
|
||||||
fi
|
|
||||||
fi
|
|
|
@ -1,21 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# A dmenu prompt to unmount drives.
|
|
||||||
# Provides you with mounted partitions, select one to unmount.
|
|
||||||
# Drives mounted at /, /boot and /home will not be options to unmount.
|
|
||||||
|
|
||||||
drives="$(lsblk -nrpo "name,type,size,mountpoint,label" | awk -F':' '{gsub(/ /,":")}$4!~/\/boot|\/efi|\/home$|SWAP/&&length($4)>1{printf "%s (%s) %s\n",$4,$3,$5}'; awk '/simple-mtpfs/ { print "📱", $2; }' /etc/mtab)"
|
|
||||||
|
|
||||||
chosen="$(echo "$drives" | dmenu -i -p "Unmount which drive?")" || exit 1
|
|
||||||
|
|
||||||
case "$chosen" in
|
|
||||||
📱*)
|
|
||||||
chosen="${chosen#📱 }"
|
|
||||||
sudo -A umount -l "$chosen"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
chosen="${chosen% (*}"
|
|
||||||
sudo -A umount -l "$chosen"
|
|
||||||
;;
|
|
||||||
esac && notify-send "🖥️ Drive unmounted." "$chosen successfully unmounted." ||
|
|
||||||
notify-send "🖥️ Drive failed to unmount." "Possibly a permissions or I/O issue."
|
|
|
@ -4,7 +4,7 @@
|
||||||
# replace the older `dmenumount` which had extra steps and couldn't handle
|
# replace the older `dmenumount` which had extra steps and couldn't handle
|
||||||
# encrypted drives.
|
# encrypted drives.
|
||||||
# TODO: Remove already mounted Android phones from prompt.
|
# TODO: Remove already mounted Android phones from prompt.
|
||||||
# TODO: Try mount first for drives if in fstab to avoid directory prompt?
|
# TODO: Try decrypt for drives in crtypttab
|
||||||
# TODO: Add some support for connecting iPhones (although they are annoying).
|
# TODO: Add some support for connecting iPhones (although they are annoying).
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
@ -54,11 +54,18 @@ getmount(){
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
attemptmount(){
|
||||||
|
# Attempt to mount without a mountpoint, to see if drive is in fstab.
|
||||||
|
sudo -A mount "$chosen" || return 1
|
||||||
|
notify-send "💾Drive Mounted." "$chosen mounted."
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
case "$chosen" in
|
case "$chosen" in
|
||||||
💾*)
|
💾*)
|
||||||
chosen="${chosen%% *}"
|
chosen="${chosen%% *}"
|
||||||
chosen="${chosen:1}" # This is a bashism.
|
chosen="${chosen:1}" # This is a bashism.
|
||||||
getmount
|
attemptmount || getmount
|
||||||
sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
||||||
notify-send "💾Drive Mounted." "$chosen mounted to $mp."
|
notify-send "💾Drive Mounted." "$chosen mounted to $mp."
|
||||||
;;
|
;;
|
||||||
|
@ -77,14 +84,14 @@ case "$chosen" in
|
||||||
# Check if now decrypted.
|
# Check if now decrypted.
|
||||||
test -b "/dev/mapper/usb$num"
|
test -b "/dev/mapper/usb$num"
|
||||||
|
|
||||||
getmount
|
attemptmount || getmount
|
||||||
sudo -A mount "/dev/mapper/usb$num" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
sudo -A mount "/dev/mapper/usb$num" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
||||||
notify-send "🔓Decrypted drive Mounted." "$chosen decrypted and mounted to $mp."
|
notify-send "🔓Decrypted drive Mounted." "$chosen decrypted and mounted to $mp."
|
||||||
;;
|
;;
|
||||||
|
|
||||||
📱*)
|
📱*)
|
||||||
|
notify-send "❗Note" "Remember to allow file access on your phone now."
|
||||||
getmount
|
getmount
|
||||||
echo "OK" | dmenu -i -p "Tap Allow on your phone if it asks for permission and then press enter"
|
|
||||||
chosen="${chosen%%:*}"
|
chosen="${chosen%%:*}"
|
||||||
chosen="${chosen:1}" # This is a bashism.
|
chosen="${chosen:1}" # This is a bashism.
|
||||||
sudo -A simple-mtpfs -o allow_other --device "$chosen" "$mp"
|
sudo -A simple-mtpfs -o allow_other --device "$chosen" "$mp"
|
||||||
|
|
Loading…
Reference in a new issue