1
0
mirror of https://github.com/fafhrd91/actix-net synced 2024-12-19 08:42:39 +01:00
actix-net/actix-server/src/server.rs

113 lines
2.9 KiB
Rust
Raw Permalink Normal View History

2019-11-26 11:33:45 +01:00
use std::future::Future;
use std::io;
2019-11-26 11:33:45 +01:00
use std::pin::Pin;
use std::task::{Context, Poll};
use tokio::sync::mpsc::UnboundedSender;
use tokio::sync::oneshot;
2018-12-10 06:51:35 +01:00
2018-12-11 06:06:54 +01:00
use crate::builder::ServerBuilder;
use crate::signals::Signal;
2018-12-10 06:51:35 +01:00
#[derive(Debug)]
2018-12-10 06:51:35 +01:00
pub(crate) enum ServerCommand {
Migrate actix-net to std::future (#64) * Migrate actix-codec, actix-rt, and actix-threadpool to std::future * update to latest tokio alpha and futures-rs * Migrate actix-service to std::future, This is a squash of ~8 commits, since it included a lot of experimentation. To see the commits, look into the semtexzv/std-future-service-tmp branch. * update futures-rs and tokio * Migrate actix-threadpool to std::future (#59) * Migrate actix-threadpool to std::future * Cosmetic refactor - turn log::error! into log::warn! as it doesn't throw any error - add Clone and Copy impls for Cancelled making it cheap to operate with - apply rustfmt * Bump up crate version to 0.2.0 and pre-fill its changelog * Disable patching 'actix-threadpool' crate in global workspace as unnecessary * Revert patching and fix 'actix-rt' * Migrate actix-rt to std::future (#47) * remove Pin from Service::poll_ready(); simplify combinators api; make code compile * disable tests * update travis config * refactor naming * drop IntoFuture trait * Migrate actix-server to std::future (#50) Still not finished, this is more WIP, this is an aggregation of several commits, which can be found in semtexzv/std-future-server-tmp branch * update actix-server * rename Factor to ServiceFactory * start server worker in start mehtod * update actix-utils * remove IntoTransform trait * Migrate actix-server::ssl::nativetls to std futures (#61) * Refactor 'nativetls' module * Migrate 'actix-server-config' to std futures - remove "uds" feature - disable features by default * Switch NativeTlsAcceptor to use 'tokio-tls' crate * Bikeshed features names and remove unnecessary dependencies for 'actix-server-config' crate * update openssl impl * migrate actix-connect to std::future * migrate actix-ioframe to std::future * update version to alpha.1 * fix boxed service * migrate server rustls support * migratte openssl and rustls connecttors * store the thread's handle with arbiter (#62) * update ssl connect tests * restore service tests * update readme
2019-11-14 13:38:24 +01:00
WorkerFaulted(usize),
2018-12-10 06:51:35 +01:00
Pause(oneshot::Sender<()>),
Resume(oneshot::Sender<()>),
Signal(Signal),
2018-12-10 06:51:35 +01:00
/// Whether to try and shut down gracefully
Stop {
graceful: bool,
2018-12-11 06:06:54 +01:00
completion: Option<oneshot::Sender<()>>,
2018-12-10 06:51:35 +01:00
},
2019-11-26 11:33:45 +01:00
/// Notify of server stop
Notify(oneshot::Sender<()>),
2018-12-10 06:51:35 +01:00
}
2019-11-26 11:33:45 +01:00
#[derive(Debug)]
pub struct Server(
UnboundedSender<ServerCommand>,
Option<oneshot::Receiver<()>>,
);
2018-12-10 06:51:35 +01:00
impl Server {
pub(crate) fn new(tx: UnboundedSender<ServerCommand>) -> Self {
2019-11-26 11:33:45 +01:00
Server(tx, None)
2018-12-10 06:51:35 +01:00
}
/// Start server building process
pub fn build() -> ServerBuilder {
ServerBuilder::default()
}
pub(crate) fn signal(&self, sig: Signal) {
let _ = self.0.send(ServerCommand::Signal(sig));
}
2018-12-11 06:06:54 +01:00
Migrate actix-net to std::future (#64) * Migrate actix-codec, actix-rt, and actix-threadpool to std::future * update to latest tokio alpha and futures-rs * Migrate actix-service to std::future, This is a squash of ~8 commits, since it included a lot of experimentation. To see the commits, look into the semtexzv/std-future-service-tmp branch. * update futures-rs and tokio * Migrate actix-threadpool to std::future (#59) * Migrate actix-threadpool to std::future * Cosmetic refactor - turn log::error! into log::warn! as it doesn't throw any error - add Clone and Copy impls for Cancelled making it cheap to operate with - apply rustfmt * Bump up crate version to 0.2.0 and pre-fill its changelog * Disable patching 'actix-threadpool' crate in global workspace as unnecessary * Revert patching and fix 'actix-rt' * Migrate actix-rt to std::future (#47) * remove Pin from Service::poll_ready(); simplify combinators api; make code compile * disable tests * update travis config * refactor naming * drop IntoFuture trait * Migrate actix-server to std::future (#50) Still not finished, this is more WIP, this is an aggregation of several commits, which can be found in semtexzv/std-future-server-tmp branch * update actix-server * rename Factor to ServiceFactory * start server worker in start mehtod * update actix-utils * remove IntoTransform trait * Migrate actix-server::ssl::nativetls to std futures (#61) * Refactor 'nativetls' module * Migrate 'actix-server-config' to std futures - remove "uds" feature - disable features by default * Switch NativeTlsAcceptor to use 'tokio-tls' crate * Bikeshed features names and remove unnecessary dependencies for 'actix-server-config' crate * update openssl impl * migrate actix-connect to std::future * migrate actix-ioframe to std::future * update version to alpha.1 * fix boxed service * migrate server rustls support * migratte openssl and rustls connecttors * store the thread's handle with arbiter (#62) * update ssl connect tests * restore service tests * update readme
2019-11-14 13:38:24 +01:00
pub(crate) fn worker_faulted(&self, idx: usize) {
let _ = self.0.send(ServerCommand::WorkerFaulted(idx));
2018-12-10 06:51:35 +01:00
}
/// Pause accepting incoming connections
///
/// If socket contains some pending connection, they might be dropped.
/// All opened connection remains active.
2019-11-26 11:33:45 +01:00
pub fn pause(&self) -> impl Future<Output = ()> {
2018-12-10 06:51:35 +01:00
let (tx, rx) = oneshot::channel();
let _ = self.0.send(ServerCommand::Pause(tx));
async {
let _ = rx.await;
}
2018-12-10 06:51:35 +01:00
}
/// Resume accepting incoming connections
2019-11-26 11:33:45 +01:00
pub fn resume(&self) -> impl Future<Output = ()> {
2018-12-10 06:51:35 +01:00
let (tx, rx) = oneshot::channel();
let _ = self.0.send(ServerCommand::Resume(tx));
async {
let _ = rx.await;
}
2018-12-10 06:51:35 +01:00
}
/// Stop incoming connection processing, stop all workers and exit.
///
/// If server starts with `spawn()` method, then spawned thread get terminated.
2019-11-26 11:33:45 +01:00
pub fn stop(&self, graceful: bool) -> impl Future<Output = ()> {
2018-12-10 06:51:35 +01:00
let (tx, rx) = oneshot::channel();
let _ = self.0.send(ServerCommand::Stop {
2018-12-10 06:51:35 +01:00
graceful,
2018-12-11 06:06:54 +01:00
completion: Some(tx),
2018-12-10 06:51:35 +01:00
});
async {
let _ = rx.await;
}
2019-11-26 11:33:45 +01:00
}
}
impl Clone for Server {
fn clone(&self) -> Self {
Self(self.0.clone(), None)
}
}
impl Future for Server {
type Output = io::Result<()>;
2019-11-26 11:33:45 +01:00
2019-12-02 17:30:09 +01:00
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
2019-11-26 11:33:45 +01:00
let this = self.get_mut();
if this.1.is_none() {
let (tx, rx) = oneshot::channel();
if this.0.send(ServerCommand::Notify(tx)).is_err() {
return Poll::Ready(Ok(()));
2019-11-26 11:33:45 +01:00
}
this.1 = Some(rx);
}
match Pin::new(this.1.as_mut().unwrap()).poll(cx) {
Poll::Pending => Poll::Pending,
Poll::Ready(_) => Poll::Ready(Ok(())),
2019-11-26 11:33:45 +01:00
}
2018-12-10 06:51:35 +01:00
}
}