/* SPDX-License-Identifier: GPL-3.0-or-later * Copyright © 2023-2025 The TokTok team. */ /** * Functions for the network profile. */ #ifndef C_TOXCORE_TOXCORE_NET_PROFILE_H #define C_TOXCORE_TOXCORE_NET_PROFILE_H #include #include #include "attributes.h" #include "logger.h" #include "mem.h" #ifdef __cplusplus extern "C" { #endif /* 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. */ void netprof_record_packet(Net_Profile *_Nullable 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. */ uint64_t netprof_get_packet_count_id(const Net_Profile *_Nullable profile, uint8_t id, Packet_Direction dir); /** * Returns the total number of sent or received packets for the given profile. */ uint64_t netprof_get_packet_count_total(const Net_Profile *_Nullable profile, Packet_Direction dir); /** * Returns the number of bytes sent or received of packet type `id` for the given profile. */ uint64_t netprof_get_bytes_id(const Net_Profile *_Nullable profile, uint8_t id, Packet_Direction dir); /** * Returns the total number of bytes sent or received for the given profile. */ uint64_t netprof_get_bytes_total(const Net_Profile *_Nullable profile, Packet_Direction dir); /** * Returns a new net_profile object. The caller is responsible for freeing the * returned memory via `netprof_kill`. */ Net_Profile *_Nullable netprof_new(const Logger *_Nonnull log, const Memory *_Nonnull mem); /** * Kills a net_profile object and frees all associated memory. */ void netprof_kill(const Memory *_Nonnull mem, Net_Profile *_Nullable net_profile); #ifdef __cplusplus } /* extern "C" */ #endif #endif /* C_TOXCORE_TOXCORE_NET_PROFILE_H */