2024-06-19 15:06:14 +08:00
|
|
|
#pragma once
|
2024-04-10 11:40:26 +08:00
|
|
|
|
2024-04-21 11:30:41 +08:00
|
|
|
#ifdef __cplusplus
|
2024-04-10 11:40:26 +08:00
|
|
|
extern "C"
|
|
|
|
|
{
|
|
|
|
|
#endif
|
|
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
#include <stdint.h>
|
2024-08-01 11:40:00 +08:00
|
|
|
#include <stdio.h>
|
2024-05-17 19:10:28 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
#include "stellar/session.h"
|
2024-04-10 11:40:26 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
/******************************************************************************
|
|
|
|
|
* session set/get
|
|
|
|
|
******************************************************************************/
|
2024-04-10 11:40:26 +08:00
|
|
|
|
|
|
|
|
void session_init(struct session *sess);
|
2024-06-25 10:32:51 +08:00
|
|
|
|
|
|
|
|
// session ID
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_id(struct session *sess, uint64_t id);
|
2024-06-25 10:32:51 +08:00
|
|
|
uint64_t session_get_id(const struct session *sess);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session tuple
|
|
|
|
|
void session_set_tuple6(struct session *sess, const struct tuple6 *tuple);
|
2024-06-07 15:17:35 +08:00
|
|
|
const struct tuple6 *session_get_tuple6(const struct session *sess);
|
|
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session tuple direction
|
|
|
|
|
const char *session_get0_readable_addr(const struct session *sess);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session direction
|
2024-05-09 14:57:12 +08:00
|
|
|
void session_set_direction(struct session *sess, enum session_direction dir);
|
2024-06-25 10:32:51 +08:00
|
|
|
enum session_direction session_get_direction(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session flow direction
|
2024-05-16 17:05:45 +08:00
|
|
|
void session_set_current_flow_direction(struct session *sess, enum flow_direction dir);
|
2024-06-25 10:32:51 +08:00
|
|
|
enum flow_direction session_get_current_flow_direction(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session state
|
2024-05-20 11:12:24 +08:00
|
|
|
void session_set_current_state(struct session *sess, enum session_state state);
|
2024-06-25 10:32:51 +08:00
|
|
|
enum session_state session_get_current_state(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session type
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_type(struct session *sess, enum session_type type);
|
2024-06-25 10:32:51 +08:00
|
|
|
enum session_type session_get_type(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session seen duplicate traffic
|
2024-05-09 16:32:45 +08:00
|
|
|
void session_set_duplicate_traffic(struct session *sess);
|
2024-06-25 10:32:51 +08:00
|
|
|
int session_has_duplicate_traffic(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session closing reason
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_closing_reason(struct session *sess, enum closing_reason reason);
|
2024-06-25 10:32:51 +08:00
|
|
|
enum closing_reason session_get_closing_reason(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session stat
|
2024-05-09 14:57:12 +08:00
|
|
|
void session_inc_stat(struct session *sess, enum flow_direction dir, enum session_stat stat, uint64_t val);
|
2024-06-25 10:32:51 +08:00
|
|
|
uint64_t session_get_stat(const struct session *sess, enum flow_direction dir, enum session_stat stat);
|
|
|
|
|
|
|
|
|
|
// session timestamp
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_timestamp(struct session *sess, enum session_timestamp type, uint64_t value);
|
2024-06-25 10:32:51 +08:00
|
|
|
uint64_t session_get_timestamp(const struct session *sess, enum session_timestamp type);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session sids
|
2024-06-14 19:24:27 +08:00
|
|
|
void session_clear_sids(struct session *sess, enum flow_direction dir);
|
|
|
|
|
void session_set_sids(struct session *sess, enum flow_direction dir, const struct sids *sids);
|
|
|
|
|
const struct sids *session_get_sids(const struct session *sess, enum flow_direction dir);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session route ctx
|
2024-05-09 14:57:12 +08:00
|
|
|
void session_clear_route_ctx(struct session *sess, enum flow_direction dir);
|
|
|
|
|
void session_set_route_ctx(struct session *sess, enum flow_direction dir, const struct route_ctx *ctx);
|
2024-06-14 19:24:27 +08:00
|
|
|
const struct route_ctx *session_get_route_ctx(const struct session *sess, enum flow_direction dir);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session first packet
|
2024-05-09 14:57:12 +08:00
|
|
|
void session_set_first_packet(struct session *sess, enum flow_direction dir, const struct packet *pkt);
|
2024-06-25 10:32:51 +08:00
|
|
|
const struct packet *session_get_first_packet(const struct session *sess, enum flow_direction dir);
|
|
|
|
|
|
|
|
|
|
// session current packet
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_current_packet(struct session *sess, const struct packet *pkt);
|
2024-06-25 10:32:51 +08:00
|
|
|
const struct packet *session_get0_current_packet(const struct session *sess);
|
|
|
|
|
|
|
|
|
|
// session symmetric
|
|
|
|
|
int session_is_symmetric(const struct session *sess, unsigned char *flag);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session user data
|
2024-04-10 11:40:26 +08:00
|
|
|
void session_set_user_data(struct session *sess, void *user_data);
|
|
|
|
|
void *session_get_user_data(const struct session *sess);
|
2024-05-09 14:57:12 +08:00
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
// session tcp segment
|
2024-04-10 11:40:26 +08:00
|
|
|
struct tcp_segment *session_get_tcp_segment(struct session *sess);
|
|
|
|
|
void session_free_tcp_segment(struct session *sess, struct tcp_segment *seg);
|
|
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
|
* session ex data
|
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
|
|
typedef void session_ex_free_cb(struct session *sess, uint8_t idx, void *ex_ptr, void *arg);
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* the exdata prodoced by user, and comsumed by same user.
|
|
|
|
|
* so, the exdata is not shared by different user.
|
|
|
|
|
* otherwise, the exdata need dup by refer count, and free by refer count.
|
|
|
|
|
*
|
|
|
|
|
* if key exist, not allow update, return original index.
|
|
|
|
|
*/
|
|
|
|
|
uint8_t session_get_ex_new_index(const char *key, session_ex_free_cb *free_cb, void *args);
|
2024-06-25 10:32:51 +08:00
|
|
|
|
2024-04-10 11:40:26 +08:00
|
|
|
/*
|
|
|
|
|
* Support update ex_data.
|
|
|
|
|
*
|
|
|
|
|
* if key exist: run free_cb free old value, then set new value.
|
|
|
|
|
* if not run free_cb, old value will be memory leak.
|
|
|
|
|
* if not allow update, new value will be memory leak.
|
|
|
|
|
* if key not exist: set new value.
|
|
|
|
|
*/
|
|
|
|
|
void session_set_ex_data(struct session *sess, uint8_t idx, void *val);
|
|
|
|
|
void *session_get0_ex_data(const struct session *sess, uint8_t idx);
|
|
|
|
|
/*
|
|
|
|
|
* after set ex_data, the owner of ex_data is session, so user should not free it directly.
|
|
|
|
|
* if user want to free ex_data, should use session_free_ex_data.
|
|
|
|
|
*/
|
|
|
|
|
void session_free_ex_data(struct session *sess, uint8_t idx);
|
|
|
|
|
void session_free_all_ex_data(struct session *sess);
|
|
|
|
|
|
|
|
|
|
/******************************************************************************
|
2024-06-25 10:32:51 +08:00
|
|
|
* to string
|
2024-04-10 11:40:26 +08:00
|
|
|
******************************************************************************/
|
|
|
|
|
|
2024-06-25 10:32:51 +08:00
|
|
|
const char *closing_reason_to_str(enum closing_reason reason);
|
2024-05-09 14:57:12 +08:00
|
|
|
const char *session_state_to_str(enum session_state state);
|
2024-06-25 10:32:51 +08:00
|
|
|
const char *session_type_to_str(enum session_type type);
|
2024-05-09 14:57:12 +08:00
|
|
|
const char *flow_direction_to_str(enum flow_direction dir);
|
2024-06-25 10:32:51 +08:00
|
|
|
|
2024-08-01 11:40:00 +08:00
|
|
|
// bref : 1, output session bref info
|
|
|
|
|
// bref : 0, output session detail info
|
|
|
|
|
int session_to_str(const struct session *sess, int bref, char *buff, int size);
|
|
|
|
|
|
|
|
|
|
static inline void session_print(const struct session *sess)
|
|
|
|
|
{
|
|
|
|
|
char buff[4096];
|
|
|
|
|
session_to_str(sess, 0, buff, sizeof(buff));
|
|
|
|
|
printf("%s\n", buff);
|
|
|
|
|
}
|
2024-04-10 11:40:26 +08:00
|
|
|
|
2024-04-21 11:30:41 +08:00
|
|
|
#ifdef __cplusplus
|
2024-04-10 11:40:26 +08:00
|
|
|
}
|
|
|
|
|
#endif
|