Skip to content

Commit

Permalink
feat: hints all in one (GreptimeTeam#5194)
Browse files Browse the repository at this point in the history
* feat: hints all in one

* chore: If hints are provided in the x-greptime-hints header, ignore the rest of the headers
  • Loading branch information
fengjiachun authored and evenyag committed Jan 3, 2025
1 parent bdd701c commit 5fa04bc
Showing 1 changed file with 37 additions and 0 deletions.
37 changes: 37 additions & 0 deletions src/servers/src/hint_headers.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@
use http::HeaderMap;
use tonic::metadata::MetadataMap;

// For the given format: `x-greptime-hints: auto_create_table=true, ttl=7d`
pub const HINTS_KEY: &str = "x-greptime-hints";

pub const HINT_KEYS: [&str; 5] = [
"x-greptime-hint-auto_create_table",
"x-greptime-hint-ttl",
Expand All @@ -25,6 +28,16 @@ pub const HINT_KEYS: [&str; 5] = [

pub(crate) fn extract_hints<T: ToHeaderMap>(headers: &T) -> Vec<(String, String)> {
let mut hints = Vec::new();
if let Some(value_str) = headers.get(HINTS_KEY) {
value_str.split(',').for_each(|hint| {
let mut parts = hint.splitn(2, '=');
if let (Some(key), Some(value)) = (parts.next(), parts.next()) {
hints.push((key.trim().to_string(), value.trim().to_string()));
}
});
// If hints are provided in the `x-greptime-hints` header, ignore the rest of the headers
return hints;
}
for key in HINT_KEYS.iter() {
if let Some(value) = headers.get(key) {
let new_key = key.replace("x-greptime-hint-", "");
Expand Down Expand Up @@ -112,6 +125,30 @@ mod tests {
assert_eq!(hints[1], ("ttl".to_string(), "3600d".to_string()));
}

#[test]
fn test_extract_hints_all_in_one() {
let mut headers = HeaderMap::new();
headers.insert(
"x-greptime-hints",
HeaderValue::from_static(" auto_create_table=true, ttl =3600d, append_mode=true , merge_mode=false , physical_table= table1"),
);

let hints = extract_hints(&headers);

assert_eq!(hints.len(), 5);
assert_eq!(
hints[0],
("auto_create_table".to_string(), "true".to_string())
);
assert_eq!(hints[1], ("ttl".to_string(), "3600d".to_string()));
assert_eq!(hints[2], ("append_mode".to_string(), "true".to_string()));
assert_eq!(hints[3], ("merge_mode".to_string(), "false".to_string()));
assert_eq!(
hints[4],
("physical_table".to_string(), "table1".to_string())
);
}

#[test]
fn test_extract_hints_with_metadata_map() {
let mut metadata = MetadataMap::new();
Expand Down

0 comments on commit 5fa04bc

Please sign in to comment.