Skip to main content

A small web framework, just big enough for a spider.

Project description

spiderweb

PyPI release version for Spiderweb Gitmoji Code style: Black

As a professional web developer focusing on arcane uses of Django for arcane purposes, it occurred to me a little while ago that I didn't actually know how a web framework worked.

So I built one.

spiderweb is a small web framework, just big enough to hold a spider. Getting started is easy:

uv add spiderweb-framework
# or
pip install spiderweb-framework

Create a new file and drop this in it:

from spiderweb import SpiderwebRouter
from spiderweb.response import HttpResponse

app = SpiderwebRouter()

@app.route("/")
def index(request):
    return HttpResponse("HELLO, WORLD!")

if __name__ == "__main__":
    app.start()

View the docs here!

Development (using uv)

This repository uses uv for local development and testing.

  • Create a virtual environment: uv venv
  • Activate it (Windows): .venv\Scripts\activate
  • Activate it (POSIX): source .venv/bin/activate
  • Install deps (editable + dev): uv pip install -e .[dev]
  • Run tests: uv run python -m pytest
  • Lint/format: uv run ruff check . and uv run black .

My goal with this framework was to do three things:

  1. Learn a lot
  2. Create an unholy blend of Django and Flask
  3. Not look at any existing code. Go off of vibes alone and try to solve all the problems I could think of in my own way

And, honestly, I think I got there. Here's a non-exhaustive list of things this can do:

  • Function-based views
  • Optional Flask-style URL routing
  • Optional Django-style URL routing
  • URLs with variables in them a lá Django
  • Full middleware implementation
  • Limit routes by HTTP verbs
  • Custom error routes
  • Built-in dev server
  • Gunicorn support
  • HTML templates with Jinja2
  • Static files support
  • Cookies (reading and setting)
  • Optional append_slash (with automatic redirects!)
  • CSRF middleware
  • CORS middleware
  • Optional POST data validation middleware with Pydantic
  • Session middleware with built-in session store
  • Database support (using SQLAlchemy, but you can use whatever you want as long as there's a SQLAlchemy driver for it)
  • Tests (currently roughly 89% coverage)

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

spiderweb_framework-2.0.1.tar.gz (567.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

spiderweb_framework-2.0.1-py2.py3-none-any.whl (3.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file spiderweb_framework-2.0.1.tar.gz.

File metadata

  • Download URL: spiderweb_framework-2.0.1.tar.gz
  • Upload date:
  • Size: 567.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.12

File hashes

Hashes for spiderweb_framework-2.0.1.tar.gz
Algorithm Hash digest
SHA256 f69f31514c661be3d1f43793fa25faa80604939989bda0596dd45393e023e9a8
MD5 381bd5d24329e48639494bad8e7af282
BLAKE2b-256 4da67a1d10e1699bd8197ac4cd0494b2cd5aa6559fd4cccde8cf57c98eb3d0d6

See more details on using hashes here.

File details

Details for the file spiderweb_framework-2.0.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for spiderweb_framework-2.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f3051f2dc5921cfbc2ffb74ca72d24f072c908eeedc20925cc619e8dc0caaab4
MD5 62bc0e2bdb452aedabb67b71d2c5cd4b
BLAKE2b-256 543342937e4cae9d9fbb0731d0f6fc7dc116866a02fb59ec638a6cd5c92dea64

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page