Skip to content

A modern desktop application for secure file encryption, decryption, and key management. Built with PySide6, it features a sleek UI, drag-and-drop functionality, multi-language support, and robust cryptographic tools. Perfect for users who value security and simplicity.

License

Notifications You must be signed in to change notification settings

Victor-Nikliaiev/RSA-4096-Encryption-Manager

Repository files navigation

MIT License PySide6 GitHub Repo

RSA-4096 Encryption Manager v1.0

Overview

The RSA-4096 Encryption Manager v1.0 is a medium-sized, moderately complex desktop application designed to provide a secure, efficient, and user-friendly solution for file encryption, decryption, and key management. This project leverages advanced cryptographic algorithms and a modern GUI to meet the needs of both casual users and professionals seeking secure file handling.

Built using PySide6, the app showcases a modular architecture, dynamic user experience features, and localization support, making it a versatile tool for global audiences.


Releases

Download the latest version of the application from the Releases page.

Available Versions

Note: For Linux, make the program executable, and then run it:

chmod +x encryption_manager_linux
./encryption_manager_linux

Demo

Demo of My Program

Features

Core Functionalities

  1. File Encryption

    • Description: Securely encrypt files to protect sensitive information using robust cryptographic algorithms.
    • Tools Used:
      • Python's cryptography library: Implements encryption and secure key generation.
      • PySide6: Provides GUI components for file selection and displaying encryption results.
  2. File Decryption

    • Description: Allows users to decrypt previously encrypted files to access their original content with accuracy.
    • Tools Used:
      • cryptography library: Ensures reliable decryption matching the encryption process.
      • PySide6 Widgets: Creates a user-friendly interface for inputting decryption keys and file selection.
  3. Key Management

    • Description: Enables generating, exporting, and securely managing cryptographic keys.
    • Tools Used:
      • cryptography key generation functions: Supports public-private and symmetric keys.
      • PySide6 File Dialogs: Facilitates exporting keys to user-defined locations.

User Experience Features

  1. Modern UI Design

    • Description: A visually appealing and intuitive interface for enhanced user interaction.
    • Tools Used:
      • PySide6 Designer: Designs UI layouts and integrates custom components.
      • Global Stylesheets: Ensures consistency across the application's themes.
  2. Drag-and-Drop Functionality

    • Description: Allows users to drag files directly into the application for quick and easy processing.
    • Tools Used:
      • PySide6 Drag-and-Drop APIs: Simplifies file selection and enhances usability.
  3. Localization Support

    • Description: Offers multi-language support to cater to global audiences.
    • Tools Used:
      • PySide6 Translation Tools: Manages .ts and .qm files for localization.
      • Dynamic Translation Loading: Applies language changes in real-time.

Additional Features

  1. Glowing Animated Logo

    • Description: Enhances the application's aesthetics with a visually engaging, glowing logo.
    • Tools Used:
      • PySide6 Animation Framework: Creates smooth and dynamic animations.
      • Custom QSS Styles: Adds glowing effects to the logo.
  2. Error Handling

    • Description: Provides detailed error messages and alerts to guide users through potential issues.
    • Tools Used:
      • Python Try-Except Blocks: Handles backend exceptions like invalid keys or unsupported file formats.
      • PySide6 Message Dialogs: Displays user-friendly prompts for error resolution.
  3. Performance Optimization

    • Description: Efficiently handles large files and complex operations without compromising performance.
    • Tools Used:
      • Threading in PySide6: Runs time-consuming tasks in the background.
      • Buffered File Handling: Processes large files in chunks for optimized memory usage.
  4. Comprehensive Test Suite

    • Description: Ensures the application's stability, reliability, and robustness across various scenarios.

    • Tools Used:

      • Pytest Framework: Executes unit and integration tests for backend components.

      • Mocking Libraries: Simulates various user interactions and edge cases.


Project Structure

The application follows a modular structure, ensuring clarity, scalability, and maintainability:

  • main.py: The entry point for initializing the application.
  • backend: Contains core cryptographic logic and processing algorithms.
  • components: Modular and reusable UI components shared across the application.
  • screens: Dedicated screens for encryption, decryption, and key management functionalities.
  • tools: Utility scripts supporting drag-and-drop, error handling, and other reusable functionality.
  • assets: Houses static resources like icons, stylesheets, and images.
  • translations: Manages localization files for multi-language support.
  • tests: Includes unit and integration tests for backend logic and UI components.

Installation

Prerequisites

  • Python 3.8 or higher
  • Virtual environment (recommended)

Steps

  1. Clone the repository:

    git clone https://github.com/Victor-Nikliaiev/RSA-4096-Encryption-Manager
    cd RSA-4096-Encryption-Manager-master
  2. Install required dependencies:

    pip install -r requirements.txt
  3. Run the application:

    python main.py

Localization

To add or update translations:

  1. Generate .ts files:

    pyside6-lupdate -extensions py,ui -recursive . -ts ./translations/<language>.ts
  2. Edit translations using PySide6 Linguist:

    pyside6-linguist ./translations/<language>.ts
  3. Compile .qm files:

    pyside6-lrelease ./translations/<language>.ts -qm ./translations/<language>.qm

Contributing

You are most welcome for contributions to enhance the RSA-4096 Encryption Manager v1.0:

  1. Fork the repository and create a feature branch:

    git checkout -b feature/your-feature-name
  2. Implement your feature or fix and commit changes:

    git commit -m "Description of your changes"
  3. Push your changes:

    git push origin feature/your-feature-name
  4. Submit a pull request.


Running Tests

Ensure all components work as expected by running the test suite:

pytest tests/

Tests cover critical functionalities such as:

  • Encryption and decryption workflows.

  • Key generation and management.

  • User interface interactions.


License

This project is licensed under the MIT License. Feel free to use, modify, and distribute as per the terms.


Acknowledgments

  • Qt for Python (PySide6): Powers the application’s user interface.
  • Open Source Libraries: The cryptography library and others enhance functionality.
  • Contributors: Thanks to everyone who contributed to this project.

For more details, visit the GitHub Repository.

About

A modern desktop application for secure file encryption, decryption, and key management. Built with PySide6, it features a sleek UI, drag-and-drop functionality, multi-language support, and robust cryptographic tools. Perfect for users who value security and simplicity.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages