Skip to content

Commit

Permalink
Merge pull request #45 from gevulotnetwork/feature/fetch-all-worker-p…
Browse files Browse the repository at this point in the history
…ages

Use pagination to list all workers
  • Loading branch information
koxu1996 authored Feb 10, 2025
2 parents 680dfd6 + d448d8b commit 1258a15
Showing 1 changed file with 47 additions and 13 deletions.
60 changes: 47 additions & 13 deletions src/worker_client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,19 @@ use tokio::sync::RwLock;
use crate::{
base_client::BaseClient,
error::{Error, Result},
proto::gevulot::gevulot::{
MsgAnnounceWorkerExit, MsgAnnounceWorkerExitResponse, MsgCreateWorker,
MsgCreateWorkerResponse, MsgDeleteWorker, MsgDeleteWorkerResponse, MsgUpdateWorker,
MsgUpdateWorkerResponse,
proto::{
cosmos::base::query::v1beta1::PageRequest,
gevulot::gevulot::{
MsgAnnounceWorkerExit, MsgAnnounceWorkerExitResponse, MsgCreateWorker,
MsgCreateWorkerResponse, MsgDeleteWorker, MsgDeleteWorkerResponse, MsgUpdateWorker,
MsgUpdateWorkerResponse, QueryAllWorkerRequest,
},
},
};

/// Default page size for pagination.
const PAGE_SIZE: u64 = 100;

/// Client for managing workers in the Gevulot system.
#[derive(Debug, Clone)]
pub struct WorkerClient {
Expand Down Expand Up @@ -41,15 +47,43 @@ impl WorkerClient {
///
/// This function will return an error if the request to the Gevulot client fails.
pub async fn list(&mut self) -> Result<Vec<crate::proto::gevulot::gevulot::Worker>> {
let request = crate::proto::gevulot::gevulot::QueryAllWorkerRequest { pagination: None };
let response = self
.base_client
.write()
.await
.gevulot_client
.worker_all(request)
.await?;
Ok(response.into_inner().worker)
let mut all_workers = Vec::new();
let mut next_key: Option<Vec<u8>> = None;

loop {
// Construct request with pagination for the current page.
let pagination = Some(PageRequest {
key: next_key.unwrap_or_default(),
limit: PAGE_SIZE,
..Default::default()
});
let request = QueryAllWorkerRequest { pagination };

let response = self
.base_client
.write()
.await
.gevulot_client
.worker_all(request)
.await?;

let inner = response.into_inner();
all_workers.extend(inner.worker);

// Handle next page.
next_key = inner.pagination.and_then(|p| {
if p.next_key.is_empty() {
None
} else {
Some(p.next_key)
}
});
if next_key.is_none() {
break;
}
}

Ok(all_workers)
}

/// Gets a worker by its ID.
Expand Down

0 comments on commit 1258a15

Please sign in to comment.