معرفی شرکت ها


bumbo-el-0.0.2


Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر
Card image cap
تبلیغات ما

مشتریان به طور فزاینده ای آنلاین هستند. تبلیغات می تواند به آنها کمک کند تا کسب و کار شما را پیدا کنند.

مشاهده بیشتر

توضیحات

Bumbo Python Web Framework built for learning purposes.
ویژگی مقدار
سیستم عامل -
نام فایل bumbo-el-0.0.2
نام bumbo-el
نسخه کتابخانه 0.0.2
نگهدارنده []
ایمیل نگهدارنده []
نویسنده neleonora
ایمیل نویسنده nan.eleonora@gmail.com
آدرس صفحه اصلی -
آدرس اینترنتی https://pypi.org/project/bumbo-el/
مجوز MIT
# Bumbo: Python Web Framework built for learning purposes ![purpose](https://img.shields.io/badge/purpose-learning-green.svg) ![PyPI](https://img.shields.io/pypi/v/bumbo.svg) Bumbo is a Python web framework built for learning purposes. It's a WSGI framework and can be used with any WSGI application server such as Gunicorn. ## Installation ```shell pip install bumbo ``` ## How to use it ### Basic usage: ```python from bumbo.api import API app = API() @app.route("/home") def home(request, response): response.text = "Hello from the HOME page" @app.route("/hello/{name}") def greeting(request, response, name): response.text = f"Hello, {name}" @app.route("/book") class BooksResource: def get(self, req, resp): resp.text = "Books Page" def post(self, req, resp): resp.text = "Endpoint to create a book" @app.route("/template") def template_handler(req, resp): resp.body = app.template( "index.html", context={"name": "Bumbo", "title": "Best Framework"}).encode() ``` ### Unit Tests The recommended way of writing unit tests is with [pytest](https://docs.pytest.org/en/latest/). There are two built in fixtures that you may want to use when writing unit tests with Bumbo. The first one is `app` which is an instance of the main `API` class: ```python def test_route_overlap_throws_exception(app): @app.route("/") def home(req, resp): resp.text = "Welcome Home." with pytest.raises(AssertionError): @app.route("/") def home2(req, resp): resp.text = "Welcome Home2." ``` The other one is `client` that you can use to send HTTP requests to your handlers. It is based on the famous [requests](http://docs.python-requests.org/en/master/) and it should feel very familiar: ```python def test_parameterized_route(app, client): @app.route("/{name}") def hello(req, resp, name): resp.text = f"hey {name}" assert client.get("http://testserver/matthew").text == "hey matthew" ``` ## Templates The default folder for templates is `templates`. You can change it when initializing the main `API()` class: ```python app = API(templates_dir="templates_dir_name") ``` Then you can use HTML files in that folder like so in a handler: ```python @app.route("/show/template") def handler_with_template(req, resp): resp.html = app.template( "example.html", context={"title": "Awesome Framework", "body": "welcome to the future!"}) ``` ## Static Files Just like templates, the default folder for static files is `static` and you can override it: ```python app = API(static_dir="static_dir_name") ``` Then you can use the files inside this folder in HTML files: ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>{{title}}</title> <link href="/static/main.css" rel="stylesheet" type="text/css"> </head> <body> <h1>{{body}}</h1> <p>This is a paragraph</p> </body> </html> ``` ### Middleware You can create custom middleware classes by inheriting from the `bumbo.middleware.Middleware` class and overriding its two methods that are called before and after each request: ```python from bumbo.api import API from bumbo.middleware import Middleware app = API() class SimpleCustomMiddleware(Middleware): def process_request(self, req): print("Before dispatch", req.url) def process_response(self, req, res): print("After dispatch", req.url) app.add_middleware(SimpleCustomMiddleware) ```


نیازمندی

مقدار نام
==2.10.3 Jinja2
==1.12.1 parse
==2.22.0 requests
==0.4.1 requests-wsgi-adapter
==1.8.5 WebOb
==4.1.4 whitenoise


زبان مورد نیاز

مقدار نام
>=3.6.0 Python


نحوه نصب


نصب پکیج whl bumbo-el-0.0.2:

    pip install bumbo-el-0.0.2.whl


نصب پکیج tar.gz bumbo-el-0.0.2:

    pip install bumbo-el-0.0.2.tar.gz