Skip to content

Commit

Permalink
use 'IntoFuture' trait
Browse files Browse the repository at this point in the history
  • Loading branch information
danieleades committed Mar 1, 2024
1 parent 8684b04 commit c478154
Show file tree
Hide file tree
Showing 6 changed files with 47 additions and 16 deletions.
1 change: 0 additions & 1 deletion examples/list_transactions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ async fn main() -> monzo::Result<()> {
.transactions(account_id)
.since(Utc::now() - Duration::days(args.days))
.limit(args.limit)
.send()
.await?;

println!("account: {account_id}");
Expand Down
4 changes: 1 addition & 3 deletions src/client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,6 @@ where
/// client
/// .basic_feed_item(account_id, title, image_url)
/// .body("i figured out how to send messages to monzo from my computer...")
/// .send()
/// .await?;
/// #
/// # Ok(())
Expand Down Expand Up @@ -243,7 +242,6 @@ where
/// .transactions(account_id)
/// .since(Utc::now() - Duration::days(10))
/// .limit(10)
/// .send()
/// .await?;
/// #
/// # Ok(())
Expand All @@ -270,7 +268,7 @@ where
/// #
/// let transaction_id = "TRANSACTION_ID";
///
/// let transactions = client.transaction(transaction_id).send().await?;
/// let transactions = client.transaction(transaction_id).await?;
/// #
/// # Ok(())
/// # }
Expand Down
21 changes: 16 additions & 5 deletions src/endpoints/feed_items.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
pub use basic::Request as Basic;

pub(crate) mod basic {
use std::future::{Future, IntoFuture};

use serde::Serialize;

use crate::{client, endpoints::Endpoint, Result};
Expand Down Expand Up @@ -99,11 +101,6 @@ pub(crate) mod basic {
self.payload.params.body = Some(body);
self
}

/// Consume and send the [`Request`].
pub async fn send(self) -> Result<()> {
self.client.handle_request(&self).await
}
}

impl<'a, C> Endpoint for Request<'a, C>
Expand All @@ -121,6 +118,20 @@ pub(crate) mod basic {
}
}

impl<'a, C> IntoFuture for Request<'a, C>
where
C: client::Inner,
{
type Output = Result<()>;

type IntoFuture = impl Future<Output = Self::Output>;

/// Consume and send the [`Request`].
fn into_future(self) -> Self::IntoFuture {
async move { self.client.handle_request(&self).await }
}
}

#[derive(Debug, Serialize)]
struct Params<'a> {
#[serde(rename = "params[title]")]
Expand Down
15 changes: 13 additions & 2 deletions src/endpoints/transactions/get.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
use std::future::{Future, IntoFuture};

use super::Transaction;
use crate::{client, endpoints::Endpoint, Result};

Expand Down Expand Up @@ -53,9 +55,18 @@ where
self.expand_merchant = true;
self
}
}

impl<'a, C> IntoFuture for Request<'a, C>
where
C: client::Inner,
{
type Output = Result<Transaction>;

type IntoFuture = impl Future<Output = Self::Output>;

/// Consume the request and return the [`Transaction`]
pub async fn send(self) -> Result<Transaction> {
self.client.handle_request(&self).await
fn into_future(self) -> Self::IntoFuture {
async move { self.client.handle_request(&self).await }
}
}
21 changes: 16 additions & 5 deletions src/endpoints/transactions/list.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
use std::future::{Future, IntoFuture};

use chrono::{DateTime, Utc};
use serde::{Deserialize, Serialize};

Expand Down Expand Up @@ -78,17 +80,26 @@ where
self.query.expand_merchant = Some("merchant");
self
}
}

impl<'a, C> IntoFuture for Request<'a, C>
where
C: client::Inner,
{
type Output = Result<Vec<Transaction>>;

type IntoFuture = impl Future<Output = Self::Output>;

/// Consume the request and return the list of [`Transaction`]s
pub async fn send(self) -> Result<Vec<Transaction>> {
fn into_future(self) -> Self::IntoFuture {
#[derive(Deserialize)]
struct Response {
transactions: Vec<Transaction>,
}

let response: Response = self.client.handle_request(&self).await?;

Ok(response.transactions)
async move {
let response: Response = self.client.handle_request(&self).await?;
Ok(response.transactions)
}
}
}

Expand Down
1 change: 1 addition & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
)]
#![warn(clippy::pedantic)]
#![allow(clippy::missing_errors_doc)]
#![feature(impl_trait_in_assoc_type)]

//! A Monzo client in pure rust.
//!
Expand Down

0 comments on commit c478154

Please sign in to comment.