sortix-mirror/libc/unistd/getlogin_r.c

60 lines
1.9 KiB
C
Raw Normal View History

2013-04-15 22:08:33 +00:00
/*******************************************************************************
Copyright(C) Jonas 'Sortie' Termansen 2013.
This file is part of the Sortix C Library.
The Sortix C Library is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or (at your
option) any later version.
The Sortix C Library is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
License for more details.
You should have received a copy of the GNU Lesser General Public License
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
2016-02-28 11:11:02 +00:00
unistd/getlogin_r.c
2013-10-02 09:02:29 +00:00
Get name of user logged in at the controlling terminal.
2013-04-15 22:08:33 +00:00
*******************************************************************************/
#include <errno.h>
2013-10-02 09:02:29 +00:00
#include <pwd.h>
2013-04-15 22:08:33 +00:00
#include <stdlib.h>
#include <string.h>
2013-10-02 09:02:29 +00:00
#include <unistd.h>
2013-04-15 22:08:33 +00:00
2016-02-28 11:11:02 +00:00
int getlogin_r(char* buf, size_t size)
2013-04-15 22:08:33 +00:00
{
2013-10-02 09:02:29 +00:00
struct passwd passwd_object;
struct passwd* passwd;
int errnum = 0;
char* pwdbuf = NULL;
size_t pwdbuflen = 0;
do
{
2015-02-04 16:07:13 +00:00
// TODO: Potential overflow.
2013-10-02 09:02:29 +00:00
size_t new_pwdbuflen = pwdbuflen ? 2 * pwdbuflen : 64;
2014-02-05 22:22:28 +00:00
char* new_pwdbuf = (char*) realloc(pwdbuf, new_pwdbuflen);
2013-10-02 09:02:29 +00:00
if ( !new_pwdbuf )
return free(pwdbuf), -1;
pwdbuf = new_pwdbuf;
pwdbuflen = new_pwdbuflen;
} while ( (errnum = getpwuid_r(getuid(), &passwd_object, pwdbuf, pwdbuflen,
&passwd)) == ERANGE );
if ( errnum )
return free(pwdbuf), errno = errnum, -1;
const char* username = passwd->pw_name;
2015-02-04 16:07:13 +00:00
if ( size <= strlcpy(buf, username, size) )
2013-10-02 09:02:29 +00:00
return free(pwdbuf), errno = ERANGE, -1;
2015-02-04 16:07:13 +00:00
free(pwdbuf);
2013-10-02 09:02:29 +00:00
2013-04-15 22:08:33 +00:00
return 0;
}