Sponsored Content
Top Forums Shell Programming and Scripting Print asterisk instead of password (Bash) Post 302989766 by rbatte1 on Wednesday 18th of January 2017 05:32:55 AM
Old 01-18-2017
I think that the -p flag of read takes the next item as a prompt, so you might have:-
Code:
$ cat pass.sh
echo "Enter the username"
read username

stty -echo
read -p "Enter password:- " password
stty echo
echo           # Force new-line because otherwise
               # the cursor is left at the end of the prompt and may confuse any subsequent output.

To display one * for every key press will be more tricky. You would need to read the input 1 character at a time and display the *, building up your overall password variable as you go. No doubt you would also want to handle mistakes in the input, so you would have to allow a backspace character and both delete an * from the screen (making sure that you don't start deleting the prompt) but also remove the last character from the variable you are building up.

Is it really worth this much effort? A telnet or ssh login prompt does not go to these lengths, and it's of limited value to the user anyway.

Those horrible project management phrases are clanging in my head - cost justification; business need; supportability; ..........



Robin
This User Gave Thanks to rbatte1 For This Post:
 

5 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

how to print asterisk without its wild card functionality

I have three cron entries in a file /cron_entries as 15 * * * * /bin/hourjobs > /tmp/hrjob.log 2>&1 .................. .................... I am trying to read this file in for loop using code below: cron=`cat /cron_entries` for line in $cron do printf... (4 Replies)
Discussion started by: sudh
4 Replies

2. Shell Programming and Scripting

Use asterisk in shell script bash

Hello, I am trying to save in a file a single "*" but its not working... look what i am doing... FILE="/home/teste/a.txt" ...BEGIN... ASTERISK="*" echo "STRING $ASTERISK STRING" >> $FILE ...END... when i do it, the result is a list of all files of the current... (4 Replies)
Discussion started by: diogooute
4 Replies

3. UNIX for Dummies Questions & Answers

space-asterisk in bash killed my server

So, here's the deal... I was attempting to type this: > grep -R "searchterm" * and somehow I typed this instead: > grep -R "searchterm" > * I accidentally typed "space-asterisk" on the second prompt. This apparently caused Bash to attempt to run the first file in the pwd, which... (1 Reply)
Discussion started by: treesloth
1 Replies

4. Shell Programming and Scripting

Make a password protected bash script resist/refuse “bash -x” when the password is given

I want to give my long scripts to customer. The customer must not be able to read the scripts even if he has the password. The following command locks and unlocks the script but the set +x is simply ignored. The code: read -p 'Script: ' S && C=$S.crypt H='eval "$((dd if=$0 bs=1 skip=//|gpg... (7 Replies)
Discussion started by: frad
7 Replies

5. Shell Programming and Scripting

To print diamond asterisk pattern based on inputs

I have to print the number of stars that increases on each line from the minimum number until it reaches the maximum number, and then decreases until it goes back to the minimum number. After printing out the lines of stars, it should also print the total number of stars printed. I have tried... (13 Replies)
Discussion started by: rohit_shinez
13 Replies
DROPLANG(1)						  PostgreSQL 9.2.7 Documentation					       DROPLANG(1)

NAME
droplang - remove a PostgreSQL procedural language SYNOPSIS
droplang [connection-option...] langname [dbname] droplang [connection-option...] --list | -l [dbname] DESCRIPTION
droplang is a utility for removing an existing procedural language from a PostgreSQL database. droplang is just a wrapper around the DROP EXTENSION (DROP_EXTENSION(7)) SQL command. Caution droplang is deprecated and may be removed in a future PostgreSQL release. Direct use of the DROP EXTENSION command is recommended instead. OPTIONS
droplang accepts the following command line arguments: langname Specifies the name of the procedural language to be removed. (This name is lower-cased.) [-d] dbname, [--dbname=]dbname Specifies from which database the language should be removed. The default is to use the database with the same name as the current system user. -e, --echo Display SQL commands as they are executed. -l, --list Show a list of already installed languages in the target database. -V, --version Print the droplang version and exit. -?, --help Show help about droplang command line arguments, and exit. droplang also accepts the following command line arguments for connection parameters: -h host, --host=host Specifies the host name of the machine on which the server is running. If host begins with a slash, it is used as the directory for the Unix domain socket. -p port, --port=port Specifies the Internet TCP/IP port or local Unix domain socket file extension on which the server is listening for connections. -U username, --username=username User name to connect as. -w, --no-password Never issue a password prompt. If the server requires password authentication and a password is not available by other means such as a .pgpass file, the connection attempt will fail. This option can be useful in batch jobs and scripts where no user is present to enter a password. -W, --password Force droplang to prompt for a password before connecting to a database. This option is never essential, since droplang will automatically prompt for a password if the server demands password authentication. However, droplang will waste a connection attempt finding out that the server wants a password. In some cases it is worth typing -W to avoid the extra connection attempt. ENVIRONMENT
PGDATABASE, PGHOST, PGPORT, PGUSER Default connection parameters This utility, like most other PostgreSQL utilities, also uses the environment variables supported by libpq (see Section 31.14, "Environment Variables", in the documentation). DIAGNOSTICS
Most error messages are self-explanatory. If not, run droplang with the --echo option and see under the respective SQL command for details. Also, any default connection settings and environment variables used by the libpq front-end library will apply. NOTES
Use createlang(1) to add a language. EXAMPLES
To remove the language pltcl: $ droplang pltcl dbname SEE ALSO
createlang(1), DROP EXTENSION (DROP_EXTENSION(7)), DROP LANGUAGE (DROP_LANGUAGE(7)) PostgreSQL 9.2.7 2014-02-17 DROPLANG(1)
All times are GMT -4. The time now is 10:51 AM.
Unix & Linux Forums Content Copyright 1993-2022. All Rights Reserved.
Privacy Policy