HTTPS and HTTP server framework
Project description
Slinn is a HTTPS and HTTP server framework
Create project
Unix-like (Linux, MacOS, FreeBSD...):
python3 -m slinn create helloworld
cd helloworld
venv/bin/python manage.py create localhost host=localhost host=127.0.0.1
venv/bin/python manage.py run
Windows:
py -m slinn create helloworld
cd helloworld
venv\Scripts\activate
py manage.py create localhost host=localhost host=127.0.0.1
py manage.py run
Simple example
# localhost/app.py
from slinn import Dispatcher, AnyFilter, LinkFilter, HttpResponse, HttpAPIResponse
dp = Dispatcher('localhost', '127.0.0.1')
@dp(LinkFilter('api'))
def api(request):
return HttpAPIResponse('{"status": "ok"}')
@dp(AnyFilter)
def helloworld(request):
return HttpResponse('Hello world!')
$ venv/bin/python manage.py run
Loading config...
Apps: firstrun
Debug mode enabled
Smart navigation enabled
Starting server...
HTTP server is available on http://[::1]:8080/
To config project you should edit ./project.json
To config app you should edit ./%app%/config.json
Functions:
from slinn import Server
server = Server(*dispatchers: list[Dispatcher], ssl_cert: str=None, ssl_key: str=None, http_ver: str='2.0')
server.address() -> str
server.reload(*dispatchers: list[Dispatcher])
server.listen(address: Address)
from slinn import Address
address = Address(port: int, host: str=None)
from slinn import Dispatcher
dispatcher = Dispatcher(hosts: list=None)
dispatcher.route(filter: Filter)
from slinn import Filter
_filter = Filter(filter: str, methods: list[str]=None)
_filter.check(text: str, method: str) -> bool
_filter.size(text: str, method: str) -> int # Special method for Smart Navigation
# LinkFilter inherits from Filter
from slinn import LinkFilter
link_filter = LinkFilter(filter: str, methods: list[str]=None)
link_filter.check(text: str, method: str) -> bool
# AnyFilter as same as Filter('.*')
from slinn import AnyFilter
from slinn import HttpResponse
http_response = HttpResponse(payload, data: list[tuple]=None, status: str='200 OK', content_type: str='text/plain')
http_response.set_cookie(key: str, value)
http_response.make(type: str='HTTP/2.0') -> str
# HttpAPIResponse inherits from HttpResponse
from slinn import HttpAPIResponse
http_api_response = HttpAPIResponse(payload, data: list[tuple]=None, status: str='200 OK', content_type: str='text/plain')
http_api_response.set_cookie(key: str, value)
http_api_response.make(type: str='HTTP/2.0') -> str
# HttpRedirect inherits from HttpResponse
from slinn import HttpRedirect
HttpRedirect(location: str)
from slinn import Request
request = Request(http_data: str, client_address: tuple[str, int])
# Attributes
request.ip, request.port # Client`s IP and port
request.method # HTTP method
request.version # HTTP version
request.full_link # Full link(path and params)
request.host # Requested host
request.user_agent # Client`s user agent
request.accept # maybe supported technologies
request.encoding # Supported encodings
request.language # Client`s language
request.link # Link(only path)
request.args # GET args
request.cookies # All saved cookies
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
slinn-2.1.0.tar.gz
(14.1 kB
view details)
File details
Details for the file slinn-2.1.0.tar.gz.
File metadata
- Download URL: slinn-2.1.0.tar.gz
- Upload date:
- Size: 14.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
40c515b277cca5fd1cdf3c1679a89cbdbbbc21b90880aecf0b8087f430732aa1
|
|
| MD5 |
a5e40024328da4da65c338d3dda7b66c
|
|
| BLAKE2b-256 |
7378a1ffd5c5718473379a0fbbf32d6d32a586213c42d7a62b4fbe7d57ca5c96
|