seld / cli-prompt
Allows you to prompt for user input on the command line, and optionally hide the characters they type
Installs: 22 187 307
Dependents: 17
Suggesters: 0
Security: 0
Stars: 244
Watchers: 6
Forks: 7
Open Issues: 0
Requires
- php: >=5.3
Requires (Dev)
- phpstan/phpstan: ^0.12.63
README
While prompting for user input using fgets()
is quite easy, sometimes you
need to prompt for sensitive information. In these cases, the characters typed
in by the user should not be directly visible, and this is quite a pain to
do in a cross-platform way.
This tiny package fixes just that for you:
<?php echo 'Say hello: '; $answer = Seld\CliPrompt\CliPrompt::hiddenPrompt(); echo 'You answered: '.$answer . PHP_EOL; // Output in the CLI: // // Say hello: // You answered: hello
Installation
composer require seld/cli-prompt
API
-
Seld\CliPrompt\CliPrompt::hiddenPrompt($allowFallback = false);
Prompts the user for input and hides what they type. If this fails for any reason and
$allowFallback
is set totrue
the prompt will be done using the usualfgets()
and characters will be visible. -
Seld\CliPrompt\CliPrompt::prompt();
Regular user prompt for input with characters being shown on screen.
In both cases, the trailing newline the user enters when submitting the answer is trimmed.
Requirements
PHP 5.3 and above
License
CLI-Prompt is licensed under the MIT License - see the LICENSE file for details
Acknowledgments
- This project uses hiddeninput.exe to prompt for passwords on Windows, sources and details can be found on the github page of the project.