A CLI password generator, written in C++.
It generates random passwords according to the configurations provided by the user, such as the length, which set of characters to include in the password, etc.
- Here we are using /dev/urandom file which uses uses truly random data to generate seeds, and make them unpredictable because of the large entropy from the entropy pool of the Linux kernel. The final password generated has highly randomized data, almost secure and untraceable.
- User can save the generated password in a specified text file.
It uses cmake to build the program so it needs to be installed on system.
To know more about cmake refer to this page :- https://cmake.org/cmake/help/latest/guide/tutorial/index.html
Cmake can be installed using package managers like apt/dnf by the following ways:-
- For Ubuntu/Debian
sudo apt-get install cmake
- For fedora/CentOS
sudo dnf install cmake
- Cloning this repository
$ git clone https://github.com/hnccbits/passgen-cpp.git
- Going into the reposistory
$ cd passgen-cpp
- Generating standard build files
$ cmake -B build/
$ cd build
$ make
In the project root while generating CMake build files
$ cmake -B build/ -DCMAKE_INSTALL_PREFIX="/usr"
$ sudo make install
Run the following command for information on usage
$ passgen -H
Run this command to generate a random password with default character set of specified length
$ passgen -L <length>
Run this command to generate a random password with all character set of default length 8.
$ passgen -S
Run this command to generate a random password with all character set of specified length
$ passgen -S -L <length>
Run this command to generate a password of default length with special characters and saves it in the specified file.
- The file path can be absolute or relative.
$ passgen -F <file path> -S -L <length>
It is a special file that serves as a pseudorandom number generator.
- This file is present in Unix-like operating systems.
- Providing access to the environmental noise collected from the device drivers, such as printers, graphic cards, helps us read random data, which is used as the seed for further generation of the password.
- to know more about this file refer to to this documentation :- /dev/urandom
- It can also be achieved by the use of the srand(time(0)) function but the same password is generated if our code is run multiple times in the same second.