Skip to main content

A really basic, not so safe web server.

Project description

SMDB Web Server

An easy to use, not secured web server, because I don't like the other options, and I like to create my own solutions most of the time.

Table of content

Section Name
Usage
Get handler
Put Handler
Post Handler
Data

Usage

To start using this HTTP Server, import the HTMLServer class, and initialize it.

from smdb_web_server import HTMLServer, UrlData
server = HTMLServer("127.0.0.1", 8080, title="Example server")

If the plaintext or json responses will use any specific encodings you can set the response_charset property when creating the HTMLServer. The default value is 'UTF-8'.

IP restrictions can be enplaced by a function passed in to address_filter. For example, a local IP restriction could look like the following:

from smdb_web_server import HTMLServer, UrlData

def restrict_ip_to_lan(ip: str) -> bool:
    return '.'.join(ip.split('.')[:-1]) == '192.168.0'

server = HTMLServer("127.0.0.1", 8080, title="Example server", address_filter=restrict_ip_to_lan)

disable_cache can be set to true to prevent the user's browser from caching the data sent.

An smdb_logger can be used, if desired, but not neccesery.

To add a new url path, use the add_url_rule command.

def index_handler(url_data: UrlData) -> str:
    ...

server.add_url_rule("/", index_handler)

This method will be called with a GET request by default. This can be set as an optional parameter called protocol. For now, only GET and PUT are supported.

Url handlers can be assigned with a decorator as well:

@server.as_url_rule("/help")
def help_handler(url_data: UrlData) -> str:
    ...

To start the server, use either the serve_forever or the serve_forever_threaded function. The first will be a blocking call, the second will create a new thread.

server.serve_forever_threaded(template_dictionary, static_dictionary, "Example Thread")

Both handlers can fail with KnownError exception, whitch will result in a user controlled return code and reason.

To disable caching for one page, set the "disable_cache" flag to true when creating the handler:

@server.as_url_rule("/help", disable_cache=True)
def help_handler(url_data: UrlData) -> str:
    ...

This will send the no_cache flag in the header of the message. To do this with the whole application, set the same flag to true, when instanciating the server.

GET handler

This handler can return any string, but it's usefull, if it returns an HTML file as string. This can be a hardcoded HTML code, or a static or dynamic file. For rendering HTML template files, the server has a helper function called render_template_file. This can render an HTML file from a pre setup dictionary.

def index_handler(url_data: UrlData) -> str:
    example_list = ["value1", "value2|False", "value3|True"]
    return server.render_template("index", page_title="Example Title", example_selector=example_list, button_1="Button 1 name", button_2="Button 2 name")

If you need to just create a list to update an already rendered HTML page's selector, you can use it the following way:

def update(url_data: UrlData) -> str:
    return server.render_template_list("example_selector", ["value1|True", "value2|False", "value3|False"])

server.add_url_rule("/update", update)

This will result in the following list, if we use the option tag as shown in the template_dictionary in the data paragraph:

<option disabled></option>
<option value="value1" selected>value1</option>
<option value="value2">value2</option>
<option value="value3">value3</option>

This list will be sent as a plaintext response.

Put Handler

This handler can return a simple string. The incoming data will be a bytearray of the body of the request.

from smdb_web_server import Protocol

def put_handler(url_data: UrlData) -> str:
    # Do stuff here.
    # Either return with string, or fail with KnownError
    ...

server.add_url_rule("/put", put_handler, Protocol.Put)

Post Handler

This handler can return a simple string. The incoming data will be a bytearray of the body of the request.

rom smdb_web_server import Protocol

def post_handler(url_data: UrlData) -> str:
    # Do stuff here.
    # Either return with string, or fail with KnownError
    ...

server.add_url_rule("/post", post_handler, Protocol.Post)

Data

Template dictionary

  • Keys: The "file name" without extention
  • Value: The file's content, or a path in the following format: "PATH|{Relative path to file}"

This dictionary will be used to generate HTML response from the template. Theese templates can have replaceable values with the following format.

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>{{ page_title }}</title>
    <link rel="stylesheet" href="/static/style.css">
</head>
<body>
    <div class="container">
        <h2>Example Header</h2>
        <div class="grid-container">
                <label for="ExampleSelector">Example Selector:</label>
                <select id="ExampleSelector" class="fixed-width">
                    {{[ example_selector ]}}
                </select>
            <div class="button-group">
                <button id="ExampleButton1">{{ button_1 }}</button>
                <button id="ExampleButton2">{{ button_2 }}</button>
            </div>
        </div>
    </div>
    <script src="/static/script.js"></script>
</body>
</html>

In this page the {{ page_title }}, the {{ button_1 }} and the {{ button_2 }} will be replaced with one value, and the {{[ ExampleSelector ]}} will be generated using a list.

This dictionary should contain a key-value pair with the value being a repeateable value to fill the {{[ ExampleSelector ]}} place.

selector_values = """<option value="{{VALUE}}"{{SELECTED}}>{{VALUE}}</option>"""

Here, the {{VALUE}} will be replaced by the list's content, and the {{SELECTED}} will be replaced by either the value selected or with an emty string, if the list's value is formatted in the following manner: {value}|True. If the value following the | character is not "True", it will be treated as if it was not present.

You can return a list by calling the render_template_list function by itself, or by rendering a full HTML page by calling render_template, with a list as an argument.

Static dictionary

  • Keys: The "file name" without extention
  • Value: Either the file's content, or a path in the following format: "PATH|{Relative path to file}"

Static files will be sent automatically, if the correct URL is called. In the Template Dictionary example, the javascript and the css files are loaded from the path /static/{file_name}. This will result in the {file_name} file being served from the dictionary.

KnownError

This error is used to send a usercontrolled response code to the requester. This exception can be used the following way:

from smdb_web_server import KnownError
def fail(_):
    raise KnownError("Reason", 405)

Protocol

This is a simple enum class to use with add_url_rule to determine the protocol to be used

Values: Get, Put, Post

UrlData

This dataclass contains the following fields, either filled or containing None:

  • fragment: String object (Data following the # in the URL)
  • query: Dictionary with string keys and values (Data following the ? in the URL). The key will be the part following the ? or & characters, and the value will be the part after the = sign. If there is no value, None will be used as a value in the dictionary.
  • data: Bytes object (Payload of the request, if available)
  • source: String object (source addres of the request)
  • headers: Dictionary with string keys and values (The request's headers)

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

smdb_web_server-0.6.4.tar.gz (13.8 kB view details)

Uploaded Source

Built Distribution

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

smdb_web_server-0.6.4-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

File details

Details for the file smdb_web_server-0.6.4.tar.gz.

File metadata

  • Download URL: smdb_web_server-0.6.4.tar.gz
  • Upload date:
  • Size: 13.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.5

File hashes

Hashes for smdb_web_server-0.6.4.tar.gz
Algorithm Hash digest
SHA256 9448e865fdb9edc8eb541f39e812ad2f55f1e266074c5006d6e56710f7e60522
MD5 30d112085ce3c05c361d33d6cfa085c8
BLAKE2b-256 0435fd4f22a992c45f23e398052e853742d7c0620eb4c6aefeef5e6c500a3b6a

See more details on using hashes here.

File details

Details for the file smdb_web_server-0.6.4-py3-none-any.whl.

File metadata

File hashes

Hashes for smdb_web_server-0.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0bb98d4838a8e0642236240c61cda026a01c8881f3ac67b6bc015709c339a4a9
MD5 c5a5ee80d4f6179bccc5481ce9097771
BLAKE2b-256 401beaa6aa7c61f65f95fe8619bad6110e3bb6152c9501b35a78389ecdd7b579

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