2024-07-30 20:10:00 +00:00
|
|
|
#ifndef YU_MANGLE_H
|
|
|
|
#define YU_MANGLE_H
|
2024-08-03 22:29:57 +00:00
|
|
|
|
2024-07-30 20:10:00 +00:00
|
|
|
#ifdef KERNEL_SPACE
|
|
|
|
#include <linux/types.h>
|
|
|
|
typedef __u8 uint8_t;
|
|
|
|
typedef __u32 uint32_t;
|
|
|
|
|
|
|
|
#include <linux/string.h>
|
|
|
|
#include <linux/errno.h>
|
|
|
|
#include <linux/stddef.h>
|
|
|
|
#include <linux/net.h>
|
|
|
|
#include <linux/in.h>
|
|
|
|
#include <linux/ip.h>
|
|
|
|
#include <linux/tcp.h>
|
|
|
|
|
|
|
|
#include <asm/byteorder.h>
|
|
|
|
|
2024-07-31 19:13:06 +00:00
|
|
|
/* from <netinet/ip.h> */
|
2024-07-30 20:10:00 +00:00
|
|
|
#define IP_RF 0x8000 /* reserved fragment flag */
|
|
|
|
#define IP_DF 0x4000 /* dont fragment flag */
|
|
|
|
#define IP_MF 0x2000 /* more fragments flag */
|
|
|
|
#define IP_OFFMASK 0x1fff /* mask for fragmenting bits */
|
|
|
|
#else
|
2024-08-03 22:29:57 +00:00
|
|
|
#define USER_SPACE
|
2024-07-30 20:10:00 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <arpa/inet.h>
|
|
|
|
#include <netinet/ip.h>
|
|
|
|
#include <netinet/tcp.h>
|
|
|
|
#endif
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Result of analyze_tls_data function
|
|
|
|
*/
|
|
|
|
struct tls_verdict {
|
2024-08-08 12:29:04 +00:00
|
|
|
int target_sni; /* google video hello packet */
|
2024-07-30 20:10:00 +00:00
|
|
|
int sni_offset; /* offset from start of tcp _payload_ */
|
|
|
|
int sni_len;
|
|
|
|
};
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Processes the packet and finds TLS Client Hello information inside it.
|
|
|
|
* data pointer points to start of TLS Message (TCP Payload)
|
|
|
|
*/
|
|
|
|
struct tls_verdict analyze_tls_data(const uint8_t *data, uint32_t dlen);
|
2024-07-30 20:10:00 +00:00
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Splits the packet to two IP fragments on position payload_offset.
|
|
|
|
* payload_offset indicates the position relatively to start of IP payload
|
|
|
|
* (start of transport header)
|
|
|
|
*/
|
2024-07-30 20:10:00 +00:00
|
|
|
int ip4_frag(const uint8_t *pkt, uint32_t pktlen,
|
|
|
|
uint32_t payload_offset,
|
|
|
|
uint8_t *frag1, uint32_t *f1len,
|
|
|
|
uint8_t *frag2, uint32_t *f2len);
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Splits the packet to two TCP segments on position payload_offset
|
|
|
|
* payload_offset indicates the position relatively to start of TCP payload.
|
|
|
|
*/
|
2024-07-30 20:10:00 +00:00
|
|
|
int tcp4_frag(const uint8_t *pkt, uint32_t pktlen,
|
|
|
|
uint32_t payload_offset,
|
|
|
|
uint8_t *seg1, uint32_t *s1len,
|
|
|
|
uint8_t *seg2, uint32_t *s2len);
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Splits the raw packet payload to ip header and ip payload.
|
|
|
|
*/
|
2024-07-30 20:10:00 +00:00
|
|
|
int ip4_payload_split(uint8_t *pkt, uint32_t buflen,
|
|
|
|
struct iphdr **iph, uint32_t *iph_len,
|
|
|
|
uint8_t **payload, uint32_t *plen);
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Splits the raw packet payload to ip header, tcp header and tcp payload.
|
|
|
|
*/
|
2024-07-30 20:10:00 +00:00
|
|
|
int tcp4_payload_split(uint8_t *pkt, uint32_t buflen,
|
|
|
|
struct iphdr **iph, uint32_t *iph_len,
|
|
|
|
struct tcphdr **tcph, uint32_t *tcph_len,
|
|
|
|
uint8_t **payload, uint32_t *plen);
|
2024-08-03 23:20:09 +00:00
|
|
|
|
2024-08-04 12:55:07 +00:00
|
|
|
void tcp4_set_checksum(struct tcphdr *tcph, struct iphdr *iph);
|
|
|
|
void ip4_set_checksum(struct iphdr *iph);
|
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Generates fake client hello message
|
|
|
|
*/
|
2024-08-03 23:20:09 +00:00
|
|
|
int gen_fake_sni(const struct iphdr *iph, const struct tcphdr *tcph,
|
|
|
|
uint8_t *buf, uint32_t *buflen);
|
2024-08-10 23:10:18 +00:00
|
|
|
|
2024-08-11 08:40:13 +00:00
|
|
|
/**
|
|
|
|
* Invalidates the raw packet. The function aims to invalid the packet
|
|
|
|
* in such way as it will be accepted by DPI, but dropped by target server
|
|
|
|
*/
|
2024-08-10 23:10:18 +00:00
|
|
|
int fail4_packet(uint8_t *payload, uint32_t plen);
|
|
|
|
|
|
|
|
#define PKT_ACCEPT 0
|
|
|
|
#define PKT_DROP 1
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Processes the packet and returns verdict.
|
|
|
|
* This is the primary function that traverses the packet.
|
|
|
|
*/
|
|
|
|
int process_packet(const uint8_t *packet, uint32_t packet_len);
|
2024-08-11 21:23:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sends fake client hello.
|
|
|
|
*/
|
|
|
|
int post_fake_sni(const struct iphdr *iph, unsigned int iph_len,
|
|
|
|
const struct tcphdr *tcph, unsigned int tcph_len,
|
|
|
|
unsigned char sequence_len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Splits packet by poses and posts.
|
|
|
|
* Poses are relative to start of TCP payload.
|
|
|
|
* dvs used internally and should be zero.
|
|
|
|
*/
|
|
|
|
int send_tcp4_frags(
|
|
|
|
const uint8_t *packet, uint32_t pktlen,
|
|
|
|
const uint32_t *poses, uint32_t poses_len, uint32_t dvs);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Splits packet by poses and posts.
|
|
|
|
* Poses are relative to start of TCP payload.
|
|
|
|
* dvs used internally and should be zero.
|
|
|
|
*/
|
|
|
|
int send_ip4_frags(
|
|
|
|
const uint8_t *packet, uint32_t pktlen,
|
|
|
|
const uint32_t *poses, uint32_t poses_len, uint32_t dvs);
|
2024-07-30 20:10:00 +00:00
|
|
|
#endif /* YU_MANGLE_H */
|