Specify APIs with a Python dict and run with one line
Project description
🙈 Dead Simple Web Framework 🙉
Overview:
A dead simple framework for web applications:
Backend:
- Python 3.7 [Flask]
- MongoDB
- Celery + RabbitMQ
- TODO: Kafka Hooks
- TODO: Redis Hooks
Installing:
$ pip install dead-simple-framework
Configuration:
TODO
Example Application (demo.py
):
* MongoDB must be running *
$ mongod
$ rabbitmq-server
$ celery -A demo worker -l info
from dead_simple_framework import Application, Task_Manager, Database, API
# A sample backend specified as a dictionary
sample_config = {
'routes': {
'/demo': { # Route with automatic CRUD support
'name': 'demo',
'methods': ['GET', 'POST', 'DELETE', 'PUT'],
'template': None,
'defaults': None,
'logic': None,
'collection': 'demo'
},
'/': { # Route that runs an async task (addition)
'name': 'index',
'methods': ['GET'],
'template': None,
'defaults': None,
'logic': lambda: str(Task_Manager.run_task('add', [5, 8], kwargs={})),
},
'/insert': { # Another route with automatic CRUD support
'name': 'insert',
'methods': ['GET', 'POST', 'DELETE', 'PUT'],
'template': None,
'defaults': None,
'logic': None,
'collection': 'insert'
},
'/call': { # Route that runs an async task (API call)
'name': 'call',
'methods': ['GET'],
'template': None,
'defaults': None,
'logic': lambda: str(Task_Manager.run_task('call_api', ['http://services.runescape.com/m=itemdb_oldschool/api/catalogue/detail.json', {'item': 56}])),
},
},
'tasks': { # Async tasks available to the Task_Manager [celery] to schedule or run
'add': { # Simple Addition Task (with default arguments)
'logic': lambda x,y: x + y,
'schedule': None,
'timeframe': None,
'args': (2,2)
},
'insert': { # Periodic Database Insert Task
'logic': lambda res: Database(collection='insert').connect().insert_one({'test': 'doc', 'result': res}),
'schedule': {}, # Default - every minute
'timeframe': None,
'depends_on': 'add' # Return value substituted for `res`
},
'call_api': { # API Call Task
'logic': lambda url, params=None: API.get_json(url, params)
}
}
}
# Required boilerplate to run the app or the scheduler [RabbitMQ must be running]
# Command line:
# Celery | celery -A <path.to.app> worker -l info
# App | python3 <app.py>
app = Application(sample_config)
if __name__ == '__main__':
app.run()
-
Starts a local server at http://0.0.0.0:5000/
-
Serves CRUD operations for MongoDB collection
demo
at endpoint/demo
-
Runs and returns the result of an asynchronous Celery task at endpoint
/
-
Runs an asynchronous chained value calculation and insert into the
insert
collection (viewable at/insert
) -
Runs an asynchronous API call and displays the result at endpoint
/call
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
Built Distribution
Close
Hashes for dead_simple_framework-0.1.3.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7cb6765e33032723aa516a643cfd1485f4a079f841ab5605a4de57931db0d45 |
|
MD5 | d84c28aa4fe2b93c1b8605bb362d7db1 |
|
BLAKE2b-256 | 94123df008b1898e5104ce8bb55c36480628b77a9bfc95d10f2cd4f33a5ac648 |
Close
Hashes for dead_simple_framework-0.1.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bde3f038fab59a7a80cbc776385f659560887a81cb1d280297e7e17ff0dbebc1 |
|
MD5 | 4b6dae0b515c183cdf251d0ec1cc513e |
|
BLAKE2b-256 | 65bba10c655643934147cc7ff8cf4280adcd3afbbc817841379481ac1ea32ab0 |