2020-05-12 01:35:48 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c)2013-2020 ZeroTier, Inc.
|
|
|
|
*
|
|
|
|
* Use of this software is governed by the Business Source License included
|
|
|
|
* in the LICENSE.TXT file in the project's root directory.
|
|
|
|
*
|
2020-08-20 12:51:39 -07:00
|
|
|
* Change Date: 2025-01-01
|
2020-05-12 01:35:48 -07:00
|
|
|
*
|
|
|
|
* On the date above, in accordance with the Business Source License, use
|
|
|
|
* of this software will be governed by version 2.0 of the Apache License.
|
|
|
|
*/
|
|
|
|
/****/
|
|
|
|
|
|
|
|
#ifndef ZT_FLOW_HPP
|
|
|
|
#define ZT_FLOW_HPP
|
|
|
|
|
|
|
|
#include "Path.hpp"
|
|
|
|
#include "SharedPtr.hpp"
|
|
|
|
|
|
|
|
namespace ZeroTier {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A protocol flow that is identified by the origin and destination port.
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
struct Flow {
|
2020-05-14 20:09:25 -07:00
|
|
|
/**
|
|
|
|
* @param flowId Given flow ID
|
|
|
|
* @param now Current time
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
Flow(int32_t flowId, int64_t now) : _flowId(flowId), _bytesInPerUnitTime(0), _bytesOutPerUnitTime(0), _lastActivity(now), _lastPathReassignment(0), _assignedPath(SharedPtr<Path>())
|
|
|
|
{
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset flow statistics
|
|
|
|
*/
|
|
|
|
void resetByteCounts()
|
|
|
|
{
|
|
|
|
_bytesInPerUnitTime = 0;
|
|
|
|
_bytesOutPerUnitTime = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return The Flow's ID
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
int32_t id()
|
|
|
|
{
|
|
|
|
return _flowId;
|
|
|
|
}
|
2020-05-14 20:09:25 -07:00
|
|
|
|
2020-05-12 01:35:48 -07:00
|
|
|
/**
|
|
|
|
* @return Number of incoming bytes processed on this flow per unit time
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
int64_t bytesInPerUnitTime()
|
|
|
|
{
|
|
|
|
return _bytesInPerUnitTime;
|
|
|
|
}
|
2020-05-14 20:09:25 -07:00
|
|
|
|
2020-05-12 01:35:48 -07:00
|
|
|
/**
|
|
|
|
* Record number of incoming bytes on this flow
|
|
|
|
*
|
|
|
|
* @param bytes Number of incoming bytes
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
void recordIncomingBytes(uint64_t bytes)
|
|
|
|
{
|
|
|
|
_bytesInPerUnitTime += bytes;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Number of outgoing bytes processed on this flow per unit time
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
int64_t bytesOutPerUnitTime()
|
|
|
|
{
|
|
|
|
return _bytesOutPerUnitTime;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Record number of outgoing bytes on this flow
|
|
|
|
*
|
|
|
|
* @param bytes
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
void recordOutgoingBytes(uint64_t bytes)
|
|
|
|
{
|
|
|
|
_bytesOutPerUnitTime += bytes;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return The total number of bytes processed on this flow
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
uint64_t totalBytes()
|
|
|
|
{
|
|
|
|
return _bytesInPerUnitTime + _bytesOutPerUnitTime;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* How long since a packet was sent or received in this flow
|
|
|
|
*
|
|
|
|
* @param now Current time
|
|
|
|
* @return The age of the flow in terms of last recorded activity
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
int64_t age(int64_t now)
|
|
|
|
{
|
|
|
|
return now - _lastActivity;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Record that traffic was processed on this flow at the given time.
|
|
|
|
*
|
|
|
|
* @param now Current time
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
void updateActivity(int64_t now)
|
|
|
|
{
|
|
|
|
_lastActivity = now;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return Path assigned to this flow
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
SharedPtr<Path> assignedPath()
|
|
|
|
{
|
|
|
|
return _assignedPath;
|
|
|
|
}
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param path Assigned path over which this flow should be handled
|
|
|
|
*/
|
2021-05-03 17:59:31 -07:00
|
|
|
void assignPath(const SharedPtr<Path>& path, int64_t now)
|
|
|
|
{
|
2020-05-12 01:35:48 -07:00
|
|
|
_assignedPath = path;
|
|
|
|
_lastPathReassignment = now;
|
|
|
|
}
|
|
|
|
|
|
|
|
AtomicCounter __refCount;
|
|
|
|
|
|
|
|
int32_t _flowId;
|
|
|
|
uint64_t _bytesInPerUnitTime;
|
|
|
|
uint64_t _bytesOutPerUnitTime;
|
|
|
|
int64_t _lastActivity;
|
|
|
|
int64_t _lastPathReassignment;
|
|
|
|
SharedPtr<Path> _assignedPath;
|
2020-06-16 12:30:21 -07:00
|
|
|
SharedPtr<Path> _previouslyAssignedPath;
|
2020-05-12 01:35:48 -07:00
|
|
|
};
|
|
|
|
|
2021-05-03 17:59:31 -07:00
|
|
|
} // namespace ZeroTier
|
2020-05-12 01:35:48 -07:00
|
|
|
|
|
|
|
#endif
|