mirror of
https://github.com/google/nomulus.git
synced 2025-07-24 19:48:32 +02:00
Add TokenStore and QuotaManager to manage proxy quota requests
The TokenStore is configured by a QuotaConfig for a protocol (EPP/WHOIS). It accepts concurrent take, put and refresh request to grant/accept token to the caller. The QuotaManager contains a TokenStore and provides abstractions that are appropriate for a quota leasing entity to use. Quota return calls are executed asynchronously by the QuotaManager, and quota refresh tasks are scheduled by the QuotaManager to run periodically. ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=182109341
This commit is contained in:
parent
e577d2f5e9
commit
b6d2790a13
8 changed files with 797 additions and 5 deletions
|
@ -14,6 +14,8 @@
|
|||
|
||||
package google.registry.proxy.quota;
|
||||
|
||||
import static com.google.common.base.Preconditions.checkState;
|
||||
|
||||
import com.google.common.annotations.VisibleForTesting;
|
||||
import com.google.common.collect.ImmutableMap;
|
||||
import google.registry.proxy.ProxyConfig.Quota;
|
||||
|
@ -23,6 +25,10 @@ import org.joda.time.Duration;
|
|||
/** Value class that stores the quota configuration for a protocol. */
|
||||
public class QuotaConfig {
|
||||
|
||||
/** A special value of token amount that indicates unlimited tokens. */
|
||||
public static final int SENTINEL_UNLIMITED_TOKENS = -1;
|
||||
|
||||
private final String protocolName;
|
||||
private final int refreshSeconds;
|
||||
private final QuotaGroup defaultQuota;
|
||||
private final ImmutableMap<String, QuotaGroup> customQuotaMap;
|
||||
|
@ -33,7 +39,8 @@ public class QuotaConfig {
|
|||
* <p>Each {@link QuotaGroup} is keyed to all the {@code userId}s it contains. This allows for
|
||||
* fast lookup with a {@code userId}.
|
||||
*/
|
||||
public QuotaConfig(Quota quota) {
|
||||
public QuotaConfig(Quota quota, String protocolName) {
|
||||
this.protocolName = protocolName;
|
||||
refreshSeconds = quota.refreshSeconds;
|
||||
defaultQuota = quota.defaultQuota;
|
||||
ImmutableMap.Builder<String, QuotaGroup> mapBuilder = new ImmutableMap.Builder<>();
|
||||
|
@ -47,18 +54,34 @@ public class QuotaConfig {
|
|||
return customQuotaMap.getOrDefault(userId, defaultQuota);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns if the given user ID is provisioned with unlimited tokens.
|
||||
*
|
||||
* <p>This is configured by setting {@code tokenAmount} to {@code -1} in the config file.
|
||||
*/
|
||||
boolean hasUnlimitedTokens(String userId) {
|
||||
return findQuotaGroup(userId).tokenAmount == SENTINEL_UNLIMITED_TOKENS;
|
||||
}
|
||||
|
||||
/** Returns the token amount for the given {@code userId}. */
|
||||
public int getTokenAmount(String userId) {
|
||||
int getTokenAmount(String userId) {
|
||||
checkState(
|
||||
!hasUnlimitedTokens(userId), "User ID %s is provisioned with unlimited tokens", userId);
|
||||
return findQuotaGroup(userId).tokenAmount;
|
||||
}
|
||||
|
||||
/** Returns the refill period for the given {@code userId}. */
|
||||
public Duration getRefillPeriod(String userId) {
|
||||
Duration getRefillPeriod(String userId) {
|
||||
return Duration.standardSeconds(findQuotaGroup(userId).refillSeconds);
|
||||
}
|
||||
|
||||
/** Returns the refresh period for this quota config. */
|
||||
public Duration getRefreshPeriod() {
|
||||
Duration getRefreshPeriod() {
|
||||
return Duration.standardSeconds(refreshSeconds);
|
||||
}
|
||||
|
||||
/** Returns the name of the protocol for which this quota config is made. */
|
||||
String getProtocolName() {
|
||||
return protocolName;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue