Skip to content

Commit

Permalink
Merge
Browse files Browse the repository at this point in the history
  • Loading branch information
kushudai committed Jul 20, 2024
2 parents e5b9c23 + c756d9b commit b12d86a
Showing 1 changed file with 37 additions and 25 deletions.
62 changes: 37 additions & 25 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -294,33 +294,39 @@ impl Consul {
/// - request - the [ReadKeyRequest](consul::types::ReadKeyRequest)
/// # Errors:
/// [ConsulError](consul::ConsulError) describes all possible errors returned by this api.
pub async fn read_key(&self, request: ReadKeyRequest<'_>) -> Result<Vec<ReadKeyResponse>> {
pub async fn read_key(
&self,
request: ReadKeyRequest<'_>,
) -> Result<ResponseMeta<Vec<ReadKeyResponse>>> {
let req = self.build_read_key_req(request);
let (response_body, _index) = self
let (response_body, index) = self
.execute_request(
req,
BoxBody::new(http_body_util::Empty::<Bytes>::new()),
None,
READ_KEY_METHOD_NAME,
)
.await?;
serde_json::from_reader::<_, Vec<ReadKeyResponse>>(response_body.reader())
.map_err(ConsulError::ResponseDeserializationFailed)?
.into_iter()
.map(|mut r| {
r.value = match r.value {
Some(val) => Some(
std::str::from_utf8(
&base64::engine::general_purpose::STANDARD.decode(val)?,
)?
.to_string(),
),
None => None,
};

Ok(r)
})
.collect()
Ok(ResponseMeta {
response: serde_json::from_reader::<_, Vec<ReadKeyResponse>>(response_body.reader())
.map_err(ConsulError::ResponseDeserializationFailed)?
.into_iter()
.map(|mut r| {
r.value = match r.value {
Some(val) => Some(
std::str::from_utf8(
&base64::engine::general_purpose::STANDARD.decode(val)?,
)?
.to_string(),
),
None => None,
};

Ok(r)
})
.collect::<Result<Vec<_>>>()?,
index,
})
}

/// Creates or updates a key in Consul's KV store. See the [consul docs](https://www.consul.io/api-docs/kv#create-update-key) for more information.
Expand Down Expand Up @@ -497,7 +503,7 @@ impl Consul {
pub async fn watch_lock<'a>(
&self,
request: LockWatchRequest<'_>,
) -> Result<Vec<ReadKeyResponse>> {
) -> Result<ResponseMeta<Vec<ReadKeyResponse>>> {
let req = ReadKeyRequest {
key: request.key,
namespace: request.namespace,
Expand Down Expand Up @@ -1333,7 +1339,7 @@ mod tests {
.await
}

async fn read_key(consul: &Consul, key: &str) -> Result<Vec<ReadKeyResponse>> {
async fn read_key(consul: &Consul, key: &str) -> Result<ResponseMeta<Vec<ReadKeyResponse>>> {
let req = ReadKeyRequest {
key,
..Default::default()
Expand Down Expand Up @@ -1362,14 +1368,20 @@ mod tests {

async fn get_single_key_value_with_index(consul: &Consul, key: &str) -> (Option<String>, i64) {
let res = read_key(consul, key).await.expect("failed to read key");
let r = res.into_iter().next().unwrap();
(r.value, r.modify_index)
let r = res.response.into_iter().next().unwrap();
(r.value, res.index as i64)
}

fn verify_single_value_matches(res: Result<Vec<ReadKeyResponse>>, value: &str) {
fn verify_single_value_matches(res: Result<ResponseMeta<Vec<ReadKeyResponse>>>, value: &str) {
assert!(res.is_ok());
assert_eq!(
res.unwrap().into_iter().next().unwrap().value.unwrap(),
res.unwrap()
.response
.into_iter()
.next()
.unwrap()
.value
.unwrap(),
value
)
}
Expand Down

0 comments on commit b12d86a

Please sign in to comment.