Fix more backslash issues.

The Software should now work correctly with any backslashed input,
output, fieldnames and values.
This commit is contained in:
Dominik Hannen 2016-05-25 00:03:11 +02:00
parent ff62ec6ca1
commit 011fe2993b

View File

@ -149,7 +149,7 @@ generatePass () {
# main Menu # main Menu
mainMenu () { mainMenu () {
if [[ $1 == "--bmarks" ]]; then if [[ $1 == "--bmarks" ]]; then
selected_password="$(echo -e "$(list_passwords 2>/dev/null)" \ selected_password="$(list_passwords 2>/dev/null \
| _rofi -mesg "Bookmarks Mode. ${switch} to switch" \ | _rofi -mesg "Bookmarks Mode. ${switch} to switch" \
-dmenu \ -dmenu \
-kb-custom-1 "Alt+x" \ -kb-custom-1 "Alt+x" \
@ -167,12 +167,12 @@ mainMenu () {
fi fi
else else
unset selected_password unset selected_password
help_text=$(echo -e "Enter: Autotype - ${action_menu}: Actions - ${show}: View\n${type_menu}: Type Field - ${copy_menu}: Copy Field - ${help}: Help" | column -s '-' -t) help_text=$({ echo -e "Enter: Autotype - ${action_menu}: Actions - ${show}: View"; echo "${type_menu}: Type Field - ${copy_menu}: Copy Field - ${help}: Help";} | column -s '-' -t)
line1=$(echo "${help_text}" | head -1) line1=$(echo "${help_text}" | head -1)
line3=$(echo "${help_text}" | tail -1) line3=$(echo "${help_text}" | tail -1)
HELP="<span color='$help_color'>${line1} HELP="<span color='$help_color'>${line1}
${line3}</span>" ${line3}</span>"
selected_password="$(echo -e "[ Add Entry ]>\n---\n$(list_passwords 2>/dev/null)" \ selected_password="$({ echo -e "[ Add Entry ]>\n---"; list_passwords 2>/dev/null;} \
| _rofi -mesg "${HELP}" \ | _rofi -mesg "${HELP}" \
-dmenu -kb-custom-1 "${autotype}" \ -dmenu -kb-custom-1 "${autotype}" \
-kb-custom-2 "${type_user}" \ -kb-custom-2 "${type_user}" \
@ -202,8 +202,8 @@ ${line3}</span>"
password=$(echo "${password_temp}" | head -1) password=$(echo "${password_temp}" | head -1)
declare -A stuff declare -A stuff
while read -r LINE; do while read -r LINE; do
_id=$(echo -e "${LINE}" | gawk -F ':[[:space:]]*' '{print $1}') _id=$(echo "${LINE}" | gawk -F ':[[:space:]]*' '{print $1}')
_val=$(echo -e "${LINE}" | gawk '{sub(/:/,"")}{for (i=2; i<NF; i++) printf $i " "; print $NF}') _val=$(echo "${LINE}" | gawk '{sub(/:/,"")}{for (i=2; i<NF; i++) printf $i " "; print $NF}')
stuff["${_id}"]=${_val} stuff["${_id}"]=${_val}
done < <(PASSWORD_STORE_DIR="${root}" pass "${selected_password}" | tail -n+2 | grep -P '(: |:\t)' ) done < <(PASSWORD_STORE_DIR="${root}" pass "${selected_password}" | tail -n+2 | grep -P '(: |:\t)' )
stuff["pass"]=${password} stuff["pass"]=${password}
@ -259,7 +259,7 @@ else unset helptext; mainMenu; fi
typeMenu () { typeMenu () {
checkIfPass checkIfPass
typefield=$(echo -e "< Return\n---\npassword\n$(pass "${selected_password}" | grep -P ':[\t ]' | gawk -F ':' '{ print $1 }')" | _rofi -dmenu -p "Choose Field to type > ") typefield=$({ echo -e "< Return\n---\npassword"; pass "${selected_password}" | grep -P ':[\t ]' | gawk -F ':' '{ print $1 }';} | _rofi -dmenu -p "Choose Field to type > ")
if [[ $typefield == "" ]]; then exit; if [[ $typefield == "" ]]; then exit;
elif [[ $typefield == "password" ]]; then typePass; elif [[ $typefield == "password" ]]; then typePass;
elif [[ $typefield == "< Return" ]]; then mainMenu; elif [[ $typefield == "< Return" ]]; then mainMenu;
@ -269,7 +269,7 @@ typeMenu () {
copyMenu () { copyMenu () {
checkIfPass checkIfPass
copyfield=$(echo -e "< Return\n---\npassword\n$(pass "${selected_password}" | grep -P ':[\t ]' | gawk -F ':' '{ print $1 }')" | _rofi -dmenu -p "Choose Field to copy > ") copyfield=$({ echo -e "< Return\n---\npassword"; pass "${selected_password}" | grep -P ':[\t ]' | gawk -F ':' '{ print $1 }';} | _rofi -dmenu -p "Choose Field to copy > ")
if [[ $copyfield == "" ]]; then exit; if [[ $copyfield == "" ]]; then exit;
elif [[ $copyfield == "password" ]]; then copyPass; elif [[ $copyfield == "password" ]]; then copyPass;
elif [[ $copyfield == "< Return" ]]; then mainMenu; elif [[ $copyfield == "< Return" ]]; then mainMenu;
@ -298,8 +298,8 @@ showEntry () {
declare -A stuff declare -A stuff
while read -r LINE; do while read -r LINE; do
_id=$(echo -e "${LINE}" | gawk -F ':[[:space:]]*' '{print $1}') _id=$(echo "${LINE}" | gawk -F ':[[:space:]]*' '{print $1}')
_val=$(echo -e "${LINE}" | gawk '{sub(/:/,"")}{for (i=2; i<NF; i++) printf $i " "; print $NF}') _val=$(echo "${LINE}" | gawk '{sub(/:/,"")}{for (i=2; i<NF; i++) printf $i " "; print $NF}')
stuff["${_id}"]=${_val} stuff["${_id}"]=${_val}
done < <(PASSWORD_STORE_DIR="${root}" pass "${selected_password}" | tail -n+2 | grep -P '(: |:\t)' ) done < <(PASSWORD_STORE_DIR="${root}" pass "${selected_password}" | tail -n+2 | grep -P '(: |:\t)' )
@ -397,7 +397,7 @@ insertPass () {
if [[ -z "$domain" ]]; then domain="Empty"; fi if [[ -z "$domain" ]]; then domain="Empty"; fi
if [[ -z "$name" ]]; then name="Empty"; fi if [[ -z "$name" ]]; then name="Empty"; fi
insertmenu=$(echo -e "0 Return to Main Menu\n* Accept Values and Add Password Entry\n---\n1 Name ($name)\n2 URL ($domain)\n3 User ($user)\n4 Password ($pass2)" | _rofi -dmenu -mesg "<span color='$help_color'>For faster adding use the addpass command</span>" -p "Add Entry > ") insertmenu=$({ echo -e "0 Return to Main Menu\n* Accept Values and Add Password Entry\n---"; echo "1 Name ($name)"; echo "2 URL ($domain)"; echo "3 User ($user)"; echo "4 Password ($pass2)"; } | _rofi -dmenu -mesg "<span color='$help_color'>For faster adding use the addpass command</span>" -p "Add Entry > ")
insert_val=$? insert_val=$?
if [[ $insert_val -eq 1 ]]; then exit if [[ $insert_val -eq 1 ]]; then exit
else else
@ -405,13 +405,23 @@ insertPass () {
elif [[ $insertmenu == "" ]]; then exit elif [[ $insertmenu == "" ]]; then exit
elif [[ $insertmenu == "* Accept Values and Add Password Entry" ]]; then elif [[ $insertmenu == "* Accept Values and Add Password Entry" ]]; then
cd "${root}" || exit cd "${root}" || exit
group=$(echo -e "No Group\n---\n$(find -type d -not -iwholename '*.git*' -printf '%d\t%P\n' | sort -r -nk1 | cut -f2-)" | _rofi -dmenu -p "Choose Group > ") group=$({ echo -e "No Group\n---"; find -type d -not -iwholename '*.git*' -printf '%d\t%P\n' | sort -r -nk1 | cut -f2-;} | _rofi -dmenu -p "Choose Group > ")
if [[ "$group" == "No Group" ]]; then if [[ "$group" == "No Group" ]]; then
PASSWORD_STORE_DIR="${root}" pass insert -m -f "${name}" < <(echo -e "${pass}\n${USERNAME_field}: ${user}\n---\n${URL_field}: ${domain}") {
echo "${pass}"
echo "${USERNAME_field}: ${user}"
echo "---"
echo "${URL_field}: ${domain}"
} | PASSWORD_STORE_DIR="${root}" pass insert -m -f "${name}"
elif [[ "$group" == "" ]]; then elif [[ "$group" == "" ]]; then
exit exit
else else
PASSWORD_STORE_DIR="${root}" pass insert -m -f "${group}/${name}" < <(echo -e "${pass}\nU${USERNAME_field}: ${user}\n---\n${URL_field}: ${domain}") {
echo "${pass}"
echo "${USERNAME_field}: ${user}"
echo "---"
echo "${URL_field}: ${domain}"
} | PASSWORD_STORE_DIR="${root}" pass insert -m -f "${group}/${name}"
fi fi
exit exit
elif [[ $insertmenu == "1 Name"* ]]; then elif [[ $insertmenu == "1 Name"* ]]; then