]> CyberLeo.Net >> Repos - FreeBSD/releng/10.0.git/blob - crypto/heimdal/appl/ftp/ftpd/logwtmp.c
- Copy stable/10 (r259064) to releng/10.0 as part of the
[FreeBSD/releng/10.0.git] / crypto / heimdal / appl / ftp / ftpd / logwtmp.c
1 /*
2  * Copyright (c) 1995 - 2000 Kungliga Tekniska Högskolan
3  * (Royal Institute of Technology, Stockholm, Sweden).
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in the
15  *    documentation and/or other materials provided with the distribution.
16  *
17  * 3. Neither the name of the Institute nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31  * SUCH DAMAGE.
32  */
33
34 #ifdef HAVE_CONFIG_H
35 #include <config.h>
36 RCSID("$Id$");
37 #endif
38
39 #include <stdio.h>
40 #include <string.h>
41 #ifdef TIME_WITH_SYS_TIME
42 #include <sys/time.h>
43 #include <time.h>
44 #elif defined(HAVE_SYS_TIME_H)
45 #include <sys/time.h>
46 #else
47 #include <time.h>
48 #endif
49 #ifdef HAVE_UNISTD_H
50 #include <unistd.h>
51 #endif
52 #ifdef HAVE_FCNTL_H
53 #include <fcntl.h>
54 #endif
55 #ifdef HAVE_UTMP_H
56 #include <utmp.h>
57 #endif
58 #ifdef HAVE_UTMPX_H
59 #include <utmpx.h>
60 #endif
61 #ifdef HAVE_ASL_H
62 #include <asl.h>
63 #endif
64 #include <roken.h>
65 #include "extern.h"
66
67 #ifndef HAVE_UTMPX_H
68 #ifndef WTMP_FILE
69 #ifdef _PATH_WTMP
70 #define WTMP_FILE _PATH_WTMP
71 #else
72 #define WTMP_FILE "/var/adm/wtmp"
73 #endif
74 #endif
75 #endif
76
77 #ifdef HAVE_ASL_H
78
79 #ifndef ASL_KEY_FACILITY
80 #define ASL_KEY_FACILITY "Facility"
81 #endif
82
83 static void
84 ftpd_logwtmp_asl(char *line, char *name, char *host)
85 {
86     static aslmsg m = NULL;
87     static int init = 0;
88
89     if (!init) {
90         init = 1;
91         m = asl_new(ASL_TYPE_MSG);
92         if (m == NULL)
93             return;
94         asl_set(m, ASL_KEY_FACILITY, "org.h5l.ftpd");
95     }
96     if (m)
97         asl_log(NULL, m, ASL_LEVEL_NOTICE,
98                 "host %s/%s user %s%sconnected pid %d",
99                 host, line, name, name[0] ? " " : "dis", (int)getpid());
100 }
101
102 #endif
103
104 #ifndef HAVE_ASL_H
105
106 static void
107 ftpd_logwtmp_wtmp(char *line, char *name, char *host)
108 {
109     static int init = 0;
110     static int fd;
111 #ifdef WTMPX_FILE
112     static int fdx;
113 #endif
114 #ifdef HAVE_UTMP_H
115     struct utmp ut;
116 #endif
117 #if defined(WTMPX_FILE) || defined(HAVE_UTMPX_H)
118     struct utmpx utx;
119 #endif
120
121 #ifdef HAVE_UTMPX_H
122     memset(&utx, 0, sizeof(struct utmpx));
123 #endif
124 #ifdef HAVE_UTMP_H
125     memset(&ut, 0, sizeof(struct utmp));
126 #ifdef HAVE_STRUCT_UTMP_UT_TYPE
127     if(name[0])
128         ut.ut_type = USER_PROCESS;
129     else
130         ut.ut_type = DEAD_PROCESS;
131 #endif
132     strncpy(ut.ut_line, line, sizeof(ut.ut_line));
133     strncpy(ut.ut_name, name, sizeof(ut.ut_name));
134 #ifdef HAVE_STRUCT_UTMP_UT_PID
135     ut.ut_pid = getpid();
136 #endif
137 #ifdef HAVE_STRUCT_UTMP_UT_HOST
138     strncpy(ut.ut_host, host, sizeof(ut.ut_host));
139 #endif
140     ut.ut_time = time(NULL);
141 #endif
142
143 #if defined(WTMPX_FILE) || defined(HAVE_UTMPX_H)
144     strncpy(utx.ut_line, line, sizeof(utx.ut_line));
145     strncpy(utx.ut_user, name, sizeof(utx.ut_user));
146     strncpy(utx.ut_host, host, sizeof(utx.ut_host));
147 #ifdef HAVE_STRUCT_UTMPX_UT_SYSLEN
148     utx.ut_syslen = strlen(host) + 1;
149     if (utx.ut_syslen > sizeof(utx.ut_host))
150         utx.ut_syslen = sizeof(utx.ut_host);
151 #endif
152     {
153         struct timeval tv;
154
155         gettimeofday (&tv, 0);
156         utx.ut_tv.tv_sec = tv.tv_sec;
157         utx.ut_tv.tv_usec = tv.tv_usec;
158     }
159
160     if(name[0])
161         utx.ut_type = USER_PROCESS;
162     else
163         utx.ut_type = DEAD_PROCESS;
164 #endif
165
166 #ifdef HAVE_UTMPX_H
167     pututxline(&utx);
168 #endif
169
170     if(!init){
171 #ifdef WTMP_FILE
172         fd = open(WTMP_FILE, O_WRONLY|O_APPEND, 0);
173 #endif
174 #ifdef WTMPX_FILE
175         fdx = open(WTMPX_FILE, O_WRONLY|O_APPEND, 0);
176 #endif
177         init = 1;
178     }
179     if(fd >= 0) {
180 #ifdef WTMP_FILE
181         write(fd, &ut, sizeof(struct utmp)); /* XXX */
182 #endif
183 #ifdef WTMPX_FILE
184         write(fdx, &utx, sizeof(struct utmpx));
185 #endif
186     }
187 }
188
189 #endif /* !HAVE_ASL_H */
190
191 void
192 ftpd_logwtmp(char *line, char *name, char *host)
193 {
194 #ifdef HAVE_ASL_H
195     ftpd_logwtmp_asl(line, name, host);
196 #else
197     ftpd_logwtmp_wtmp(line, name, host);
198 #endif
199 }