Crates.io | rhodium |
lib.rs | rhodium |
version | 1.0.3 |
source | src |
created_at | 2020-09-03 02:10:08.245919 |
updated_at | 2021-04-02 14:52:20.188174 |
description | Hyper wrapper |
homepage | https://github.com/imonzalvo/rhodium |
repository | https://github.com/imonzalvo/rhodium |
max_upload_size | |
id | 284111 |
size | 75,142 |
Each Handler has its own handle_request
and handle_response
methods.
Handlers are executed by order while handling a request, and by the reverse order while handling the response.
The order in which handle_request
and handle_response
functions are executed is summarized in the next flow diagram:
Every Handler is a struct implementing de RhodHandler
trait, while the Service is a struct implementing the RhodService
trait.
RhodHandlers + RhodService conforms a RhodStack
To use Rhodium, you just have to create a RhodStack
, set the socket address where the hyper server will listen,
and the protocol to be used (HTTP).
If the Handler i returns an error while handling a request:
catch_request
functions are called for the next handlers (Handler i+1, i+2, ..., n), and then the flow is ended.
If the Service
returns an error:
the flow is ended
If the Handler i
returns an error while handling a response:
catch_response
functions are called for the next handlers (Handler i-1, i-2, ..., 1), and then the flow is ended.
cargo test