Basic Integration Platform
Project description
Basic Integration Platform
Provides a platform for automation with code-first approach, with embedded batteries:
- Tracing (journals)
- Internal and user-defined API
- Ultra-light but rich mobile-first UI
- Embedded key-value storage
It is heavily inspired by node-red and aims to provide same enjoyment during development but without mess of nodes and connections for tasks a little bit more complicated than just hello world.
The platform also tries to be easy in deployment and maintaining. Code could be stored in a SCM (ex: git) and persistent storage is just a single file that could be backed up and restored trivially.
Because memory and CPU consumption relatively low a solution based on the platform could be launched even on Raspberry Pi Zero with 512MB RAM.
Install
pip install binp uvicorn
Example:
from random import randint
from binp import BINP
binp = BINP()
@binp.app.post('/random', response_model=int)
@binp.journal
async def generate_random():
"""
Generate random number in range 0 ... 1024
"""
return randint(0, 1024)
@binp.action
@binp.journal
async def currency_rate():
"""
Fetch currency rate for EUR -> USD
"""
# go to external service
euro = 1.3
await binp.journal.record('rates fetched', base_currency='USD', euro=euro)
Save as 'example.py' and run it by
uvicorn example:binp.app
TIP: pass
--reload
flag touvicorn
to support automatic reload during development
It will expose
- http://127.0.0.1:8000 - UI and API
- http://127.0.0.1:8000/docs - Swagger docs for user-defined APIs
- http://127.0.0.1:8000/internal/docs - Swagger docs for internal APIs
Configuration
Default configuration can be changed by environment variables:
DEV
- setDEV=true
to enable development modeDB_URL
- database SQLITE URL, defaultsqlite:///data.db
HTTP port and binding address configured by uvicorn
:
--port
- set listening port, default8000
--host
- set binding host, default127.0.0.1
For uvicorn
command should be like
uvicorn <python file without .py>:<binp instance>.app
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
Built Distribution
File details
Details for the file binp-0.0.3.tar.gz
.
File metadata
- Download URL: binp-0.0.3.tar.gz
- Upload date:
- Size: 128.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 327800b42c52f9c2fa4675cdc46d5c9e1cc500fec83611616b0f8966cb144eca |
|
MD5 | 86b0026810f63c5081616ec7a2886f54 |
|
BLAKE2b-256 | 34207b2685b736a9a665cf5a015a2c259d1210e67ba41cea97f616ab114564bb |
File details
Details for the file binp-0.0.3-py3-none-any.whl
.
File metadata
- Download URL: binp-0.0.3-py3-none-any.whl
- Upload date:
- Size: 130.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e4f100301b4eafc748eb97d677b0c45c7b472e8502357758625bc72141f9113d |
|
MD5 | a8e79422ab6034325bd901a92e972266 |
|
BLAKE2b-256 | 9894853a5ad0d1dcd53cae33092c92a102d5d15a2c580c98b7275068c9823c2e |