2 * Copyright (c) 1995 - 2001 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
34 #include "login_locl.h"
38 /* try to put something useful from hostname into dst, dst_sz:
39 * full name, first component or address */
42 shrink_hostname (const char *hostname
,
43 char *dst
, size_t dst_sz
)
45 char local_hostname
[MaxHostNameLen
];
50 if (strlen(hostname
) < dst_sz
) {
51 strlcpy (dst
, hostname
, dst_sz
);
54 gethostname (local_hostname
, sizeof(local_hostname
));
55 hd
= strchr (hostname
, '.');
56 ld
= strchr (local_hostname
, '.');
57 if (hd
!= NULL
&& ld
!= NULL
&& strcmp(hd
, ld
) == 0
58 && hd
- hostname
< dst_sz
) {
59 strlcpy (dst
, hostname
, dst_sz
);
60 dst
[hd
- hostname
] = '\0';
64 ret
= getaddrinfo (hostname
, NULL
, NULL
, &ai
);
66 strncpy (dst
, hostname
, dst_sz
);
69 ret
= getnameinfo (ai
->ai_addr
, ai
->ai_addrlen
,
75 strncpy (dst
, hostname
, dst_sz
);
81 void utmp_login(char *tty
, const char *username
, const char *hostname
)
87 /* update utmp and wtmp - the BSD way */
90 prepare_utmp (struct utmp
*utmp
, char *tty
,
91 const char *username
, const char *hostname
)
93 char *ttyx
= clean_ttyname (tty
);
95 memset(utmp
, 0, sizeof(*utmp
));
96 utmp
->ut_time
= time(NULL
);
97 strncpy(utmp
->ut_line
, ttyx
, sizeof(utmp
->ut_line
));
98 strncpy(utmp
->ut_name
, username
, sizeof(utmp
->ut_name
));
100 # ifdef HAVE_STRUCT_UTMP_UT_USER
101 strncpy(utmp
->ut_user
, username
, sizeof(utmp
->ut_user
));
104 # ifdef HAVE_STRUCT_UTMP_UT_ADDR
107 if ((he
= gethostbyname(hostname
)))
108 memcpy(&utmp
->ut_addr
, he
->h_addr_list
[0],
109 sizeof(utmp
->ut_addr
));
113 # ifdef HAVE_STRUCT_UTMP_UT_HOST
114 shrink_hostname (hostname
, utmp
->ut_host
, sizeof(utmp
->ut_host
));
117 # ifdef HAVE_STRUCT_UTMP_UT_TYPE
118 utmp
->ut_type
= USER_PROCESS
;
121 # ifdef HAVE_STRUCT_UTMP_UT_PID
122 utmp
->ut_pid
= getpid();
125 # ifdef HAVE_STRUCT_UTMP_UT_ID
126 strncpy(utmp
->ut_id
, make_id(ttyx
), sizeof(utmp
->ut_id
));
130 void utmp_login(char *tty
, const char *username
, const char *hostname
)
135 prepare_utmp (&utmp
, tty
, username
, hostname
);
138 utmpname(_PATH_UTMP
);
148 if (ttyno
> 0 && (fd
= open(_PATH_UTMP
, O_WRONLY
, 0)) >= 0) {
149 lseek(fd
, (long)(ttyno
* sizeof(struct utmp
)), SEEK_SET
);
150 write(fd
, &utmp
, sizeof(struct utmp
));
154 #endif /* HAVE_TTYSLOT */
155 #endif /* HAVE_SETUTENT */
157 if ((fd
= open(_PATH_WTMP
, O_WRONLY
|O_APPEND
, 0)) >= 0) {
158 write(fd
, &utmp
, sizeof(struct utmp
));
163 #endif /* !HAVE_UTMPX_H */