Expand description
An extensible and efficient forward-thinking web server for the future.
Kvarn is a rethought web server tailored for the current needs from web application developers.
It handles several things for you, including
- Content-Type
- Compression of body
- Correct and performant HTTP/1 and HTTP/2
- Common API across HTTP/1 and HTTP/2
- Easy integration with HTTP/2 push promises
- Five types of extensions, all backed with intuitive macros
- Optional encryption with rustls
- Several checks for illegal requests
- cache-controland- kvarn-cache-controlheader limits server cache lifetimes
§Getting started
To get started, configure a RunConfig. See the example at RunConfig::execute
on how to get a simple web server running.
A battle-tested reference implementation can be found at GitHub. It powers my two websites with minimal resource requirements.
§Future plans
See the README @ GitHub and kvarn.org.
Re-exports§
- pub use error::default as default_error;
- pub use error::default_response as default_error_response;
- pub use extensions::Extensions;
- pub use extensions::Id;
- pub use read::file as read_file;
- pub use read::file_cached as read_file_cached;
Modules§
- Abstractions for the application layer, providing a common interface for all HTTP versions supported.
- Compress and cache.
- CORS implementation for Kvarn.
- CSP implementation for Kvarn.
- ctlhandoverControl the Kvarn server from the outside.
- Encryption for incoming and outgoing traffic, implemented through streams.
- Utility functions to generate error responses.
- Here, all extensions code is housed.
- Handling of multipleHosts on one instance of Kvarn.
- Limits traffic from a IP address to partially mitigate attacks.
- The Kvarn Prelude
- Utilities for reading files with or without aFileCache.
- Graceful shutdown for Kvarn.
- Vary header handling in Kvarn.
- websocketwebsocketEasy and fast WebSockets for Kvarn.
Macros§
- Create a pinned future, compatible withcrate::RetFut.
- The ultimate extension-creation macro.
- Construct aPackageextension like you write closures.
- pluginhandoverCreate aPlugin.
- Construct aPostextension like you write closures.
- Construct aPrepareextension like you write closures.
- Construct aPresentextension like you write closures.
- Construct aPrimeextension like you write closures.
- Creates asuper::ResponsePipeFuture.
- Creates aRunConfigfromPortDescriptors. This allows you to configure theRunConfigand thenRunConfig::executethe server.
Structs§
- The returned data fromhandle_cache.
- AResponsereturned byhandle_request().
- Describes port, certificate, and host data for a single port to bind.
- Configuration forSelf::execute. This mainly consists of an array ofPortDescriptors.
Enums§
- Which version of the Internet Protocol to bind to.
- An incoming connection, before it’s wrapped with HTTP.
- How to send data to the client.
Functions§
- Will handle a single request, check the cache, process if needed, and caches it. This is where the response is sent.
- Handles a single connection. This includes encrypting it, extracting the HTTP header information, optionally (HTTP/2 & HTTP/3) decompressing them, and passing the request tohandle_cache(). It will also recognize which host should handle the connection.
- Handles a single request and returns response with cache and compress preference.
- Spawn a task.
Type Aliases§
- TheRequestused within Kvarn.