Skip to main content

DJANGO OUTBOX ENCRYPTION

Project description

DJANGO OUTBOX ENCRYPTION

Sometimes, when you ready to publish your project to server.

There is a slight change between the application settings on the local and the server. Such as database name, password, etc. The second thing, is you need to encrypt information like password or other. The last one, you need to automatically select setting local when you work on local computer, and auto select server when application running on server.

You are on the right path...

Install package to your environment

> pip install outbox-encryption

How to use

Encrypt to environment

This code for create ".env.client" or ".env.server" file    
> python manage.py shell

> from encryption import OutboxEncryption
> lib = OutboxEncryption()
> mplaint_text = {
        'DB_PASSWORD': '',
        'SECRET_KEY': 'xxg_7me8rl2m#a_h2oresgt2#ni=3_4*!ai*=rtsq)yi!g7_5-51xx'
    }
> lib.encrypt_environ('.env.local', mplaint_text)
# file .env.local is created (maybe file is hidden, CTRL+H to show it)

# Open file .env.local
    You have to write other setting that no encrypt apply, such as:
    DEBUG=True
    UNDER_CONSTRUCTION=False
    DB_ENGINE=django.db.backends.mysql
    DB_NAME=db_name
    DB_USER=root
    DB_HOST=127.0.0.1
    DB_PORT=3306

Note:

File .env.local must be :
    .env.local or
    .env.server (nothing else)

Decrypt from environment

Run inside settings.py (django project settings)            
> from encryption import OutboxEncryption
> lib = OutboxEncryption()

Setting unique variable that only exists in local environment, and not exist in server 
We choose env_outbox_encrypt
> lib.set_keyword_local('env_outbox_encrypt')

List of key variable that must be encrypt or decrypt before set or get data
> mplaint_key = ['DB_PASSWORD', 'SECRET_KEY']

Variable that must be cast as list from environmnet to settings.py
> mplaint_list = ['ALLOWED_HOSTS']

Variable that must be cast as tuple from environment to settings.py
> mplaint_tuple = ['SECURE_PROXY_SSL_HEADER']

Get encryption data
> dict1 = lib.decrypt_environ(mplaint_key, mplaint_list, mplaint_tuple)

Setting variable :
> DEBUG = dict1['DEBUG']
> UNDER_CONSTRUCTION = dict1['UNDER_CONSTRUCTION']
> DEBUG = dict1['DEBUG']
> SECRET_KEY = dict1['SECRET_KEY']
> ALLOWED_HOSTS = dict1['ALLOWED_HOSTS']
> DATABASES = {
    'default': {
        'ENGINE'    : dict1['DB_ENGINE'],
        'NAME'      : dict1['DB_NAME'],
        'USER'      : dict1['DB_USER'],
        'PASSWORD'  : dict1['DB_PASSWORD'],
        'HOST'      : dict1['DB_HOST'],
        'PORT'      : dict1['DB_PORT'],
    }
> SECURE_PROXY_SSL_HEADER = dict1['SECURE_PROXY_SSL_HEADER']

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

outbox-encryption-1.0.21.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

outbox_encryption-1.0.21-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file outbox-encryption-1.0.21.tar.gz.

File metadata

  • Download URL: outbox-encryption-1.0.21.tar.gz
  • Upload date:
  • Size: 9.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for outbox-encryption-1.0.21.tar.gz
Algorithm Hash digest
SHA256 6a4de5ea52809c8244ce588f78b755ad507f1dae9d4f1b457919e32f8f26ed25
MD5 7b69c594fa22b1889470a93a42743301
BLAKE2b-256 c84e4b3ce64f7a3be4e9c936f23f5d66d89a6dd45095d2b6f27f7d5f1bda6ba4

See more details on using hashes here.

Provenance

File details

Details for the file outbox_encryption-1.0.21-py3-none-any.whl.

File metadata

File hashes

Hashes for outbox_encryption-1.0.21-py3-none-any.whl
Algorithm Hash digest
SHA256 af422d7e9f31e64af3b436036658a27e1f9eb47ec6a6247228ba46b954fe72b7
MD5 c0235c42d45454754d13d6e34d21f483
BLAKE2b-256 9c88ecd2d8fb1ff836fb625f94ee772c60250edc10cdc1fbde0619eab4c9d550

See more details on using hashes here.

Provenance

Supported by

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