pub struct ServerBuilder<M: Metadata = (), S: Middleware<M> = Noop> { /* private fields */ }
Expand description
Convenient JSON-RPC HTTP Server builder.
Implementations§
Source§impl<M: Metadata + Default, S: Middleware<M>> ServerBuilder<M, S>
impl<M: Metadata + Default, S: Middleware<M>> ServerBuilder<M, S>
Sourcepub fn new<T>(handler: T) -> Selfwhere
T: Into<MetaIoHandler<M, S>>,
pub fn new<T>(handler: T) -> Selfwhere
T: Into<MetaIoHandler<M, S>>,
Creates new ServerBuilder
for given IoHandler
.
By default:
- Server is not sending any CORS headers.
- Server is validating
Host
header.
Examples found in repository?
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params| {
7 futures::finished(Value::String("hello".to_owned()))
8 });
9
10 let server = ServerBuilder::new(io)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
More examples
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params: Params| Ok(Value::String("hello".to_string())));
7
8 let server = ServerBuilder::new(io)
9 .threads(3)
10 .rest_api(RestApi::Unsecure)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Any]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
5fn main() {
6 let mut io = IoHandler::default();
7 io.add_method("say_hello", |_params| {
8 futures::finished(Value::String("hello".to_owned()))
9 });
10
11 let server = ServerBuilder::new(io)
12 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
13 .request_middleware(|request: hyper::Request<hyper::Body>| {
14 if request.uri() == "/status" {
15 Response::ok("Server running OK.").into()
16 } else {
17 request.into()
18 }
19 })
20 .rest_api(RestApi::Unsecure)
21 .start_http(&"127.0.0.1:3030".parse().unwrap())
22 .expect("Unable to start RPC server");
23
24 server.wait();
25}
11fn main() {
12 let mut io = MetaIoHandler::default();
13
14 io.add_method_with_meta("say_hello", |_params: Params, meta: Meta| {
15 let auth = meta.auth.unwrap_or_else(String::new);
16 if auth.as_str() == "let-me-in" {
17 Ok(Value::String("Hello World!".to_owned()))
18 } else {
19 Ok(Value::String(
20 "Please send a valid Bearer token in Authorization header.".to_owned(),
21 ))
22 }
23 });
24
25 let server = ServerBuilder::new(io)
26 .cors_allow_headers(AccessControlAllowHeaders::Only(vec!["Authorization".to_owned()]))
27 .rest_api(RestApi::Unsecure)
28 // You can also implement `MetaExtractor` trait and pass a struct here.
29 .meta_extractor(|req: &hyper::Request<hyper::Body>| {
30 let auth = req
31 .headers()
32 .get(hyper::header::AUTHORIZATION)
33 .map(|h| h.to_str().unwrap_or("").to_owned());
34
35 Meta { auth }
36 })
37 .start_http(&"127.0.0.1:3030".parse().unwrap())
38 .expect("Unable to start RPC server");
39
40 server.wait();
41}
Source§impl<M: Metadata, S: Middleware<M>> ServerBuilder<M, S>
impl<M: Metadata, S: Middleware<M>> ServerBuilder<M, S>
Sourcepub fn with_meta_extractor<T, E>(handler: T, extractor: E) -> Self
pub fn with_meta_extractor<T, E>(handler: T, extractor: E) -> Self
Creates new ServerBuilder
for given IoHandler
.
By default:
- Server is not sending any CORS headers.
- Server is validating
Host
header.
Sourcepub fn event_loop_executor(self, executor: TaskExecutor) -> Self
pub fn event_loop_executor(self, executor: TaskExecutor) -> Self
Utilize existing event loop executor to poll RPC results.
Applies only to 1 of the threads. Other threads will spawn their own Event Loops.
Sourcepub fn rest_api(self, rest_api: RestApi) -> Self
pub fn rest_api(self, rest_api: RestApi) -> Self
Enable the REST -> RPC converter.
Allows you to invoke RPCs by sending POST /<method>/<param1>/<param2>
requests
(with no body). Disabled by default.
Examples found in repository?
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params: Params| Ok(Value::String("hello".to_string())));
7
8 let server = ServerBuilder::new(io)
9 .threads(3)
10 .rest_api(RestApi::Unsecure)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Any]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
More examples
5fn main() {
6 let mut io = IoHandler::default();
7 io.add_method("say_hello", |_params| {
8 futures::finished(Value::String("hello".to_owned()))
9 });
10
11 let server = ServerBuilder::new(io)
12 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
13 .request_middleware(|request: hyper::Request<hyper::Body>| {
14 if request.uri() == "/status" {
15 Response::ok("Server running OK.").into()
16 } else {
17 request.into()
18 }
19 })
20 .rest_api(RestApi::Unsecure)
21 .start_http(&"127.0.0.1:3030".parse().unwrap())
22 .expect("Unable to start RPC server");
23
24 server.wait();
25}
11fn main() {
12 let mut io = MetaIoHandler::default();
13
14 io.add_method_with_meta("say_hello", |_params: Params, meta: Meta| {
15 let auth = meta.auth.unwrap_or_else(String::new);
16 if auth.as_str() == "let-me-in" {
17 Ok(Value::String("Hello World!".to_owned()))
18 } else {
19 Ok(Value::String(
20 "Please send a valid Bearer token in Authorization header.".to_owned(),
21 ))
22 }
23 });
24
25 let server = ServerBuilder::new(io)
26 .cors_allow_headers(AccessControlAllowHeaders::Only(vec!["Authorization".to_owned()]))
27 .rest_api(RestApi::Unsecure)
28 // You can also implement `MetaExtractor` trait and pass a struct here.
29 .meta_extractor(|req: &hyper::Request<hyper::Body>| {
30 let auth = req
31 .headers()
32 .get(hyper::header::AUTHORIZATION)
33 .map(|h| h.to_str().unwrap_or("").to_owned());
34
35 Meta { auth }
36 })
37 .start_http(&"127.0.0.1:3030".parse().unwrap())
38 .expect("Unable to start RPC server");
39
40 server.wait();
41}
Sourcepub fn health_api<A, B, T>(self, health_api: T) -> Self
pub fn health_api<A, B, T>(self, health_api: T) -> Self
Enable health endpoint.
Allows you to expose one of the methods under GET /<path>
The method will be invoked with no parameters.
Error returned from the method will be converted to status 500
response.
Expects a tuple with (<path>, <rpc-method-name>)
.
Sourcepub fn keep_alive(self, val: bool) -> Self
pub fn keep_alive(self, val: bool) -> Self
Enables or disables HTTP keep-alive.
Default is true.
Sourcepub fn threads(self, threads: usize) -> Self
pub fn threads(self, threads: usize) -> Self
Sets number of threads of the server to run.
Panics when set to 0
.
Examples found in repository?
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params: Params| Ok(Value::String("hello".to_string())));
7
8 let server = ServerBuilder::new(io)
9 .threads(3)
10 .rest_api(RestApi::Unsecure)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Any]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
Sourcepub fn cors(
self,
cors_domains: DomainsValidation<AccessControlAllowOrigin>,
) -> Self
pub fn cors( self, cors_domains: DomainsValidation<AccessControlAllowOrigin>, ) -> Self
Configures a list of allowed CORS origins.
Examples found in repository?
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params| {
7 futures::finished(Value::String("hello".to_owned()))
8 });
9
10 let server = ServerBuilder::new(io)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
More examples
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params: Params| Ok(Value::String("hello".to_string())));
7
8 let server = ServerBuilder::new(io)
9 .threads(3)
10 .rest_api(RestApi::Unsecure)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Any]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
5fn main() {
6 let mut io = IoHandler::default();
7 io.add_method("say_hello", |_params| {
8 futures::finished(Value::String("hello".to_owned()))
9 });
10
11 let server = ServerBuilder::new(io)
12 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
13 .request_middleware(|request: hyper::Request<hyper::Body>| {
14 if request.uri() == "/status" {
15 Response::ok("Server running OK.").into()
16 } else {
17 request.into()
18 }
19 })
20 .rest_api(RestApi::Unsecure)
21 .start_http(&"127.0.0.1:3030".parse().unwrap())
22 .expect("Unable to start RPC server");
23
24 server.wait();
25}
Sourcepub fn cors_max_age<T: Into<Option<u32>>>(self, cors_max_age: T) -> Self
pub fn cors_max_age<T: Into<Option<u32>>>(self, cors_max_age: T) -> Self
Configure CORS AccessControlMaxAge
header returned.
Passing Some(millis)
informs the client that the CORS preflight request is not necessary
for at least millis
ms.
Disabled by default.
Sourcepub fn cors_allow_headers(
self,
allowed_headers: AccessControlAllowHeaders,
) -> Self
pub fn cors_allow_headers( self, allowed_headers: AccessControlAllowHeaders, ) -> Self
Configure the CORS AccessControlAllowHeaders
header which are allowed.
Examples found in repository?
11fn main() {
12 let mut io = MetaIoHandler::default();
13
14 io.add_method_with_meta("say_hello", |_params: Params, meta: Meta| {
15 let auth = meta.auth.unwrap_or_else(String::new);
16 if auth.as_str() == "let-me-in" {
17 Ok(Value::String("Hello World!".to_owned()))
18 } else {
19 Ok(Value::String(
20 "Please send a valid Bearer token in Authorization header.".to_owned(),
21 ))
22 }
23 });
24
25 let server = ServerBuilder::new(io)
26 .cors_allow_headers(AccessControlAllowHeaders::Only(vec!["Authorization".to_owned()]))
27 .rest_api(RestApi::Unsecure)
28 // You can also implement `MetaExtractor` trait and pass a struct here.
29 .meta_extractor(|req: &hyper::Request<hyper::Body>| {
30 let auth = req
31 .headers()
32 .get(hyper::header::AUTHORIZATION)
33 .map(|h| h.to_str().unwrap_or("").to_owned());
34
35 Meta { auth }
36 })
37 .start_http(&"127.0.0.1:3030".parse().unwrap())
38 .expect("Unable to start RPC server");
39
40 server.wait();
41}
Sourcepub fn request_middleware<T: RequestMiddleware>(self, middleware: T) -> Self
pub fn request_middleware<T: RequestMiddleware>(self, middleware: T) -> Self
Configures request middleware
Examples found in repository?
5fn main() {
6 let mut io = IoHandler::default();
7 io.add_method("say_hello", |_params| {
8 futures::finished(Value::String("hello".to_owned()))
9 });
10
11 let server = ServerBuilder::new(io)
12 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
13 .request_middleware(|request: hyper::Request<hyper::Body>| {
14 if request.uri() == "/status" {
15 Response::ok("Server running OK.").into()
16 } else {
17 request.into()
18 }
19 })
20 .rest_api(RestApi::Unsecure)
21 .start_http(&"127.0.0.1:3030".parse().unwrap())
22 .expect("Unable to start RPC server");
23
24 server.wait();
25}
Sourcepub fn meta_extractor<T: MetaExtractor<M>>(self, extractor: T) -> Self
pub fn meta_extractor<T: MetaExtractor<M>>(self, extractor: T) -> Self
Configures metadata extractor
Examples found in repository?
11fn main() {
12 let mut io = MetaIoHandler::default();
13
14 io.add_method_with_meta("say_hello", |_params: Params, meta: Meta| {
15 let auth = meta.auth.unwrap_or_else(String::new);
16 if auth.as_str() == "let-me-in" {
17 Ok(Value::String("Hello World!".to_owned()))
18 } else {
19 Ok(Value::String(
20 "Please send a valid Bearer token in Authorization header.".to_owned(),
21 ))
22 }
23 });
24
25 let server = ServerBuilder::new(io)
26 .cors_allow_headers(AccessControlAllowHeaders::Only(vec!["Authorization".to_owned()]))
27 .rest_api(RestApi::Unsecure)
28 // You can also implement `MetaExtractor` trait and pass a struct here.
29 .meta_extractor(|req: &hyper::Request<hyper::Body>| {
30 let auth = req
31 .headers()
32 .get(hyper::header::AUTHORIZATION)
33 .map(|h| h.to_str().unwrap_or("").to_owned());
34
35 Meta { auth }
36 })
37 .start_http(&"127.0.0.1:3030".parse().unwrap())
38 .expect("Unable to start RPC server");
39
40 server.wait();
41}
Sourcepub fn allow_only_bind_host(self) -> Self
pub fn allow_only_bind_host(self) -> Self
Allow connections only with Host
header set to binding address.
Sourcepub fn allowed_hosts(self, allowed_hosts: DomainsValidation<Host>) -> Self
pub fn allowed_hosts(self, allowed_hosts: DomainsValidation<Host>) -> Self
Specify a list of valid Host
headers. Binding address is allowed automatically.
Sourcepub fn max_request_body_size(self, val: usize) -> Self
pub fn max_request_body_size(self, val: usize) -> Self
Sets the maximum size of a request body in bytes (default is 5 MiB).
Sourcepub fn start_http(self, addr: &SocketAddr) -> Result<Server>
pub fn start_http(self, addr: &SocketAddr) -> Result<Server>
Start this JSON-RPC HTTP server trying to bind to specified SocketAddr
.
Examples found in repository?
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params| {
7 futures::finished(Value::String("hello".to_owned()))
8 });
9
10 let server = ServerBuilder::new(io)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
More examples
4fn main() {
5 let mut io = IoHandler::default();
6 io.add_method("say_hello", |_params: Params| Ok(Value::String("hello".to_string())));
7
8 let server = ServerBuilder::new(io)
9 .threads(3)
10 .rest_api(RestApi::Unsecure)
11 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Any]))
12 .start_http(&"127.0.0.1:3030".parse().unwrap())
13 .expect("Unable to start RPC server");
14
15 server.wait();
16}
5fn main() {
6 let mut io = IoHandler::default();
7 io.add_method("say_hello", |_params| {
8 futures::finished(Value::String("hello".to_owned()))
9 });
10
11 let server = ServerBuilder::new(io)
12 .cors(DomainsValidation::AllowOnly(vec![AccessControlAllowOrigin::Null]))
13 .request_middleware(|request: hyper::Request<hyper::Body>| {
14 if request.uri() == "/status" {
15 Response::ok("Server running OK.").into()
16 } else {
17 request.into()
18 }
19 })
20 .rest_api(RestApi::Unsecure)
21 .start_http(&"127.0.0.1:3030".parse().unwrap())
22 .expect("Unable to start RPC server");
23
24 server.wait();
25}
11fn main() {
12 let mut io = MetaIoHandler::default();
13
14 io.add_method_with_meta("say_hello", |_params: Params, meta: Meta| {
15 let auth = meta.auth.unwrap_or_else(String::new);
16 if auth.as_str() == "let-me-in" {
17 Ok(Value::String("Hello World!".to_owned()))
18 } else {
19 Ok(Value::String(
20 "Please send a valid Bearer token in Authorization header.".to_owned(),
21 ))
22 }
23 });
24
25 let server = ServerBuilder::new(io)
26 .cors_allow_headers(AccessControlAllowHeaders::Only(vec!["Authorization".to_owned()]))
27 .rest_api(RestApi::Unsecure)
28 // You can also implement `MetaExtractor` trait and pass a struct here.
29 .meta_extractor(|req: &hyper::Request<hyper::Body>| {
30 let auth = req
31 .headers()
32 .get(hyper::header::AUTHORIZATION)
33 .map(|h| h.to_str().unwrap_or("").to_owned());
34
35 Meta { auth }
36 })
37 .start_http(&"127.0.0.1:3030".parse().unwrap())
38 .expect("Unable to start RPC server");
39
40 server.wait();
41}
Auto Trait Implementations§
impl<M, S> Freeze for ServerBuilder<M, S>
impl<M = (), S = Noop> !RefUnwindSafe for ServerBuilder<M, S>
impl<M, S> Send for ServerBuilder<M, S>
impl<M, S> Sync for ServerBuilder<M, S>
impl<M, S> Unpin for ServerBuilder<M, S>
impl<M = (), S = Noop> !UnwindSafe for ServerBuilder<M, S>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more