Skip to main content

A lightweight and highly customizable Python framework for building web applications

Project description

Mango Framework

License Mango Icon

Introduction

Mango is a lightweight Python framework for building web applications. It provides a simple and intuitive way to handle routing, render HTML templates, and serve files. With Mango, you can quickly set up a web server and define routes to handle different HTTP requests. It is made to be accessible and highly modifiable even by beginners to learn and eventually move on to more mature frameworks such as Flask or Bottle. You only need python3 to run Mango and nothing else.

Features

  • Easy routing configuration
  • Rendering HTML templates
  • Serving static files
  • Handling JSON data
  • Handling of basic form data
  • Lightweight and minimal dependencies
  • Suitable for small to medium-sized web applications
  • Human readible code even beginners could modify
  • Integrated basic ORM for DB functions
  • Integrated basic Template engine Shake
  • Handling of file uploads
  • Setting custom 404 error pages
  • Handling static files

Installation

Mango can be easily installed via pip:

pip install mango-framework

Usage

  1. Import the necessary modules and functions from Mango:
from mango import route, run, render, send_json, send_file, get_json, save_file, set_404, set_static_url, enable_static
  1. Define your routes using the @route() decorator:
@route('/')
def index():
    return "Hello, Mango!"
  1. Get JSON data:
@route('/post')
def post(post):
    user = get_json(post)
    return f"Hello, {user['name']}!"
  1. Send JSON data:
@route('/send')
def send():
    return send_json({'name':'john'})
  1. Send a file for the user to download:
@route('/download')
def download():
    return send_file('image.jpeg')

### as attachment

@route('/download')
def download():
    return send_file('image.jpeg', as_attachment=True)
  1. Render the HTML to the user (now supports shake without the class):
@route('/render')
def render():
    return render('index.html')

### New reactive rendering

@route('/render')
def render():
    return render('index.html',{'name':'john'})
  1. Get form data:
@route('/form')
def form(form_data):
    name = form_data.get('name')
    return f"Hello, {name}!"
  1. Get file upload with data:
@route('/get')
def upload(form_fields, files):
    input1 = form_fields.get("input1")  
    input2 = form_fields.get("input2")

    file_item1 = files[0]  
    if file_item1.filename:  
        file_path1 = save_file(data=file_item1.file.read(), name=file_item1.filename, path='upload')

    file_item2 = files[1]
    if file_item2.filename:
        file_path2 = save_file(data=file_item2.file.read(), name=file_item2.filename, path='upload')

        #returns files in a list, forms in a dict

    return "files saved successfully"
  1. Change the default 404 Page:
set_404("<h1> not here ! </h1>")

## or pass an HTML or any file directly

set_404("404.html")
  1. Send static files to HTML:
<link rel="stylesheet" type="text/css" href="/static/style.css">
  1. Change the default Static URL
set_static_url("/images")

Default URL is /static. the new link MUST start with / !

  1. Enable or disable Static serving
enable_static(True)
  1. Run the Mango server:
run()

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

mango-framework-1.1.1.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

mango_framework-1.1.1-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

Details for the file mango-framework-1.1.1.tar.gz.

File metadata

  • Download URL: mango-framework-1.1.1.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for mango-framework-1.1.1.tar.gz
Algorithm Hash digest
SHA256 194383ef6ddba5f64f322a01a3d8294d0773974e0771c50fede75e802d112483
MD5 99c945362065711ec4937e43588dcc63
BLAKE2b-256 23d533a1d0a0d6b096e56f77588e8a5fa530f25b5ee4331016e3399ee8a360c0

See more details on using hashes here.

File details

Details for the file mango_framework-1.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mango_framework-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 357897e7444d4f8606471b4bcffbdea679f3ef7641d7caecefa14c1659a9792f
MD5 0681f8e2fe30c51125c2dd5d34ccecb3
BLAKE2b-256 c99ae3a6976db87d9b9e961becda32ab893fd914571dd6f772146a07ee5858da

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