blob: bf78e9bc865a364e9c46df647ba092d2ea6f8b3d [file] [log] [blame]
/*
* Copyright (C) 2019 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.server.wifi.util;
import com.android.server.wifi.Clock;
/**
* Manages a quota that is reset at the beginning of each new time period.
*/
public class TimedQuotaManager {
private final Clock mClock;
private final long mQuota;
private final long mPeriodMillis;
private final long mStartTimeMillis;
/**
* The number of elapsed periods between {@link #mStartTimeMillis} and the time of the last call
* to {@link #requestQuota()}.
*/
private long mLastPeriod;
/** How much quota has been consumed in the current period. */
private long mConsumedQuota;
/**
* Constructor.
* @param clock Clock instance.
* @param quota the maximum quota for a given period.
* @param periodMillis the quota will be reset at the beginning of each new period.
*/
public TimedQuotaManager(Clock clock, long quota, long periodMillis) {
mClock = clock;
mQuota = quota;
mPeriodMillis = periodMillis;
mStartTimeMillis = clock.getElapsedSinceBootMillis();
mLastPeriod = 0;
mConsumedQuota = 0;
}
/**
* Requests one quota. If there is sufficient remaining quota for the current period,
* returns true and consumes one quota. Otherwise, returns false.
*/
public boolean requestQuota() {
long currentPeriod = getCurrentPeriod();
if (mLastPeriod < currentPeriod) {
mLastPeriod = currentPeriod;
mConsumedQuota = 0;
}
if (mConsumedQuota < mQuota) {
mConsumedQuota++;
return true;
}
return false;
}
private long getCurrentPeriod() {
return (mClock.getElapsedSinceBootMillis() - mStartTimeMillis) / mPeriodMillis;
}
@Override
public String toString() {
return "TimedQuotaManager{"
+ "mQuota=" + mQuota
+ ", mPeriodMillis=" + mPeriodMillis
+ ", mStartTimeMillis=" + mStartTimeMillis
+ ", mLastPeriod=" + mLastPeriod
+ ", mConsumedQuota=" + mConsumedQuota
+ '}';
}
}