Python API for WebFramework
Project description
C++ HTTP/HTTPS server with Python API
Quick start
Server needs few files to run:
- web.json with routes
- Executors
- config.json with server settings
All these files must be in the same directory asmain.py
main.py
from web_framework_api.WebFramework import WebFramework # Server
from web_framework_api.utility.DLLHandler import initialize_web_framework # WebFramework initialization
from web_framework_api.exceptions.WebFrameworkException import WebFrameworkException # Exception
def on_start():
print("Server is running")
if __name__ == '__main__':
try:
initialize_web_framework() # Load WebFramework shared library
server = WebFramework.from_path("config.json") # Create server
server.start(True, on_start) # Start server and wait
except WebFrameworkException as exception:
print(exception)
exit(-1)
Settings
web.json
{
"HelloExecutor": {
"route": "",
"loadType": "initialization"
}
}
Config
config.json
{
"WebServer": {
"ip": "0.0.0.0",
"port": 8080,
"timeout": 0
},
"WebFramework": {
"settingsPaths": [
"web.json"
],
"loadSources": [
"hello_executor"
],
"assetsPath": "assets",
"templatesPath": "templates",
"cachingSize": 536870912,
"webServerType": "multiThreaded",
"HTTPS": {
"useHTTPS": false,
"pathToCertificate": "certificates/cert.pem",
"pathToKey": "certificates/key.pem"
},
"defaultAssetsPath": "WebFrameworkAssets"
},
"Logging": {
"usingLogging": false,
"dateFormat": "DMY",
"logFileSize": 134217728
},
"ThreadPoolServer": {
"threadCount": 0
}
}
Run sample
After running server open url 127.0.0.1:8080.
You will see response from server
{
"message": "Hello, World!"
}
Executors
Executors are C++ classes that responsible for giving responses for their route(url).
Source code of HelloExecutor from example
HelloExecutor.h
#pragma once
#include "Executors/BaseStatelessExecutor.h"
namespace executors
{
class HelloExecutor : public framework::BaseStatelessExecutor
{
public:
HelloExecutor() = default;
void doGet(framework::HTTPRequest& request, framework::HTTPResponse& response) override;
~HelloExecutor() = default;
};
}
HelloExecutor.cpp
#include "HelloExecutor.h"
#include "JSONBuilder.h"
namespace executors
{
void HelloExecutor::doGet(framework::HTTPRequest& request, framework::HTTPResponse& response)
{
response.addBody(json::JSONBuilder(CP_UTF8).appendString("message", "Hello, World!"));
}
DECLARE_EXECUTOR(HelloExecutor);
}
More information you can find in wiki.
Hello executor
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
Built Distribution
File details
Details for the file web_framework_api-1.0.2.tar.gz
.
File metadata
- Download URL: web_framework_api-1.0.2.tar.gz
- Upload date:
- Size: 5.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9d12768037c9202aba51a72c6cd14c5603dccfb20ef1a8a26c9d194759258c19 |
|
MD5 | c7303a5d9ee8df5631e9e5858f1ab409 |
|
BLAKE2b-256 | 76a2b47aab3b6028a0763de6ec17ce46724ee894f2d5c96c1c7ae6dd14e34e29 |
File details
Details for the file web_framework_api-1.0.2-py2.py3-none-any.whl
.
File metadata
- Download URL: web_framework_api-1.0.2-py2.py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 89d95d3729b43cdc19a1a3e2a0c858e764098755223bea882a0d8dfb8d624b40 |
|
MD5 | afb848246a119c673f9fd4c59b9bd57d |
|
BLAKE2b-256 | 29c9e14bcda0804256d1e7db854ff0e727ae6c0cb42e47e58dc0f49185c92dc6 |