aboutsummaryrefslogtreecommitdiff
path: root/src/lib.rs
diff options
context:
space:
mode:
authorGravatar Jake Swenson <jake@jakeswenson.com> 2021-05-15 10:27:52 -0700
committerGravatar Jake Swenson <jake@jakeswenson.com> 2021-05-15 10:28:02 -0700
commita5fccf17f6cf477426c17216b1bc7628e0434d79 (patch)
tree533eea69fbf6a9431827e2e209e0c56738468bd8 /src/lib.rs
parent371a3e49ffe52c2684030f4d3cb669a3aac2b3ca (diff)
downloadnotion-a5fccf17f6cf477426c17216b1bc7628e0434d79.tar.gz
notion-a5fccf17f6cf477426c17216b1bc7628e0434d79.tar.zst
notion-a5fccf17f6cf477426c17216b1bc7628e0434d79.zip
working database queries
Diffstat (limited to 'src/lib.rs')
-rw-r--r--src/lib.rs50
1 files changed, 43 insertions, 7 deletions
diff --git a/src/lib.rs b/src/lib.rs
index 3636ab7..7c4e454 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -1,5 +1,5 @@
-use crate::models::search::SearchRequest;
-use crate::models::{Database, DatabaseId, ListResponse};
+use crate::models::search::{DatabaseQuery, SearchRequest};
+use crate::models::{Database, DatabaseId, ListResponse, Object, Page};
use reqwest::header::{HeaderMap, HeaderValue};
use reqwest::{header, Client, ClientBuilder, RequestBuilder};
use serde::de::DeserializeOwned;
@@ -54,6 +54,7 @@ impl NotionApi {
T: DeserializeOwned,
{
let json = request.send().await?.text().await?;
+ println!("JSON: {}", json);
dbg!(serde_json::from_str::<serde_json::Value>(&json)?);
let result = serde_json::from_str(&json)?;
Ok(result)
@@ -71,7 +72,7 @@ impl NotionApi {
pub async fn search<T: Into<SearchRequest>>(
&self,
query: T,
- ) -> Result<ListResponse<Database>, Box<dyn std::error::Error>> {
+ ) -> Result<ListResponse<Database>, NotionApiClientError> {
Ok(NotionApi::make_json_request(
self.client
.post("https://api.notion.com/v1/search")
@@ -83,7 +84,7 @@ impl NotionApi {
pub async fn get_database<T: Identifiable<Type = DatabaseId>>(
&self,
database_id: T,
- ) -> Result<Database, Box<dyn std::error::Error>> {
+ ) -> Result<Database, NotionApiClientError> {
Ok(NotionApi::make_json_request(self.client.get(format!(
"https://api.notion.com/v1/databases/{}",
database_id.id().id()
@@ -95,9 +96,9 @@ impl NotionApi {
&self,
database: D,
query: T,
- ) -> Result<ListResponse<Database>, NotionApiClientError>
+ ) -> Result<ListResponse<Page>, NotionApiClientError>
where
- T: Into<SearchRequest>,
+ T: Into<DatabaseQuery>,
D: Identifiable<Type = DatabaseId>,
{
Ok(NotionApi::make_json_request(
@@ -114,8 +115,12 @@ impl NotionApi {
#[cfg(test)]
mod tests {
- use crate::models::search::{FilterProperty, FilterValue, NotionSearch};
+ use crate::models::search::PropertyCondition::Text;
+ use crate::models::search::{
+ DatabaseQuery, FilterCondition, FilterProperty, FilterValue, NotionSearch, TextCondition,
+ };
use crate::NotionApi;
+
const TEST_TOKEN: &'static str = include_str!(".api_token");
fn test_client() -> NotionApi {
@@ -165,4 +170,35 @@ mod tests {
Ok(())
}
+
+ #[tokio::test]
+ async fn query_database() -> Result<(), Box<dyn std::error::Error>> {
+ let api = test_client();
+
+ let response = api
+ .search(NotionSearch::Filter {
+ value: FilterValue::Database,
+ property: FilterProperty::Object,
+ })
+ .await?;
+
+ let db = dbg!(response.results()[0].clone());
+
+ let pages = api
+ .query_database(
+ db,
+ DatabaseQuery {
+ filter: Some(FilterCondition {
+ property: "Name".to_string(),
+ condition: Text(TextCondition::Contains("First".to_string())),
+ }),
+ ..Default::default()
+ },
+ )
+ .await?;
+
+ assert_eq!(pages.results().len(), 1);
+
+ Ok(())
+ }
}