From 2a7ada6361496b4ac51c60161c14225b71613953 Mon Sep 17 00:00:00 2001 From: Martin Nordholts Date: Sun, 29 Oct 2023 15:23:37 +0100 Subject: [PATCH] examples/graphql_issues.rs: Demonstrate variables and paging This was quite tricky to figure out how to do (for me, anyway), so let's help others by demonstrating how to do it. --- examples/graphql_issues.rs | 84 +++++++++++++++++++++++++++++++------- 1 file changed, 70 insertions(+), 14 deletions(-) diff --git a/examples/graphql_issues.rs b/examples/graphql_issues.rs index e6a2876c..5d44ae63 100644 --- a/examples/graphql_issues.rs +++ b/examples/graphql_issues.rs @@ -4,25 +4,81 @@ async fn main() -> Result<(), Box> { .personal_token(std::env::var("GITHUB_TOKEN").unwrap()) .build()?; - let query = r#" { - repository(owner:"XAMPPRocky", name:"octocrab") { - issues(last: 2, states: OPEN) { - nodes { - title - url + let mut variables = serde_json::json!({ + "owner": "XAMPPRocky", + "name": "octocrab", + "page_size": 5, + }); + + let pages_to_show = 3; + let mut page = 1; + loop { + if page > pages_to_show { + break; + } + + let response: octocrab::Result = octocrab + .graphql(&serde_json::json!({ + "query": QUERY, + "variables": variables, + })) + .await; + + match response { + Ok(value) => { + println!("Page {page}:"); + print_issues(&value); + if !update_page_info(&mut variables, &value) { + break; } } + Err(error) => { + println!("{error:#?}"); + break; + } } - } "#; - let response: octocrab::Result = octocrab - .graphql(&serde_json::json!({ "query": query })) - .await; - - match response { - Ok(value) => println!("{value:#?}"), - Err(error) => println!("{error:#?}"), + page += 1; } Ok(()) } + +fn print_issues(value: &serde_json::Value) { + let issues = value["data"]["repository"]["issues"]["nodes"] + .as_array() + .unwrap(); + + for issue in issues { + println!( + "{} {}", + issue["url"].as_str().unwrap(), + issue["title"].as_str().unwrap() + ); + } +} + +fn update_page_info(variables: &mut serde_json::Value, value: &serde_json::Value) -> bool { + let page_info = value["data"]["repository"]["issues"]["pageInfo"].clone(); + if page_info["hasPreviousPage"].as_bool().unwrap() { + variables["before"] = page_info["startCursor"].clone(); + true + } else { + false + } +} + +const QUERY: &str = r#" query ($owner: String!, $name: String!, $page_size: Int!, $before: String) { + repository(owner: $owner, name: $name) { + issues(last: $page_size, before: $before, states: OPEN) { + nodes { + title + url + } + pageInfo { + hasPreviousPage + startCursor + } + } + } +} "#;