dns.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. /*************************************************************************
  2. *
  3. * Copyright (C) 2018-2024 Ruilin Peng (Nick) <[email protected]>.
  4. *
  5. * smartdns is free software: you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation, either version 3 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * smartdns is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. #ifndef _DNS_HEAD_H
  19. #define _DNS_HEAD_H
  20. #ifdef __cplusplus
  21. extern "C" {
  22. #endif /*__cplusplus */
  23. #define DNS_RR_A_LEN 4
  24. #define DNS_RR_AAAA_LEN 16
  25. #define DNS_MAX_CNAME_LEN 256
  26. #define DNS_MAX_OPT_LEN 256
  27. #define DNS_IN_PACKSIZE (512 * 8)
  28. #define DNS_PACKSIZE (512 * 16)
  29. #define DNS_DEFAULT_PACKET_SIZE 512
  30. #define DNS_MAX_ALPN_LEN 32
  31. #define DNS_MAX_ECH_LEN 256
  32. #define DNS_OPT_FLAG_DO 0x8000
  33. #define DNS_ADDR_FAMILY_IP 1
  34. #define DNS_ADDR_FAMILY_IPV6 2
  35. /*
  36. DNS parameters:
  37. https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml
  38. */
  39. typedef enum dns_qr {
  40. DNS_QR_QUERY = 0,
  41. DNS_QR_ANSWER = 1,
  42. } dns_qr;
  43. typedef enum dns_rr_type {
  44. DNS_RRS_QD = 0,
  45. DNS_RRS_AN = 1,
  46. DNS_RRS_NS = 2,
  47. DNS_RRS_NR = 3,
  48. DNS_RRS_OPT = 4,
  49. DNS_RRS_END,
  50. } dns_rr_type;
  51. typedef enum dns_class {
  52. DNS_C_IN = 1, // DNS C IN
  53. DNS_C_ANY = 255
  54. } dns_class_t;
  55. typedef enum dns_type {
  56. DNS_T_A = 1,
  57. DNS_T_NS = 2,
  58. DNS_T_CNAME = 5,
  59. DNS_T_SOA = 6,
  60. DNS_T_PTR = 12,
  61. DNS_T_MX = 15,
  62. DNS_T_TXT = 16,
  63. DNS_T_AAAA = 28,
  64. DNS_T_SRV = 33,
  65. DNS_T_OPT = 41,
  66. DNS_T_SSHFP = 44,
  67. DNS_T_SVCB = 64,
  68. DNS_T_HTTPS = 65,
  69. DNS_T_SPF = 99,
  70. DNS_T_AXFR = 252,
  71. DNS_T_ALL = 255
  72. } dns_type_t;
  73. typedef enum dns_opt_code {
  74. DNS_OPT_T_ECS = 8, // OPT ECS
  75. DNS_OPT_T_COOKIE = 10, // OPT Cookie
  76. DNS_OPT_T_TCP_KEEPALIVE = 11,
  77. DNS_OPT_T_PADDING = 12,
  78. DNS_OPT_T_ALL = 255
  79. } dns_opt_code_t;
  80. /* https://datatracker.ietf.org/doc/draft-ietf-dnsop-svcb-https/11/ */
  81. typedef enum dns_https_svcparam {
  82. DNS_HTTPS_T_MANDATORY = 0,
  83. DNS_HTTPS_T_ALPN = 1,
  84. DNS_HTTPS_T_NO_DEFAULT_ALPN = 2,
  85. DNS_HTTPS_T_PORT = 3,
  86. DNS_HTTPS_T_IPV4HINT = 4,
  87. DNS_HTTPS_T_ECH = 5,
  88. DNS_HTTPS_T_IPV6HINT = 6,
  89. DNS_HTTPS_T_ALL = 255
  90. } dns_https_svcparam_t;
  91. typedef enum dns_opcode {
  92. DNS_OP_QUERY = 0,
  93. DNS_OP_IQUERY = 1,
  94. DNS_OP_STATUS = 2,
  95. DNS_OP_NOTIFY = 4,
  96. DNS_OP_UPDATE = 5,
  97. } dns_opcode_t; /* dns_opcode */
  98. typedef enum dns_rtcode {
  99. DNS_RC_NOERROR = 0,
  100. DNS_RC_FORMERR = 1,
  101. DNS_RC_SERVFAIL = 2,
  102. DNS_RC_NXDOMAIN = 3,
  103. DNS_RC_NOTIMP = 4,
  104. DNS_RC_REFUSED = 5,
  105. DNS_RC_YXDOMAIN = 6,
  106. DNS_RC_YXRRSET = 7,
  107. DNS_RC_NXRRSET = 8,
  108. DNS_RC_NOTAUTH = 9,
  109. DNS_RC_NOTZONE = 10,
  110. /* EDNS(0) extended RCODEs */
  111. DNS_RC_BADVERS = 16,
  112. } dns_rtcode_t; /* dns_rcode */
  113. /* dns packet head */
  114. struct dns_head {
  115. unsigned short id; /* identification number */
  116. unsigned short qr; /* Query/Response Flag */
  117. unsigned short opcode; /* Operation Code */
  118. unsigned char aa; /* Authoritative Answer Flag */
  119. unsigned char tc; /* Truncation Flag */
  120. unsigned char rd; /* Recursion Desired */
  121. unsigned char ra; /* Recursion Available */
  122. unsigned char z; /* Reserved for future use. Must be Zero! */
  123. unsigned char ad; /* Authentic Data Flag */
  124. unsigned char cd; /* Checking Disabled Flag */
  125. unsigned char padding; /* Padding */
  126. unsigned short rcode; /* Response Code */
  127. unsigned short qdcount; /* number of question entries */
  128. unsigned short ancount; /* number of answer entries */
  129. unsigned short nscount; /* number of authority entries */
  130. unsigned short nrcount; /* number of additional resource entries */
  131. } __attribute__((packed, aligned(2)));
  132. #define DNS_PACKET_DICT_SIZE 16
  133. struct dns_packet_dict_item {
  134. unsigned short pos;
  135. unsigned int hash;
  136. } __attribute__((packed));
  137. struct dns_packet_dict {
  138. short dict_count;
  139. struct dns_packet_dict_item names[DNS_PACKET_DICT_SIZE];
  140. } __attribute__((packed));
  141. /* packet head */
  142. struct dns_packet {
  143. struct dns_head head;
  144. unsigned short questions;
  145. unsigned short answers;
  146. unsigned short nameservers;
  147. unsigned short additional;
  148. unsigned short optcount;
  149. unsigned short optional;
  150. unsigned short payloadsize;
  151. unsigned int opt_option;
  152. struct dns_packet_dict namedict;
  153. int size;
  154. int len;
  155. unsigned char data[0];
  156. };
  157. struct dns_rrs {
  158. struct dns_packet *packet;
  159. unsigned short next;
  160. unsigned short len;
  161. int type;
  162. unsigned char data[0];
  163. } __attribute__((packed));
  164. /* packet encode/decode context */
  165. struct dns_context {
  166. struct dns_packet *packet;
  167. struct dns_packet_dict *namedict;
  168. unsigned char *data;
  169. int maxsize;
  170. unsigned char *ptr;
  171. };
  172. /* SOA data */
  173. struct dns_soa {
  174. char mname[DNS_MAX_CNAME_LEN];
  175. char rname[DNS_MAX_CNAME_LEN];
  176. unsigned int serial;
  177. unsigned int refresh;
  178. unsigned int retry;
  179. unsigned int expire;
  180. unsigned int minimum;
  181. } __attribute__((packed));
  182. #define DNS_OPT_ECS_FAMILY_IPV4 1
  183. #define DNS_OPT_ECS_FAMILY_IPV6 2
  184. /* OPT ECS */
  185. struct dns_opt_ecs {
  186. unsigned short family;
  187. unsigned char source_prefix;
  188. unsigned char scope_prefix;
  189. unsigned char addr[DNS_RR_AAAA_LEN];
  190. } __attribute__((packed));
  191. /* OPT COOKIE */
  192. struct dns_opt_cookie {
  193. char server_cookie_len;
  194. unsigned char client_cookie[8];
  195. unsigned char server_cookie[32];
  196. };
  197. /* OPT */
  198. struct dns_opt {
  199. unsigned short code;
  200. unsigned short length;
  201. unsigned char data[0];
  202. } __attribute__((packed));
  203. struct dns_rr_nested {
  204. struct dns_context context;
  205. unsigned char *rr_start;
  206. unsigned char *rr_len_ptr;
  207. unsigned short rr_head_len;
  208. dns_rr_type type;
  209. };
  210. struct dns_https_param {
  211. unsigned short key;
  212. unsigned short len;
  213. unsigned char value[0];
  214. };
  215. struct dns_rrs *dns_get_rrs_next(struct dns_packet *packet, struct dns_rrs *rrs);
  216. struct dns_rrs *dns_get_rrs_start(struct dns_packet *packet, dns_rr_type type, int *count);
  217. struct dns_rr_nested *dns_add_rr_nested_start(struct dns_rr_nested *rr_nested_buffer, struct dns_packet *packet,
  218. dns_rr_type type, dns_type_t rtype, const char *domain, int ttl);
  219. int dns_add_rr_nested_end(struct dns_rr_nested *rr_nested, dns_type_t rtype);
  220. int dns_add_rr_nested_memcpy(struct dns_rr_nested *rr_nested, const void *data, int data_len);
  221. void *dns_get_rr_nested_start(struct dns_rrs *rrs, char *domain, int maxsize, int *qtype, int *ttl, int *rr_len);
  222. void *dns_get_rr_nested_next(struct dns_rrs *rrs, void *rr_nested, int rr_nested_len);
  223. /*
  224. * Question
  225. */
  226. int dns_add_domain(struct dns_packet *packet, const char *domain, int qtype, int qclass);
  227. int dns_get_domain(struct dns_rrs *rrs, char *domain, int maxsize, int *qtype, int *qclass);
  228. /*
  229. * Answers
  230. */
  231. int dns_add_CNAME(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, const char *cname);
  232. int dns_get_CNAME(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, char *cname, int cname_size);
  233. int dns_add_A(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl,
  234. unsigned char addr[DNS_RR_A_LEN]);
  235. int dns_get_A(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, unsigned char addr[DNS_RR_A_LEN]);
  236. int dns_add_PTR(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, const char *cname);
  237. int dns_get_PTR(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, char *cname, int cname_size);
  238. int dns_add_TXT(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, const char *text);
  239. int dns_get_TXT(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, char *text, int txt_size);
  240. int dns_add_AAAA(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl,
  241. unsigned char addr[DNS_RR_AAAA_LEN]);
  242. int dns_get_AAAA(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, unsigned char addr[DNS_RR_AAAA_LEN]);
  243. int dns_add_SOA(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, struct dns_soa *soa);
  244. int dns_get_SOA(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, struct dns_soa *soa);
  245. int dns_add_NS(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, const char *cname);
  246. int dns_get_NS(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, char *cname, int cname_size);
  247. int dns_set_OPT_option(struct dns_packet *packet, unsigned int option);
  248. unsigned int dns_get_OPT_option(struct dns_packet *packet);
  249. int dns_set_OPT_payload_size(struct dns_packet *packet, int payload_size);
  250. int dns_get_OPT_payload_size(struct dns_packet *packet);
  251. int dns_add_OPT_ECS(struct dns_packet *packet, struct dns_opt_ecs *ecs);
  252. int dns_get_OPT_ECS(struct dns_rrs *rrs, struct dns_opt_ecs *ecs);
  253. int dns_add_OPT_TCP_KEEPALIVE(struct dns_packet *packet, unsigned short timeout);
  254. int dns_get_OPT_TCP_KEEPALIVE(struct dns_rrs *rrs, unsigned short *timeout);
  255. int dns_add_SRV(struct dns_packet *packet, dns_rr_type type, const char *domain, int ttl, int priority, int weight,
  256. int port, const char *target);
  257. int dns_get_SRV(struct dns_rrs *rrs, char *domain, int maxsize, int *ttl, unsigned short *priority,
  258. unsigned short *weight, unsigned short *port, char *target, int target_size);
  259. /* the key must be added in orders, or dig will report FORMERR */
  260. int dns_add_HTTPS_start(struct dns_rr_nested *svcparam_buffer, struct dns_packet *packet, dns_rr_type type,
  261. const char *domain, int ttl, int priority, const char *target);
  262. int dns_HTTPS_add_raw(struct dns_rr_nested *svcparam, unsigned short key, unsigned char *value, unsigned short len);
  263. /* key 1, alph */
  264. int dns_HTTPS_add_alpn(struct dns_rr_nested *svcparam, const char *alpn, int alpn_len);
  265. /* key 2, no default alph */
  266. int dns_HTTPS_add_no_default_alpn(struct dns_rr_nested *svcparam);
  267. /* key 3, port */
  268. int dns_HTTPS_add_port(struct dns_rr_nested *svcparam, unsigned short port);
  269. /* key 4, ipv4 */
  270. int dns_HTTPS_add_ipv4hint(struct dns_rr_nested *svcparam, unsigned char *addr[], int addr_num);
  271. /* key 5, ech */
  272. int dns_HTTPS_add_ech(struct dns_rr_nested *svcparam, void *ech, int ech_len);
  273. /* key 6, ipv6*/
  274. int dns_HTTPS_add_ipv6hint(struct dns_rr_nested *svcparam, unsigned char *addr[], int addr_num);
  275. int dns_add_HTTPS_end(struct dns_rr_nested *svcparam);
  276. int dns_get_HTTPS_svcparm_start(struct dns_rrs *rrs, struct dns_https_param **https_param, char *domain, int maxsize,
  277. int *ttl, int *priority, char *target, int target_size);
  278. struct dns_https_param *dns_get_HTTPS_svcparm_next(struct dns_rrs *rrs, struct dns_https_param *param);
  279. /*
  280. * Packet operation
  281. */
  282. int dns_decode_head_only(struct dns_packet *packet, int maxsize, unsigned char *data, int size);
  283. int dns_decode(struct dns_packet *packet, int maxsize, unsigned char *data, int size);
  284. int dns_encode(unsigned char *data, int size, struct dns_packet *packet);
  285. int dns_packet_init(struct dns_packet *packet, int size, struct dns_head *head);
  286. struct dns_update_param {
  287. int id;
  288. int ip_ttl;
  289. int cname_ttl;
  290. };
  291. int dns_packet_update(unsigned char *data, int size, struct dns_update_param *param);
  292. #ifdef __cplusplus
  293. }
  294. #endif /*__cplusplus */
  295. #endif