summaryrefslogtreecommitdiffstats
path: root/net/gnu-finger/files/patch-ab
blob: 8aaf2aca77772963702c97e9e27d0222a5882402 (plain)
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
75
76
77
78
79
80
81
--- lib/os.c.orig	Mon Jan  6 22:09:06 1997
+++ lib/os.c	Mon Jan  6 22:08:34 1997
@@ -26,6 +26,8 @@
 #include <sys/acct.h>
 #include <time.h>
 #include <packet.h>
+#include <sys/socket.h>
+#include <netdb.h>
 
 #ifdef HAVE_UTMPX_H
 #include <utmpx.h>
@@ -70,8 +72,12 @@
 
 /* Where the utmp file is located. */
 #ifndef HAVE_GETUTENT
+#ifdef __FreeBSD__
+#define UTMP_FILE _PATH_UTMP
+#else
 #define UTMP_FILE "/etc/utmp"
 #endif
+#endif
 
 /* A non-null value is the address of the utmp entry which contains the
    information for the user using the console. */
@@ -288,6 +294,21 @@
     {
       idle = current_time - get_last_access (utmplist[i]->ut_line);
 
+#ifdef __FreeBSD__
+      /*
+       *    GNU finger lists two information of one user for one machine,
+       * (1. about login console, 2. tty which has smallest idling time.)
+       *  In listing algorithm, GNU finger server program [fingerd] uses
+       * `console' string in tty.
+       *
+       *   But FreeBSD uses `ttyv[0-3]' as console name.
+       *
+       *   So this patch is to translate `ttyv?' string to `console'
+       */
+      if (strstr (utmplist[i]->ut_line, "ttyv") != NULL) {
+	strcpy (utmplist[i]->ut_line, "console");
+      }
+#endif
       if (idle < 0)
 	idle = 0;
 
@@ -485,6 +506,7 @@
 
   UTMP **result;
   int result_size = 0;
+  struct hostent *hp; u_long l;
 
 #ifndef HAVE_GETUTENT
   file = open (UTMP_FILE, O_RDONLY);
@@ -528,6 +550,26 @@
       if (!UT (entry, ut_name)[0])
 	continue;
 #endif /* sun */
+
+#ifdef __FreeBSD__
+      /*
+       *   From src/usr.bin/login/login.c CVS log, after 2.2 source tree,
+       * login.c write numerical address to ut_host.
+       * (1.12 comment of login.c)
+       *
+       *   So this patch is to translate numerical address to hostname.
+       */
+      if (UT(entry, ut_host)[0]) {
+          if (isdigit(UT(entry, ut_host)[0]) && 
+              (long)(l = inet_addr(UT(entry, ut_host))) != -1 &&
+              (hp = gethostbyaddr((char *)&l, sizeof(l), AF_INET))) {
+              if (hp->h_name) {
+                  strncpy(UT(entry, ut_host), hp->h_name, UT_HOSTSIZE);
+                  UT(entry, ut_host)[UT_HOSTSIZE - 1] = '\0';
+              } /* valid hostname */
+          }  /* IP addr */
+      } /* UTMP */
+#endif
 
       for (i = 0; result[i]; i++)
 	{
OpenPOWER on IntegriCloud