2022-12-30 08:23:19 +00:00
|
|
|
use crate::api::conn::Method;
|
|
|
|
use crate::api::conn::Param;
|
|
|
|
use crate::api::conn::Router;
|
|
|
|
use crate::api::Connection;
|
|
|
|
use crate::api::Result;
|
|
|
|
use crate::sql::Uuid;
|
|
|
|
use std::future::Future;
|
|
|
|
use std::future::IntoFuture;
|
|
|
|
use std::pin::Pin;
|
|
|
|
|
|
|
|
/// A live query kill future
|
|
|
|
#[derive(Debug)]
|
2023-04-19 08:26:22 +00:00
|
|
|
#[must_use = "futures do nothing unless you `.await` or poll them"]
|
2022-12-30 08:23:19 +00:00
|
|
|
pub struct Kill<'r, C: Connection> {
|
|
|
|
pub(super) router: Result<&'r Router<C>>,
|
|
|
|
pub(super) query_id: Uuid,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'r, Client> IntoFuture for Kill<'r, Client>
|
|
|
|
where
|
|
|
|
Client: Connection,
|
|
|
|
{
|
|
|
|
type Output = Result<()>;
|
|
|
|
type IntoFuture = Pin<Box<dyn Future<Output = Self::Output> + Send + Sync + 'r>>;
|
|
|
|
|
|
|
|
fn into_future(self) -> Self::IntoFuture {
|
|
|
|
Box::pin(async move {
|
|
|
|
let mut conn = Client::new(Method::Kill);
|
2023-04-28 11:20:57 +00:00
|
|
|
conn.execute_unit(self.router?, Param::new(vec![self.query_id.into()])).await
|
2022-12-30 08:23:19 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|