Skip to main content

A Python library for validating passwords with customizable rules.

Project description

FortiPassValidator

FortiPassValidator is a Python library for validating passwords against customizable rules. It helps ensure that passwords are strong, meet complexity requirements, and avoid inappropriate language.

Features

  • Validate password length, uppercase, lowercase, numbers, and special characters.
  • Detect inappropriate language in passwords using the profanity-check library.
  • Check passwords against common or weak patterns using the zxcvbn library.
  • Provide actionable feedback for weak passwords with specific improvement suggestions.
  • Offer guidance for using password managers for secure password storage.
  • Log password validation attempts securely for auditing purposes (optional).
  • Fully customizable validation settings.
  • Lightweight and easy to integrate into your projects.

Installation

Install the library using pip:

pip install FortiPassValidator

Usage

Default Settings

By default, FortiPassValidator enforces the following rules:

  • Minimum length: 8 characters
  • At least one uppercase letter
  • At least one lowercase letter
  • At least one numeric digit
  • At least one special character

Example:

from fortipass import FortiPassValidator

validator = FortiPassValidator()

password = "ValidPass123!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: True, Feedback: Password is valid.

Customizing Validation Rules

You can adjust the validation rules to fit your requirements:

  • Custom Minimum Length: Enforce a minimum length of 12 characters.
validator = FortiPassValidator(min_length=12)
password = "Short1!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: False, Feedback: Password must be at least 12 characters long.
  • Disabling Uppercase Requirement: Allow passwords without uppercase letters.
validator = FortiPassValidator(require_upper=False)
password = "lowercase123!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: True, Feedback: Password is valid.
  • Disabling Special Characters Requirement: Allow passwords without special characters.
validator = FortiPassValidator(require_special=False)
password = "Password123"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: True, Feedback: Password is valid.

Avoid Common Passwords

FortiPassValidator checks passwords against common or weak patterns using the zxcvbn library. This ensures that commonly used or predictable passwords are flagged.

Example:

password = "password"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: False, Feedback: This password is too weak or commonly used. Please choose a more unique password.

Profanity Detection

FortiPassValidator detects inappropriate language in passwords using the profanity-check library. This ensures that offensive words are flagged during validation.

Example:

password = "Badword123!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: False, Feedback: Password contains inappropriate language.

Actionable Feedback for Weak Passwords

FortiPassValidator provides actionable suggestions for improving weak passwords:

validator = FortiPassValidator()
password = "weakpass"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: False, Feedback: Password must be at least 8 characters long. Consider adding uppercase letters (e.g., A, B, C). Add at least one numeric digit (e.g., 1). Add at least one special character (e.g., @, #, $).

Logging Validation Attempts

If enabled, FortiPassValidator logs password validation attempts to a file (password_validation_log.txt) for auditing purposes:

validator = FortiPassValidator(log_attempts=True)
password = "Test1234!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Check `password_validation_log.txt` for logged attempts.

Comprehensive Validation

You can combine multiple rules to create a highly secure validation setup:

validator = FortiPassValidator(min_length=16, require_upper=True, require_lower=True, require_numbers=True, require_special=True)
password = "SuperSecure123!"
is_valid, feedback = validator.validate(password)
print(f"Valid: {is_valid}, Feedback: {feedback}")
# Output: Valid: True, Feedback: Password is valid.

Testing

To test the library, use the provided unit tests in the tests directory. Run the following command:

python -m unittest discover tests

Project Structure

FortiPassValidator/
├── fortipass/
│   ├── __init__.py
│   ├── validator.py
├── tests/
│   ├── test_validator.py
├── setup.py
├── requirements.txt
├── README.md
├── LICENSE

Dependencies

  • profanity-check: Used to detect inappropriate language in passwords.
  • zxcvbn: Used to evaluate password strength against common patterns.

To install dependencies, run:

pip install -r requirements.txt

Contribution

Contributions are welcome! Follow these steps to contribute:

  1. Fork the repository.
  2. Create a new branch for your feature or bug fix.
  3. Make your changes and test them.
  4. Submit a pull request with a detailed description of your changes.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

Author

Ahmed Abdelrahman

Example Use Cases

Web Applications

Enforce strong password policies during user registration and account updates.

Internal Tools

Validate passwords for employees or system administrators to ensure they follow best practices.

Educational Projects

Demonstrate password security concepts and secure coding practices.

Command-Line Tools

Integrate FortiPassValidator into CLI tools to check password strength in bulk or interactively.

FAQ

1. What happens if profanity-check doesn’t recognize a language?

  • The profanity-check library works well with English. For other languages, you may need to integrate additional profanity-detection tools.

2. Can I disable profanity detection?

  • Yes, you can remove or replace the profanity-check logic in the validate method if it is not required for your use case.

3. Is the library thread-safe?

  • Yes, the library is designed to be thread-safe.

4. How do I report bugs or request features?


Thank you for using FortiPassValidator! Feel free to contribute or reach out with questions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fortipassvalidator-1.0.1.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

FortiPassValidator-1.0.1-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

Details for the file fortipassvalidator-1.0.1.tar.gz.

File metadata

  • Download URL: fortipassvalidator-1.0.1.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for fortipassvalidator-1.0.1.tar.gz
Algorithm Hash digest
SHA256 e2bb54c820d414c7d297f57ec6937f76b28bfebdbf60f2abede915a6d33d2046
MD5 f9e86a2042a15fc8198f8bc3c67459fc
BLAKE2b-256 1a103d7b0dbffe1357c6b2c6501165cf15e37197c5a2022cd35d6521fc616575

See more details on using hashes here.

File details

Details for the file FortiPassValidator-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for FortiPassValidator-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 38bac1f4029227870fafb5b4e4f1c50a49d09e99a39a84938eb3c5624396bf16
MD5 39ff7376dd4de2e60c91a16088aa5575
BLAKE2b-256 10cb7f191160319fbbf1ecde547a9eeb0d01352455cb10b141ea1ef15d341258

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page