ff3512a77e
f785959eace chore: add to_string functions for netprof enums a95b7957288 cleanup: Heap allocate network profile objects a3c80149edd feat: Implement Tox network profiler ac812871a2e feat: implement the last 2 missing network struct functions and make use of them 29d1043be0b test: friend request test now tests min/max message sizes 93aafd78c1f fix: friend requests with very long messages are no longer dropped 819aa2b2618 feat: Add option to disable DNS lookups in toxcore. 0ac23cee035 fix: windows use of REUSEADDR 7d2811d302d chore(ci): make bazel server shutdown faster 1dc399ba20d chore: Use vcpkg instead of conan in the MSVC build. 14d823165d9 chore: Migrate to conan 2. bdd17c16787 cleanup: Allocate logger using tox memory allocator. b396c061515 chore(deps): bump third_party/cmp from `2ac6bca` to `52bfcfa` 2e94da60d09 feat(net): add missing connect to network struct 41fb1839c7b chore: Add check to ensure version numbers agree. 934a8301113 chore: Release 0.2.20 3acef4bf044 fix: Add missing free in dht_get_nodes_response event. git-subtree-dir: external/toxcore/c-toxcore git-subtree-split: f785959eacebc59590f756b133b52601c335a1d1
74 lines
2.1 KiB
C
74 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-3.0-or-later
|
|
* Copyright © 2023-2024 The TokTok team.
|
|
*/
|
|
|
|
/**
|
|
* Functions for the network profile.
|
|
*/
|
|
#ifndef C_TOXCORE_TOXCORE_NET_PROFILE_H
|
|
#define C_TOXCORE_TOXCORE_NET_PROFILE_H
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
#include "attributes.h"
|
|
#include "logger.h"
|
|
#include "mem.h"
|
|
|
|
/* The max number of packet ID's (must fit inside one byte) */
|
|
#define NET_PROF_MAX_PACKET_IDS 256
|
|
|
|
/* If passed to a netprof function as a nullptr the function will have no effect. */
|
|
typedef struct Net_Profile Net_Profile;
|
|
|
|
/** Specifies whether the query is for sent or received packets. */
|
|
typedef enum Packet_Direction {
|
|
PACKET_DIRECTION_SEND,
|
|
PACKET_DIRECTION_RECV,
|
|
} Packet_Direction;
|
|
|
|
/**
|
|
* Records a sent or received packet of type `id` and size `length` to the given profile.
|
|
*/
|
|
nullable(1)
|
|
void netprof_record_packet(Net_Profile *profile, uint8_t id, size_t length, Packet_Direction dir);
|
|
|
|
/**
|
|
* Returns the number of sent or received packets of type `id` for the given profile.
|
|
*/
|
|
nullable(1)
|
|
uint64_t netprof_get_packet_count_id(const Net_Profile *profile, uint8_t id, Packet_Direction dir);
|
|
|
|
/**
|
|
* Returns the total number of sent or received packets for the given profile.
|
|
*/
|
|
nullable(1)
|
|
uint64_t netprof_get_packet_count_total(const Net_Profile *profile, Packet_Direction dir);
|
|
|
|
/**
|
|
* Returns the number of bytes sent or received of packet type `id` for the given profile.
|
|
*/
|
|
nullable(1)
|
|
uint64_t netprof_get_bytes_id(const Net_Profile *profile, uint8_t id, Packet_Direction dir);
|
|
|
|
/**
|
|
* Returns the total number of bytes sent or received for the given profile.
|
|
*/
|
|
nullable(1)
|
|
uint64_t netprof_get_bytes_total(const Net_Profile *profile, Packet_Direction dir);
|
|
|
|
/**
|
|
* Returns a new net_profile object. The caller is responsible for freeing the
|
|
* returned memory via `netprof_kill`.
|
|
*/
|
|
non_null()
|
|
Net_Profile *netprof_new(const Logger *log, const Memory *mem);
|
|
|
|
/**
|
|
* Kills a net_profile object and frees all associated memory.
|
|
*/
|
|
non_null(1) nullable(2)
|
|
void netprof_kill(const Memory *mem, Net_Profile *net_profile);
|
|
|
|
#endif /* C_TOXCORE_TOXCORE_NET_PROFILE_H */
|