Skip to main content

A PYTHON Micro-Framework For Web Development. API Documentation Is Now Available.

Project description

Maintenance Percentage of issues still open

Ario - Python Lightweight Micro Framework

flask-based framework which is working with jinja2 and wrekzeug

This framework has been developed by Wish Team for web development purpose. This project is maintained by this team and hope make web development easier and faster.

Motivation

The main concept of this framework is like flask. but it's only work like a dispatcher and you could easily use any library you want. you are not dependant to any 3rd specific libraries and also you do not have any regex in matching for your url which may cause ReDos to your system. you could specify the result of your response with just a decorator like @html or @jinja which is help for focusing on your development only.

Instalation

Install and update using pip:

pip install ario

Usage

First of all you should import classes that you want. RouterController, Endpoint, Application should be imported and json, html, setup_jinja, jinja, redirect, forbidden, ok are arbitrary.

from werkzeug.serving import run_simple
from werkzeug.middleware.shared_data import SharedDataMiddleware
from ario import RouterController, Endpoint, Application, json, jinja2
from ario.status import forbidden, ok

For seting up your template:

setup_jinja("./templates")

For instance if we want to define two endpoint that one of them is json and the latter is jinja, we should define them as below:

control = RouterController(debug=True)

@control.route(method=["GET", "POST", "HEAD"], route="/")
class ExampleEndpoint(Endpoint):
    @json
    def get(request, response):
        data = {
            "name": "john",
            "family_name": "doe",
            "age": 21,
            "phone_number": "12345678"
        }
        return data
@control.route(method=["GET", "POST"], route="/user/$id")
class ExampleEndpoint(Endpoint):
    @jinja("base.html")
    def get(request, response, id):
        params = {"my_string": id, "my_list": [0, 1, 2]}
        return params

remeber for using jinja decorator, you should insert a base.html file in template folder After all, we make a socket to our port use werkzeug:

if __name__ == '__main__':
    app = Application(control)
    app = SharedDataMiddleware(app, {
        '/static': os.path.join(os.path.dirname(__file__), 'templates/static')
    })
    print('Demo server started http://localhost:5000')
    run_simple('127.0.0.1', 5000, app, use_debugger=True, use_reloader=True)

You could run your code easily by just typing python yourfile.py

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

ario-0.6.9.tar.gz (12.5 kB view details)

Uploaded Source

Built Distribution

ario-0.6.9-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file ario-0.6.9.tar.gz.

File metadata

  • Download URL: ario-0.6.9.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.5

File hashes

Hashes for ario-0.6.9.tar.gz
Algorithm Hash digest
SHA256 5c11b0057a42a62db87cb5c0b6c81283006fb3728b8c64cae974710dcf4910b6
MD5 f4287a287460bf7c606fa158f25de169
BLAKE2b-256 4a8d758838749915f48f37a64f048c3a85043cc5831aae3a0920edd1c4c23df1

See more details on using hashes here.

File details

Details for the file ario-0.6.9-py3-none-any.whl.

File metadata

  • Download URL: ario-0.6.9-py3-none-any.whl
  • Upload date:
  • Size: 14.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/51.1.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.5

File hashes

Hashes for ario-0.6.9-py3-none-any.whl
Algorithm Hash digest
SHA256 d129bb694e2820c77103b2d32c8fa9dc94430ff76b88642fd973ddd50975aaec
MD5 88f94fed9307fdec327155acedd473cd
BLAKE2b-256 032bedc3710a4442451f9447077b0e92bfa6d2661c3085246345e3999d5fa411

See more details on using hashes here.

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