summaryrefslogtreecommitdiff
path: root/mail/imap-uw/files/patch-ai
blob: 4eddf732315766a18a3e06a21a58b361d0396f40 (plain) (blame)
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
64
65
66
67
68
69
70
71
72
73
74
--- src/imapd/imapd.c.orig	Mon Oct  1 02:51:23 2001
+++ src/imapd/imapd.c	Mon Oct  1 02:52:59 2001
@@ -29,6 +29,12 @@
 #include "c-client.h"
 #include <sys/stat.h>
 
+#ifdef DRAC_AUTH
+#include <netinet/in.h>
+#include <arpa/inet.h>
+#include <stdlib.h>
+#endif /* DRAC_AUTH */
+
 
 #define CRLF PSOUT ("\015\012")	/* primary output terpri */
 
@@ -173,6 +179,12 @@
 
 /* Global storage */
 
+#ifdef DRAC_AUTH
+#define DRACTIMEOUT 10*60      /* check every 10 minutes */
+time_t lastdrac = 0;           /* time of last drac check */
+extern char *getenv ();
+#endif /* DRAC_AUTH */
+
 char *version = "2001.313";	/* version number of this server */
 time_t alerttime = 0;		/* time of last alert */
 time_t sysalerttime = 0;	/* time of last system alert */
@@ -1229,6 +1241,45 @@
 	      lasterror ());
       return;
     }
+
+#ifdef DRAC_AUTH
+    if (time (0) > lastdrac + DRACTIMEOUT)
+    {
+        FILE *dracconf;
+        char host[100];
+        char *drachost;
+        char *err;
+        char *p;
+
+        if ( (dracconf = fopen(ETC_DIR "/dracd.host", "r")) == NULL)
+        {
+          syslog (LOG_INFO, "dracd: error opening %s/dracd.host config file",ETC_DIR);
+          exit(1);
+        }
+
+        fgets(host, 100, dracconf);
+        p = strchr(host, '\n');
+        if(p != NULL)
+          *p = '\0';
+        fclose(dracconf);
+
+        if( drachost = (host) )
+        {
+            struct sockaddr_in sin;
+            int sinlen = sizeof (struct sockaddr_in);
+            char *client = getpeername (0,(struct sockaddr *) &sin,(void *) &sinlen) ?
+              "UNKNOWN" : inet_ntoa (sin.sin_addr);
+
+            lastdrac = time(0);
+
+            if (dracauth(drachost, inet_addr(client), &err) != 0)
+                syslog (LOG_INFO, err);
+            else
+                syslog (LOG_INFO, "dracd: authorized ip %s", client);
+        }
+    }
+#endif /* DRAC_AUTH */
+
 				/* change in number of messages? */
     if (existsquelled || (nmsgs != stream->nmsgs)) {
       PSOUT ("* ");