A CLI tool for password generation
Project description
PyPass Tool
pypass-tool
is a Python-based password management utility that allows users to generate random passwords and store them inside a file for easy recall. It will check for password strength and provide options to adjust the length of the password and exclude specific characters. Users can choose to generate passwords using the command line (CLI), a web browser, or a desktop app.
Contents
Features | Installation | Build from scratch | Usage | Package Usage | Development | Contributing
Features
- Command-Line Interface (CLI): Default interface for generating and managing passwords from the terminal.
- Desktop GUI: Simple graphical interface using Tkinter for generating passwords on your desktop.
- Web Interface: Web-based interface built with Flask for managing passwords through a browser.
Installation
Option 1: Install from PyPI
To install pypass-tool
directly from PyPI:
pip install pypass-tool
Option 2: Build from Source
You can also clone the repository and build the package yourself.
- Clone the repository and navigate to the project directory:
git clone https://github.com/h471x/password_generator.git
cd password_generator
- Build the package:
python setup.py sdist bdist_wheel
- Install the package:
pip install dist/pypass_tool-*.whl
Usage
Once the package is installed, you can use the pypass
command with different interfaces:
-
CLI Mode (default):
pypass
-
Desktop GUI Mode:
pypass gui
-
Web Interface Mode:
pypass web
Open your browser and navigate to
http://127.0.0.1:5000
.
Using as a Package
You can also use pypass-tool
as a package in your own scripts. Here's an example:
from pypass import PasswordGenerator
def main():
# Create an instance of PasswordGenerator
new_pass = PasswordGenerator()
# Set the desired password length and characters to exclude
new_pass.set_password_length(16)
new_pass.exclude_characters("weak12345")
# Generate the password with the specified settings
password = new_pass.generate_password()
# Print the generated password
print(f"Generated Password: {password}")
if __name__ == "__main__":
main()
Development
To modify or extend the functionality, ensure you have the required dependencies installed. You can add new features to the CLI, desktop, or web interface as per the structure.
Dependencies
The required dependencies for the project are listed in setup.py
:
- Flask (for the web interface)
- Tkinter (for the desktop GUI; included with Python)
Install the required dependencies using:
pip install -r requirements.txt
Contributing
Feel free to fork this repository, open issues, or submit pull requests with improvements or bug fixes.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pypass-tool-0.2.7.tar.gz
.
File metadata
- Download URL: pypass-tool-0.2.7.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 583e10d025bee812a8c70678a09ac6fec6d12ead84dc55b518a6cb9b03472684 |
|
MD5 | 4fa6b9d55420b7c17f98bc98947f9e45 |
|
BLAKE2b-256 | 43b3436d9d2a7343be376933c643682eeba68cbcc367d06dab1083213d5a97d5 |
File details
Details for the file pypass_tool-0.2.7-py3-none-any.whl
.
File metadata
- Download URL: pypass_tool-0.2.7-py3-none-any.whl
- Upload date:
- Size: 14.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.11.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 58b87ffb19476c5af123aecab6de80070b0f1aadf5de1e826af9af5e80aea3ab |
|
MD5 | 8a708966bae1d0fc39309640866261ca |
|
BLAKE2b-256 | f07afaa7ba1552e13343fb415de7ef024b43567704a490e7d3f9bed7e0ccc339 |