mdig: resolved and failed domain logs

This commit is contained in:
bol-van 2023-01-05 17:32:06 +03:00
parent 8e7ff486fe
commit 657a08cafa
11 changed files with 67 additions and 41 deletions

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -4,12 +4,9 @@
// errors, verbose >stderr // errors, verbose >stderr
// transparent for valid ip or ip/subnet of allowed address family // transparent for valid ip or ip/subnet of allowed address family
// can be compiled in mingw using posix thread compiler version
#define _GNU_SOURCE #define _GNU_SOURCE
#include <stdio.h> #include <stdio.h>
#include <stdint.h>
#include <stdarg.h> #include <stdarg.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
@ -17,18 +14,10 @@
#include <unistd.h> #include <unistd.h>
#include <pthread.h> #include <pthread.h>
#include <getopt.h> #include <getopt.h>
#ifdef _WIN32
#undef _WIN32_WINNT
#define _WIN32_WINNT 0x600
#include <winsock2.h>
#include <ws2ipdef.h>
#include <ws2tcpip.h>
#else
#include <sys/socket.h> #include <sys/socket.h>
#include <arpa/inet.h> #include <arpa/inet.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <netdb.h> #include <netdb.h>
#endif
#include <time.h> #include <time.h>
#define RESOLVER_EAGAIN_ATTEMPTS 2 #define RESOLVER_EAGAIN_ATTEMPTS 2
@ -67,10 +56,8 @@ static const char* eai_str(int r)
return "EAI_SERVICE"; return "EAI_SERVICE";
case EAI_SOCKTYPE: case EAI_SOCKTYPE:
return "EAI_SOCKTYPE"; return "EAI_SOCKTYPE";
#ifdef EAI_SYSTEM
case EAI_SYSTEM: case EAI_SYSTEM:
return "EAI_SYSTEM"; return "EAI_SYSTEM";
#endif
default: default:
return "UNKNOWN"; return "UNKNOWN";
} }
@ -102,6 +89,7 @@ static struct
pthread_mutex_t flock; pthread_mutex_t flock;
pthread_mutex_t slock; // stats lock pthread_mutex_t slock; // stats lock
int stats_every, stats_ct, stats_ct_ok; // stats int stats_every, stats_ct, stats_ct_ok; // stats
FILE *F_log_resolved, *F_log_failed;
} glob; } glob;
// get next domain. return 0 if failure // get next domain. return 0 if failure
@ -116,6 +104,8 @@ static char interlocked_get_dom(char *dom, size_t size)
return 1; return 1;
} }
static void interlocked_fprintf(FILE *stream, const char * format, ...) static void interlocked_fprintf(FILE *stream, const char * format, ...)
{
if (stream)
{ {
va_list args; va_list args;
va_start(args, format); va_start(args, format);
@ -124,6 +114,7 @@ static void interlocked_fprintf(FILE *stream, const char * format, ...)
pthread_mutex_unlock(&glob.flock); pthread_mutex_unlock(&glob.flock);
va_end(args); va_end(args);
} }
}
#define ELOG(format, ...) interlocked_fprintf(stderr, "[%d] " format "\n", tid, ##__VA_ARGS__) #define ELOG(format, ...) interlocked_fprintf(stderr, "[%d] " format "\n", tid, ##__VA_ARGS__)
#define VLOG(format, ...) {if (glob.verbose) ELOG(format, ##__VA_ARGS__);} #define VLOG(format, ...) {if (glob.verbose) ELOG(format, ##__VA_ARGS__);}
@ -255,11 +246,14 @@ static void *t_resolver(void *arg)
break; break;
} }
} }
else else if (glob.verbose)
{ {
invalid_domain_beautify(dom); char dom2[sizeof(dom)];
VLOG("invalid domain : %s", dom); strcpy(dom2,dom);
invalid_domain_beautify(dom2);
VLOG("invalid domain : %s", dom2);
} }
interlocked_fprintf(is_ok ? glob.F_log_resolved : glob.F_log_failed,"%s\n",dom);
} }
stat_plus(is_ok); stat_plus(is_ok);
} }
@ -319,23 +313,29 @@ static void exithelp()
" --family=<4|6|46>\t; ipv4, ipv6, ipv4+ipv6\n" " --family=<4|6|46>\t; ipv4, ipv6, ipv4+ipv6\n"
" --verbose\t\t; print query progress to stderr\n" " --verbose\t\t; print query progress to stderr\n"
" --stats=N\t\t; print resolve stats to stderr every N domains\n" " --stats=N\t\t; print resolve stats to stderr every N domains\n"
" --log-resolved=<file>\t; log successfully resolved domains to a file\n"
" --log-failed=<file>\t; log failed domains to a file\n"
); );
exit(1); exit(1);
} }
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
int v, option_index = 0; int r, v, option_index = 0;
char fn1[256],fn2[256];
static const struct option long_options[] = { static const struct option long_options[] = {
{"threads",required_argument,0,0}, // optidx=0 {"help",no_argument,0,0}, // optidx=0
{"family",required_argument,0,0}, // optidx=1 {"threads",required_argument,0,0}, // optidx=1
{"verbose",no_argument,0,0}, // optidx=2 {"family",required_argument,0,0}, // optidx=2
{"stats",required_argument,0,0}, // optidx=3 {"verbose",no_argument,0,0}, // optidx=3
{"help",no_argument,0,0}, // optidx=4 {"stats",required_argument,0,0}, // optidx=4
{"log-resolved",required_argument,0,0}, // optidx=5
{"log-failed",required_argument,0,0}, // optidx=6
{NULL,0,NULL,0} {NULL,0,NULL,0}
}; };
memset(&glob, 0, sizeof(glob)); memset(&glob, 0, sizeof(glob));
*fn1 = *fn2 = 0;
glob.family = FAMILY4; glob.family = FAMILY4;
glob.threads = 1; glob.threads = 1;
while ((v = getopt_long_only(argc, argv, "", long_options, &option_index)) != -1) while ((v = getopt_long_only(argc, argv, "", long_options, &option_index)) != -1)
@ -343,7 +343,10 @@ int main(int argc, char **argv)
if (v) exithelp(); if (v) exithelp();
switch (option_index) switch (option_index)
{ {
case 0: /* threads */ case 0: /* help */
exithelp();
break;
case 1: /* threads */
glob.threads = optarg ? atoi(optarg) : 0; glob.threads = optarg ? atoi(optarg) : 0;
if (glob.threads <= 0 || glob.threads > 100) if (glob.threads <= 0 || glob.threads > 100)
{ {
@ -351,7 +354,7 @@ int main(int argc, char **argv)
return 1; return 1;
} }
break; break;
case 1: /* family */ case 2: /* family */
if (!strcmp(optarg, "4")) if (!strcmp(optarg, "4"))
glob.family = FAMILY4; glob.family = FAMILY4;
else if (!strcmp(optarg, "6")) else if (!strcmp(optarg, "6"))
@ -364,24 +367,47 @@ int main(int argc, char **argv)
return 1;; return 1;;
} }
break; break;
case 2: /* verbose */ case 3: /* verbose */
glob.verbose = '\1'; glob.verbose = '\1';
break; break;
case 3: /* stats */ case 4: /* stats */
glob.stats_every = optarg ? atoi(optarg) : 0; glob.stats_every = optarg ? atoi(optarg) : 0;
break; break;
case 4: /* help */ case 5: /* log-resolved */
exithelp(); strncpy(fn1,optarg,sizeof(fn1));
fn1[sizeof(fn1)-1] = 0;
break;
case 6: /* log-failed */
strncpy(fn2,optarg,sizeof(fn2));
fn2[sizeof(fn2)-1] = 0;
break; break;
} }
} }
#ifdef _WIN32
WSADATA wsaData; if (*fn1)
if (WSAStartup(MAKEWORD(2, 2), &wsaData))
{ {
fprintf(stderr,"WSAStartup failed. error %u\n",GetLastError()); glob.F_log_resolved = fopen(fn1,"wt");
return 1; if (!glob.F_log_resolved)
{
fprintf(stderr,"failed to create %s\n",fn1);
r=5; goto ex;
} }
#endif }
return run_threads(); if (*fn2)
{
glob.F_log_failed = fopen(fn2,"wt");
if (!glob.F_log_failed)
{
fprintf(stderr,"failed to create %s\n",fn2);
r=5; goto ex;
}
}
r = run_threads();
ex:
if (glob.F_log_resolved) fclose(glob.F_log_resolved);
if (glob.F_log_failed) fclose(glob.F_log_failed);
return r;
} }