Skip to content

Commit

Permalink
comments
Browse files Browse the repository at this point in the history
Signed-off-by: Vikas Choudhary (vikasc) <[email protected]>
  • Loading branch information
vikaschoudhary16 committed Oct 16, 2024
1 parent 6ff6a4b commit 71ecf21
Showing 1 changed file with 15 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -309,21 +309,22 @@ LocalRateLimiterImpl::Result LocalRateLimiterImpl::requestAllowed(
if (iter != descriptors_.end()) {
matched_descriptors.push_back(iter->second.get());
} else {
// If the request descriptor is not found in the user descriptors, it could be a wildcard case
// where value is left blank in the user configured descriptor entry. In this case, we need to
// check if it matches any of the dynamic descriptors.
{
absl::ReaderMutexLock lock(&dyn_desc_lock_);
// find request descriptor in the existing dynamic descriptors. If it exists, add bucket to
// matched_descriptors.
// find request descriptor in the existing dynamic descriptors. If it exists, add token
// bucket to matched_descriptors.
auto dynamic_iter = dynamic_descriptors_.find(request_descriptor);
if (dynamic_iter != dynamic_descriptors_.end()) {
matched_descriptors.push_back(dynamic_iter->second.get());
continue;
}
}

// If it does not exist, It could be first request for a dynamic descriptor. Verify it matches
// any of the user descriptors by key and value as blank. If it does not match, skip to next
// entry. check if it matches any of the user descriptors by key and value as blank. If it
// does not match, skip to next entry. If it matches, this is the dynamic descriptor case.
// If it does not exist, then it could be the first request for a dynamic descriptor. Verify
// it matches any of the user configured descriptors by key where value is left blank
for (const auto& pair : descriptors_) {
auto user_descriptor = pair.first;
auto user_bucket = pair.second.get();
Expand All @@ -349,7 +350,7 @@ LocalRateLimiterImpl::Result LocalRateLimiterImpl::requestAllowed(
user_bucket->maxTokens(),
uint32_t(user_bucket->fillRate() *
std::chrono::duration<double>(user_bucket->fillInterval()).count()),
/*1000 milliseconds*/ user_bucket->fillInterval(), time_source_);
user_bucket->fillInterval(), time_source_);
} else {
per_descriptor_token_bucket = std::make_shared<TimerTokenBucket>(
user_bucket->maxTokens(), uint32_t(user_bucket->fillRate()),
Expand Down Expand Up @@ -414,6 +415,8 @@ LocalRateLimiterImpl::Result LocalRateLimiterImpl::requestAllowed(
return {true, makeOptRefFromPtr<TokenBucketContext>(matched_descriptors[0])};
}

// Compare the request descriptor entries with the user descriptor entries. If all non-empty user
// descriptor values match the request descriptor values, return true and fill the new descriptor
bool LocalRateLimiterImpl::compareDescriptorEntries(
const std::vector<RateLimit::DescriptorEntry>& request_entries,
const std::vector<RateLimit::DescriptorEntry>& user_entries,
Expand All @@ -430,6 +433,11 @@ bool LocalRateLimiterImpl::compareDescriptorEntries(
return false;
}

// all non-blank user values must match the request values
if (!user_entries[i].value_.empty() && user_entries[i].value_ != request_entries[i].value_) {
return false;
}

// Check for empty value in user entries
if (user_entries[i].value_.empty()) {
has_empty_value = true;
Expand Down

0 comments on commit 71ecf21

Please sign in to comment.