use futures::{Future, Poll};
use error::*;
use client::{AsyncSender, Client, Sender, SyncSender};
use client::requests::{empty_body, DefaultBody, RequestBuilder};
use client::requests::params::Index;
use client::requests::endpoints::IndicesOpenRequest;
use client::requests::raw::RawRequestInner;
use client::responses::CommandResponse;
pub type IndexOpenRequestBuilder<TSender> = RequestBuilder<TSender, IndexOpenRequestInner>;
#[doc(hidden)]
pub struct IndexOpenRequestInner {
index: Index<'static>,
}
impl<TSender> Client<TSender>
where
TSender: Sender,
{
pub fn index_open(&self, index: Index<'static>) -> IndexOpenRequestBuilder<TSender> {
RequestBuilder::new(self.clone(), None, IndexOpenRequestInner { index: index })
}
}
impl IndexOpenRequestInner {
fn into_request(self) -> IndicesOpenRequest<'static, DefaultBody> {
IndicesOpenRequest::for_index(self.index, empty_body())
}
}
impl IndexOpenRequestBuilder<SyncSender> {
pub fn send(self) -> Result<CommandResponse> {
let req = self.inner.into_request();
RequestBuilder::new(self.client, self.params, RawRequestInner::new(req))
.send()?
.into_response()
}
}
impl IndexOpenRequestBuilder<AsyncSender> {
pub fn send(self) -> Pending {
let req = self.inner.into_request();
let res_future = RequestBuilder::new(self.client, self.params, RawRequestInner::new(req))
.send()
.and_then(|res| res.into_response());
Pending::new(res_future)
}
}
pub struct Pending {
inner: Box<Future<Item = CommandResponse, Error = Error>>,
}
impl Pending {
fn new<F>(fut: F) -> Self
where
F: Future<Item = CommandResponse, Error = Error> + 'static,
{
Pending {
inner: Box::new(fut),
}
}
}
impl Future for Pending {
type Item = CommandResponse;
type Error = Error;
fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
self.inner.poll()
}
}
#[cfg(test)]
mod tests {
use prelude::*;
#[test]
fn default_request() {
let client = SyncClientBuilder::new().build().unwrap();
let req = client.index_open(index("testindex")).inner.into_request();
assert_eq!("/testindex/_open", req.url.as_ref());
}
}