fix colons in fields

This commit is contained in:
Rasmus Steinke 2015-08-13 19:44:57 +02:00
parent a6dec27994
commit 54bead78eb

View File

@ -68,9 +68,9 @@ doClip () {
# main Menu # main Menu
mainMenu () { mainMenu () {
HELP="<span color='$help_color'>${autotype}: Autotype | ${type_user}: Type User | ${type_pass}: Type Password HELP="<span color='$help_color'>${autotype}: Autotype, ${type_user}: Type User, ${type_pass}: Type Password, ${open_url}: Open URL
${open_url}: Open URL | ${copy_name}: Copy Username | ${copy_pass}: Copy Password | ${show}: Show Entry</span>" ${copy_name}: Copy Username, ${copy_pass}: Copy Password, ${copy_url}: Copy URL, ${show}: Show Entry</span>"
selected_password="$(echo -e "[ Add Entry ]>\n[ Manage Database ]>\n---\n$(list_passwords 2>/dev/null)" | _rofi -mesg "${HELP}" -dmenu -kb-custom-1 "${autotype}" -kb-custom-2 "${type_user}" -kb-custom-3 "${type_pass}" -kb-custom-4 "${open_url}" -kb-custom-5 "${copy_name}" -kb-custom-6 "${copy_pass}" -kb-custom-7 "${show}" -dmenu -select "$entry" -p "rofi-pass > ")" selected_password="$(echo -e "[ Add Entry ]>\n[ Manage Database ]>\n---\n$(list_passwords 2>/dev/null)" | _rofi -mesg "${HELP}" -dmenu -kb-custom-1 "${autotype}" -kb-custom-2 "${type_user}" -kb-custom-3 "${type_pass}" -kb-custom-4 "${open_url}" -kb-custom-5 "${copy_name}" -kb-custom-6 "${copy_pass}" -kb-custom-7 "${show}" -kb-custom-8 "${copy_url}" -dmenu -select "$entry" -p "rofi-pass > ")"
rofi_exit=$? rofi_exit=$?
if [[ -n $selected_password ]]; then if [[ -n $selected_password ]]; then
@ -78,7 +78,7 @@ ${open_url}: Open URL | ${copy_name}: Copy Username | ${copy_pass}: Copy Passwor
echo "$selected_password" > "$HOME/.config/rofi-pass/last_used" echo "$selected_password" > "$HOME/.config/rofi-pass/last_used"
fi fi
if [[ "${rofi_exit}" -eq 13 ]]; then $BROWSER "$(pass "$selected_password" | grep "URL: " | awk -F 'URL: ' '{ print $2 }')"; exit; if [[ "${rofi_exit}" -eq 13 ]]; then $BROWSER "$(pass "$selected_password" | grep "${URL_field}: " | awk '{sub(/:/,"")}{print $2}1' | head -1)"; exit;
elif [[ "${rofi_exit}" -eq 1 ]]; then exit ${rofi_exit}; elif [[ "${rofi_exit}" -eq 1 ]]; then exit ${rofi_exit};
elif [[ "${rofi_exit}" -eq 10 || "${rofi-exit}" -eq 0 ]]; then true elif [[ "${rofi_exit}" -eq 10 || "${rofi-exit}" -eq 0 ]]; then true
fi fi
@ -90,7 +90,7 @@ ${open_url}: Open URL | ${copy_name}: Copy Username | ${copy_pass}: Copy Passwor
while read LINE; do while read LINE; do
_id=$(echo "${LINE}" | awk -F':[[:space:]]*' '{print $1}') _id=$(echo "${LINE}" | awk -F':[[:space:]]*' '{print $1}')
_val=$(echo "${LINE}" | awk -F':[[:space:]]*' '{print $2}') _val=$(echo "${LINE}" | awk '{sub(/:/,"")}{print $2}1' | head -1)
stuff["${_id}"]=${_val} stuff["${_id}"]=${_val}
done < <(pass "${selected_password}" | tail -n+2 | grep ': ') done < <(pass "${selected_password}" | tail -n+2 | grep ': ')
stuff["pass"]=${password} stuff["pass"]=${password}
@ -104,6 +104,9 @@ ${open_url}: Open URL | ${copy_name}: Copy Username | ${copy_pass}: Copy Passwor
elif [[ $rofi_exit -eq 14 ]]; then elif [[ $rofi_exit -eq 14 ]]; then
echo -n "${stuff[${USERNAME_field}]}" | doClip echo -n "${stuff[${USERNAME_field}]}" | doClip
exit exit
elif [[ $rofi_exit -eq 17 ]]; then
echo -n "${stuff[${URL_field}]}" | doClip
exit
elif [[ $rofi_exit -eq 16 ]]; then elif [[ $rofi_exit -eq 16 ]]; then
showEntry "${selected_password}" showEntry "${selected_password}"
elif [[ $rofi_exit -eq 15 ]]; then elif [[ $rofi_exit -eq 15 ]]; then
@ -111,7 +114,7 @@ ${open_url}: Open URL | ${copy_name}: Copy Username | ${copy_pass}: Copy Passwor
notify-send "rofi-pass" "Copied Password\nClearing in 45 seconds" notify-send "rofi-pass" "Copied Password\nClearing in 45 seconds"
$(sleep 45; echo -n "" | xclip; echo "" | xclip -selection clipboard | notify-send "rofi-pass" "Clipboard cleared") & $(sleep 45; echo -n "" | xclip; echo "" | xclip -selection clipboard | notify-send "rofi-pass" "Clipboard cleared") &
exit exit
elif [[ $rofi_exit -eq 17 || $rofi_exit -eq 18 || $rofi_exit -eq 19 ]]; then elif [[ $rofi_exit -eq 18 || $rofi_exit -eq 19 ]]; then
mainMenu mainMenu
fi fi
if [[ "$selected_password" == "[ Add Entry ]>" ]]; then if [[ "$selected_password" == "[ Add Entry ]>" ]]; then
@ -265,9 +268,9 @@ insertPass () {
fi fi
group=$(find -type d -not -iwholename '*.git*' -printf '%d\t%P\n' | sort -r -nk1 | cut -f2- | _rofi -dmenu -p "Choose Group > ") group=$(find -type d -not -iwholename '*.git*' -printf '%d\t%P\n' | sort -r -nk1 | cut -f2- | _rofi -dmenu -p "Choose Group > ")
if [[ -n "$root" ]]; then if [[ -n "$root" ]]; then
pass insert -m -f "${root}/${group}/${name}" < <(echo -e "${pass}\nUserName: ${user}\n---\nURL: ${domain}") pass insert -m -f "${root}/${group}/${name}" < <(echo -e "${pass}\nUserName: ${user}\n---\n${URL_field}: ${domain}")
else else
pass insert -m -f "${group}/${name}" < <(echo -e "${pass}\nUserName: ${user}\n---\nURL: ${domain}") pass insert -m -f "${group}/${name}" < <(echo -e "${pass}\nUserName: ${user}\n---\n${URL_field}: ${domain}")
fi fi
elif [[ $menu == "1 Name"* ]]; then elif [[ $menu == "1 Name"* ]]; then
name=$(echo "" | _rofi -dmenu -p "Enter Name > ") name=$(echo "" | _rofi -dmenu -p "Enter Name > ")