#ifndef LAIKA_PACKET_H #define LAIKA_PACKET_H #include #define LAIKA_MAGIC "LAI\x12" #define LAIKA_MAGICLEN 4 #define LAIKA_MAX_PKTSIZE 4096 #define LAIKA_HOSTNAME_LEN 64 #define LAIKA_IPV4_LEN 16 /* first handshake between peer & cnc works as so: - peer connects to cnc and sends a LAIKAPKT_HANDSHAKE_REQ with the peer's pubkey, hostname & inet ip - after cnc receives LAIKAPKT_HANDSHAKE_REQ, all packets are encrypted - cnc responds with LAIKAPKT_HANDSHAKE_RES - if peer is an authenticated client (panel), LAIKAPKT_AUTHENTICATED_HANDSHAKE_REQ is then sent */ /* encrypted packets are laid out like so: (any packet sent/received where peer->useSecure is true) LAIKAPKT_ID pktID; -- plain text uint8_t nonce[crypto_secretbox_NONCEBYTES]; -- plain text uint8_t body[pktSize + crypto_secretbox_MACBYTES]; -- encrypted with shared key & nonce */ enum { LAIKAPKT_HANDSHAKE_REQ, /* first packet sent by peer & received by cnc */ /* layout of LAIKAPKT_HANDSHAKE_REQ: * uint8_t laikaMagic[LAIKA_MAGICLEN]; -- LAIKA_MAGIC * uint8_t majorVer; * uint8_t minorVer; * uint8_t pubKey[crypto_kx_PUBLICKEYBYTES]; -- freshly generated pubKey to encrypt decrypted nonce with * char hostname[LAIKA_HOSTNAME_LEN]; -- can be empty (ie. all NULL bytes) * char ipv4[LAIKA_IPV4_LEN]; -- can be empty (ie. all NULL bytes) */ LAIKAPKT_HANDSHAKE_RES, /* layout of LAIKAPKT_HANDSHAKE_RES: * uint8_t cncEndian; */ LAIKAPKT_AUTHENTICATED_HANDSHAKE_REQ, /* second packet sent by authenticated peers (panel). there is no response packet */ /* layout of LAIKAPKT_STAGE2_HANDSHAKE_REQ * uint8_t peerType; */ LAIKAPKT_AUTHENTICATED_ADD_PEER, /* notification that a peer has connected to the cnc */ /* layout of LAIKAPKT_AUTHENTICATED_ADD_PEER * uint8_t pubKey[crypto_kx_PUBLICKEYBYTES]; -- pubkey of said bot * char hostname[LAIKA_HOSTNAME_LEN]; * char ipv4[LAIKA_IPV4_LEN]; * uint8_t peerType; */ LAIKAPKT_AUTHENTICATED_RMV_PEER, /* notification that a peer has disconnected from the cnc */ /* layout of LAIKAPKT_AUTHENTICATED_RMV_PEER * uint8_t pubKey[crypto_kx_PUBLICKEYBYTES]; -- pubkey of said bot * uint8_t peerType; */ LAIKAPKT_VARPKT_REQ, /* layout of LAIKAPKT_VARPKT_REQ: * LAIKAPKT_ID pktID; * LAIKAPKT_SIZE pktSize; */ LAIKAPKT_MAXNONE }; typedef uint8_t LAIKAPKT_ID; typedef uint16_t LAIKAPKT_SIZE; #endif