EnigmaBridge Python Client
Project description
`Enigma Bridge <https://www.enigmabridge.com>`__ Python client
==============================================================
With this repo you can use `Enigma Bridge <https://www.enigmabridge.com>`__ encryption service.
Installation
------------
.. code:: bash
pip install ebclient
Usage
-----
The following example assumes that you already have access to the encryption server, i.e., you have a valid api key,
which in this case is 'API_TEST'.
Calling processData():
.. code:: python
from ebclient.process_data import ProcessData
from ebclient.uo import Configuration, Endpoint, SimpleRetry, UO
from ebclient.crypto_util import *
# Construct general configuration (endpoint, request config)
cfg = Configuration()
cfg.endpoint_process = Endpoint.url('https://site2.enigmabridge.com:11180')
cfg.api_key = 'API_TEST'
# UO you want to work with
uo_aes = UO(uo_id=0xee01,
uo_type=0x4,
enc_key=from_hex('e134567890123456789012345678901234567890123456789012345678901234'),
mac_key=from_hex('e224262820223456789012345678901234567890123456789012345678901234'),
configuration=cfg)
# ProcessData itself
pd = ProcessData(uo=uo_aes, config=cfg)
result = pd.call(from_hex('6bc1bee22e409f96e93d7e117393172a'))
print(from_hex('95c6bb9b6a1c3835f98cc56087a03e82') == result)
For more usage examples please refer to tests and our `API
documentation <https://api.enigmabridge.com/api/?python>`__.
Dependencies
------------
.. code:: bash
pip install pycrypto requests
Or to install to home directory
.. code:: bash
pip install --user pycrypto requests
If the error ``ImportError: No module named Crypto`` is thrown it's
needed to run pip with ``--upgrade`` and update pycrypto to the latest
version.
Compatibility
-------------
We should be compatible with Python 2.6+ and Python 3+.
Troubleshooting
---------------
Error in installation of dependencies (cryptography, pyOpenSSL):
``sorry, but this version only supports 100 named groups``
[`100-named-groups <https://community.letsencrypt.org/t/certbot-auto-fails-while-setting-up-virtual-environment-complains-about-package-hashes/20529/18>`__]
Solution: Install downgraded version of pycparser and pyOpenSSL:
::
pip install pycparser==2.13
pip install pyOpenSSL==0.13
pip install cryptography
You may need to install some deps for the python packages
::
yum install gcc g++ openssl-devel libffi-devel python-devel
SNI on Python < 2.7.9
~~~~~~~~~~~~~~~~~~~~~
TLS SNI support was added to Python. For earlier versions SNI needs to
be added to Requests networking library.
::
pip install urllib3
pip install pyopenssl
pip install ndg-httpsclient
pip install pyasn1
Mac OSX installation
~~~~~~~~~~~~~~~~~~~~
For new OSX versions (El Capitan and above) the default system python
installation cannot be modified with standard means. There are some
workarounds, but one can also use ``--user`` switch for pip.
::
pip install --user cryptography
==============================================================
With this repo you can use `Enigma Bridge <https://www.enigmabridge.com>`__ encryption service.
Installation
------------
.. code:: bash
pip install ebclient
Usage
-----
The following example assumes that you already have access to the encryption server, i.e., you have a valid api key,
which in this case is 'API_TEST'.
Calling processData():
.. code:: python
from ebclient.process_data import ProcessData
from ebclient.uo import Configuration, Endpoint, SimpleRetry, UO
from ebclient.crypto_util import *
# Construct general configuration (endpoint, request config)
cfg = Configuration()
cfg.endpoint_process = Endpoint.url('https://site2.enigmabridge.com:11180')
cfg.api_key = 'API_TEST'
# UO you want to work with
uo_aes = UO(uo_id=0xee01,
uo_type=0x4,
enc_key=from_hex('e134567890123456789012345678901234567890123456789012345678901234'),
mac_key=from_hex('e224262820223456789012345678901234567890123456789012345678901234'),
configuration=cfg)
# ProcessData itself
pd = ProcessData(uo=uo_aes, config=cfg)
result = pd.call(from_hex('6bc1bee22e409f96e93d7e117393172a'))
print(from_hex('95c6bb9b6a1c3835f98cc56087a03e82') == result)
For more usage examples please refer to tests and our `API
documentation <https://api.enigmabridge.com/api/?python>`__.
Dependencies
------------
.. code:: bash
pip install pycrypto requests
Or to install to home directory
.. code:: bash
pip install --user pycrypto requests
If the error ``ImportError: No module named Crypto`` is thrown it's
needed to run pip with ``--upgrade`` and update pycrypto to the latest
version.
Compatibility
-------------
We should be compatible with Python 2.6+ and Python 3+.
Troubleshooting
---------------
Error in installation of dependencies (cryptography, pyOpenSSL):
``sorry, but this version only supports 100 named groups``
[`100-named-groups <https://community.letsencrypt.org/t/certbot-auto-fails-while-setting-up-virtual-environment-complains-about-package-hashes/20529/18>`__]
Solution: Install downgraded version of pycparser and pyOpenSSL:
::
pip install pycparser==2.13
pip install pyOpenSSL==0.13
pip install cryptography
You may need to install some deps for the python packages
::
yum install gcc g++ openssl-devel libffi-devel python-devel
SNI on Python < 2.7.9
~~~~~~~~~~~~~~~~~~~~~
TLS SNI support was added to Python. For earlier versions SNI needs to
be added to Requests networking library.
::
pip install urllib3
pip install pyopenssl
pip install ndg-httpsclient
pip install pyasn1
Mac OSX installation
~~~~~~~~~~~~~~~~~~~~
For new OSX versions (El Capitan and above) the default system python
installation cannot be modified with standard means. There are some
workarounds, but one can also use ``--user`` switch for pip.
::
pip install --user cryptography
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
ebclient-1.1.9.tar.gz
(21.6 kB
view details)
Built Distribution
File details
Details for the file ebclient-1.1.9.tar.gz
.
File metadata
- Download URL: ebclient-1.1.9.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/3.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ba07f910aed3c175e7a5722ff74f14ff64bc4f2c575722c5246191201bd5bd96 |
|
MD5 | 8f664348efec74c40b27eb3a66d46c14 |
|
BLAKE2b-256 | 2692da28f56d914a86b163c10095c9e0a8acecd3bc39ef478bfa14c629aa15e2 |
File details
Details for the file ebclient-1.1.9-py2.py3-none-any.whl
.
File metadata
- Download URL: ebclient-1.1.9-py2.py3-none-any.whl
- Upload date:
- Size: 29.7 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: Python-urllib/3.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 35048d28a940ab4f324fddb92e4c2adc288d0b792599fb3994692d37a3e1de3d |
|
MD5 | 3881bd88648a8b1a0ef2ca2ce62cb282 |
|
BLAKE2b-256 | 007cba7f88e902094bde61ac4a93ef6b91431e97277448a940856e7aa4ea8ab7 |