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)

Decrypt from environment

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

Setting unique variable tha 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_HOSTS'],
        'PORT'      : dict1['DB_POST'],
    }
> 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.3.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

outbox_encryption-1.0.3-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: outbox-encryption-1.0.3.tar.gz
  • Upload date:
  • Size: 6.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.7

File hashes

Hashes for outbox-encryption-1.0.3.tar.gz
Algorithm Hash digest
SHA256 120a1e9fcc518379b85e6070bbaf648493cf236407c3699bbfc060cc4711dbe9
MD5 d1d93216e39e16c760b8555fe5393f39
BLAKE2b-256 b6b534e2a48cc83cdc0f001f800e3b0da6ce5c686964348f7e76071dff2eaf1c

See more details on using hashes here.

Provenance

File details

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

File metadata

File hashes

Hashes for outbox_encryption-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 4ab414329b63bf23b0922325a3610e480082ccea5a060354b5725714e7b89291
MD5 818f1700240a031a44d53c73eef52e57
BLAKE2b-256 6c5297798383638d5cc53aa7de77adc2bfa34add62187d23fc8ba218453aadad

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