demo.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. #include "demo.h"
  2. #include "dns_server.h"
  3. #include "util.h"
  4. #include <arpa/inet.h>
  5. #include <netinet/in.h>
  6. #include <stdio.h>
  7. #include <sys/socket.h>
  8. #include <tlog.h>
  9. static int demo_server_recv(struct dns_packet *packet, unsigned char *inpacket, int inpacket_len,
  10. struct sockaddr_storage *local, socklen_t local_len, struct sockaddr_storage *from,
  11. socklen_t from_len)
  12. {
  13. char hostname[256] = {0};
  14. tlog(TLOG_INFO, "recv packet from %s", get_host_by_addr(hostname, sizeof(hostname), (struct sockaddr *)from));
  15. return 0;
  16. }
  17. static void demo_server_request_complete(struct dns_request *request)
  18. {
  19. tlog(TLOG_INFO, "server complete request, request domain is %s", dns_server_request_get_domain(request));
  20. }
  21. struct smartdns_operations demo_ops = {
  22. .server_recv = demo_server_recv,
  23. .server_query_complete = demo_server_request_complete,
  24. };
  25. int dns_plugin_init(struct dns_plugin *plugin)
  26. {
  27. char options[4096] = {0};
  28. int argc = dns_plugin_get_argc(plugin);
  29. const char **argv = dns_plugin_get_argv(plugin);
  30. for (int i = 0; i < argc; i++) {
  31. snprintf(options + strlen(options), sizeof(options) - strlen(options), "%s ", argv[i]);
  32. }
  33. tlog(TLOG_INFO, "demo plugin init, options: %s", options);
  34. smartdns_operations_register(&demo_ops);
  35. return 0;
  36. }
  37. int dns_plugin_exit(struct dns_plugin *plugin)
  38. {
  39. tlog(TLOG_INFO, "demo plugin exit.");
  40. smartdns_operations_unregister(&demo_ops);
  41. return 0;
  42. }