/* * 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 + '}'; } }