File: warning.c

package info (click to toggle)
netdiag 0.7-4
  • links: PTS
  • area: main
  • in suites: woody
  • size: 1,468 kB
  • ctags: 1,279
  • sloc: ansic: 12,973; makefile: 289; awk: 130; sh: 71
file content (63 lines) | stat: -rw-r--r-- 1,244 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#include "netwatch.h"
#include <syslog.h>
#include <stdio.h>

static FILE *tmpfp;
static char tmpname[256];
static char command[256];
static char warnto[256] = { 0 };
extern int mailflag;
extern int syslogflag;
extern char *version;
extern char userwarn[];

void printbuf(FILE *fp, unsigned char *buf)
{
	int i;
	/* Dump HEader */
	for (i=0;i<60;i++)
	{
		fprintf(fp," %2X",buf[i]);
		if (syslogflag) syslog(LOG_ALERT," %2X",buf[i]);
		if (i && !(i%16))
		{
			fprintf(fp,"\n");
			if (syslogflag) syslog(LOG_ALERT,"\n");
		}
	}
	fprintf(fp,"\n");
	if (syslogflag) syslog(LOG_ALERT,"\n");
	

}

void warning(char s[], unsigned char *buf)
{
	time_t dt;

	dt = time(0);
	tmpnam(tmpname);
	tmpfp = fopen(tmpname,"w");
	if (tmpfp)
	{
		fprintf(tmpfp,"******************************************\n");
		fprintf(tmpfp,"WARNING MESSAGE from Netwatch %s at %s\n",
			version,ctime(&dt));
		fprintf(tmpfp,"%s\n",s);
		if (syslogflag) syslog(LOG_ALERT,"%s\n",s);
		if (buf)
		{
			printbuf(tmpfp,buf);
		}
		fprintf(tmpfp,"******************************************\n");
		fclose(tmpfp);
		if (!warnto[0])
			strcpy(warnto,userwarn);
		if (warnto[0])
		{
			sprintf(command,"mail %s < %s&",warnto,tmpname);
			system(command);
		}
		unlink(tmpname);
	}
}