mirror of
https://github.com/falcosecurity/falco.git
synced 2025-10-22 12:27:10 +00:00
Signed-off-by: Lorenzo Fontana <lo@linux.com> Co-authored-by: Leonardo Di Donato <leodidonato@gmail.com>
81 lines
1.9 KiB
C++
81 lines
1.9 KiB
C++
/*
|
|
Copyright (C) 2016-2018 Draios Inc dba Sysdig.
|
|
|
|
This file is part of falco.
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <cstdint>
|
|
#include <functional>
|
|
|
|
// A simple token bucket that accumulates tokens at a fixed rate and allows
|
|
// for limited bursting in the form of "banked" tokens.
|
|
class token_bucket
|
|
{
|
|
public:
|
|
token_bucket();
|
|
token_bucket(std::function<uint64_t()> timer);
|
|
virtual ~token_bucket();
|
|
|
|
//
|
|
// Initialize the token bucket and start accumulating tokens
|
|
//
|
|
void init(double rate, double max_tokens, uint64_t now = 0);
|
|
|
|
//
|
|
// Try to claim tokens tokens from the token bucket, using a
|
|
// timestamp of now. Returns true if the tokens could be
|
|
// claimed. Also updates internal metrics.
|
|
//
|
|
bool claim(double tokens, uint64_t now);
|
|
|
|
// Simpler version of claim that claims a single token and
|
|
// uses the current time for now
|
|
bool claim();
|
|
|
|
// Return the current number of tokens available
|
|
double get_tokens();
|
|
|
|
// Return the last time someone tried to claim a token.
|
|
uint64_t get_last_seen();
|
|
|
|
private:
|
|
std::function<uint64_t()> m_timer;
|
|
|
|
//
|
|
// The number of tokens generated per second.
|
|
//
|
|
double m_rate;
|
|
|
|
//
|
|
// The maximum number of tokens that can be banked for future
|
|
// claim()s.
|
|
//
|
|
double m_max_tokens;
|
|
|
|
//
|
|
// The current number of tokens
|
|
//
|
|
double m_tokens;
|
|
|
|
//
|
|
// The last time claim() was called (or the object was created).
|
|
// Nanoseconds since the epoch.
|
|
//
|
|
uint64_t m_last_seen;
|
|
};
|