Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thenareshofficial/file-encryptions
File encryption and decryption Tool in python
https://github.com/thenareshofficial/file-encryptions
algorithm cmd command-line-tool cryptography cybersecurity-tool decryption docker docker-image encryption file-encryption-python github hashing pip python python-decrypt python-docker python-encryption python3 requirements tool
Last synced: about 8 hours ago
JSON representation
File encryption and decryption Tool in python
- Host: GitHub
- URL: https://github.com/thenareshofficial/file-encryptions
- Owner: theNareshofficial
- License: gpl-3.0
- Created: 2024-04-02T14:13:27.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-06-09T04:15:02.000Z (8 months ago)
- Last Synced: 2024-11-21T13:57:26.516Z (2 months ago)
- Topics: algorithm, cmd, command-line-tool, cryptography, cybersecurity-tool, decryption, docker, docker-image, encryption, file-encryption-python, github, hashing, pip, python, python-decrypt, python-docker, python-encryption, python3, requirements, tool
- Language: Python
- Homepage:
- Size: 417 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# File Encryptions Tool
This file encryption tool allows you to securely encrypt and decrypt various text file formats using a customizable security key. The encrypted output is generated with strong cryptographic practices, including the Advanced Encryption Standard (AES), hash functions, and random salt, ensuring robust security. After encrypting, the output file has the same name as the original file with an ".enc" extension. For example, if you encrypt hello.txt, the resulting encrypted file will be hello.txt.enc.
# How it's work
It sounds like you're describing a file encryption tool that uses the Advanced Encryption Standard (AES) algorithm with additional security features like hash functions and random salt to enhance encryption strength. This kind of encryption tool is commonly used to secure sensitive information, ensuring that only those with the correct security key can access the decrypted contents.
# Installtions
```
# clone repo
$ git clone https://github.com/theNareshofficial/File-Encryptions.git# change directory
$ cd File-Encryptions# Install requirements
$ pip install -r requirements.txt# Encrypt the file
$ python file-encryption.py --file hello.txt --mode encrypt --algorithm AES# Decrypt the file
$ python file-encryption.py --file hello.txt.enc --mode decrypt --algorithm AES
```# Help command
```
# help command
$ python file-encryption.py --helpusage: file-encryptions [-h] --file FILE --mode {encrypt,decrypt} [--algorithm ALGORITHM]
Encrypt or Decrypt a file with a specified algorithm and key.
options:
-h, --help show this help message and exit
--file FILE Path to the file to encrypt or decrypt.
--mode {encrypt,decrypt}
Whether to encrypt or decrypt.
--algorithm ALGORITHM
Encryption algorithm to use. Default AES.
```# Dockerfile Installation
```
# Docker image build command
$ docker build -t file-encryption.py# Docker Encrypt command
$ docker run -t file-encryption.py --file hello.txt --mode encrypt --algorithm AES# Docker Decrypt command
$ docker run -t file-encryption.py --file hello.txt.enc --mode decrypt --algorithm AES
```# Tested OS
- Windows
- Linux
- MAC# Key Concepts
- **AES Algorithm:** AES (Advanced Encryption Standard) is a symmetric encryption algorithm that is widely used for securing data. It offers strong security and is commonly used in various applications, including file encryption tools.
- **Symmetric Encryption:** This type of encryption uses the same key for both encryption and decryption. The security of the encrypted data depends on keeping this key secret.
- **Hash Functions:** A hash function takes an input and produces a fixed-size output (the hash). While hash functions are not inherently designed for encryption, they are often used to create message authentication codes or derive keys.
- **Random Salt:** Salt is random data added to a cryptographic process to make it more resistant to attacks like brute-force or dictionary attacks. It ensures that even if the same data is encrypted multiple times, the resulting encrypted outputs are different.
ThankYouπ