Skip to main content

exa_async/resources/
answer.rs

1use crate::{
2    client::Client,
3    config::Config,
4    error::ExaError,
5    types::answer::{AnswerRequest, AnswerResponse},
6};
7
8/// API resource for the `/answer` endpoint (non-streaming)
9pub struct Answer<'c, C: Config> {
10    client: &'c Client<C>,
11}
12
13impl<'c, C: Config> Answer<'c, C> {
14    /// Creates a new Answer resource
15    #[must_use]
16    pub const fn new(client: &'c Client<C>) -> Self {
17        Self { client }
18    }
19
20    /// Generate an answer to a query using Exa's search-augmented generation
21    ///
22    /// # Errors
23    ///
24    /// Returns an error if the request fails or the API returns an error.
25    pub async fn create(&self, req: AnswerRequest) -> Result<AnswerResponse, ExaError> {
26        self.client.post("/answer", req).await
27    }
28}
29
30impl<C: Config> crate::Client<C> {
31    /// Returns the Answer API resource
32    #[must_use]
33    pub const fn answer(&self) -> Answer<'_, C> {
34        Answer::new(self)
35    }
36}