2 * Copyright (c) 1995 - 2000 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
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.
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.
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
41 #ifdef TIME_WITH_SYS_TIME
44 #elif defined(HAVE_SYS_TIME_H)
70 #define WTMP_FILE _PATH_WTMP
72 #define WTMP_FILE "/var/adm/wtmp"
79 #ifndef ASL_KEY_FACILITY
80 #define ASL_KEY_FACILITY "Facility"
84 ftpd_logwtmp_asl(char *line, char *name, char *host)
86 static aslmsg m = NULL;
91 m = asl_new(ASL_TYPE_MSG);
94 asl_set(m, ASL_KEY_FACILITY, "org.h5l.ftpd");
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());
107 ftpd_logwtmp_wtmp(char *line, char *name, char *host)
117 #if defined(WTMPX_FILE) || defined(HAVE_UTMPX_H)
122 memset(&utx, 0, sizeof(struct utmpx));
125 memset(&ut, 0, sizeof(struct utmp));
126 #ifdef HAVE_STRUCT_UTMP_UT_TYPE
128 ut.ut_type = USER_PROCESS;
130 ut.ut_type = DEAD_PROCESS;
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();
137 #ifdef HAVE_STRUCT_UTMP_UT_HOST
138 strncpy(ut.ut_host, host, sizeof(ut.ut_host));
140 ut.ut_time = time(NULL);
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);
155 gettimeofday (&tv, 0);
156 utx.ut_tv.tv_sec = tv.tv_sec;
157 utx.ut_tv.tv_usec = tv.tv_usec;
161 utx.ut_type = USER_PROCESS;
163 utx.ut_type = DEAD_PROCESS;
172 fd = open(WTMP_FILE, O_WRONLY|O_APPEND, 0);
175 fdx = open(WTMPX_FILE, O_WRONLY|O_APPEND, 0);
181 write(fd, &ut, sizeof(struct utmp)); /* XXX */
184 write(fdx, &utx, sizeof(struct utmpx));
189 #endif /* !HAVE_ASL_H */
192 ftpd_logwtmp(char *line, char *name, char *host)
195 ftpd_logwtmp_asl(line, name, host);
197 ftpd_logwtmp_wtmp(line, name, host);