mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-27 13:53:31 +01:00
Add a tor_getpass to read passphrases. Needs better backend.
This commit is contained in:
parent
1b52e95028
commit
cbdf2c5d8f
@ -386,6 +386,7 @@ AC_CHECK_FUNCS(
|
||||
ftime \
|
||||
getaddrinfo \
|
||||
getifaddrs \
|
||||
getpass \
|
||||
getrlimit \
|
||||
gettimeofday \
|
||||
gmtime_r \
|
||||
@ -399,6 +400,7 @@ AC_CHECK_FUNCS(
|
||||
pipe \
|
||||
pipe2 \
|
||||
prctl \
|
||||
readpassphrase \
|
||||
rint \
|
||||
sigaction \
|
||||
socketpair \
|
||||
@ -926,6 +928,7 @@ AC_CHECK_HEADERS(
|
||||
netinet/in.h \
|
||||
netinet/in6.h \
|
||||
pwd.h \
|
||||
readpassphrase.h \
|
||||
stdint.h \
|
||||
sys/eventfd.h \
|
||||
sys/file.h \
|
||||
|
@ -67,6 +67,9 @@
|
||||
#ifdef HAVE_CRT_EXTERNS_H
|
||||
#include <crt_externs.h>
|
||||
#endif
|
||||
#ifdef HAVE_READPASSPHRASE_H
|
||||
#include <readpassphrase.h>
|
||||
#endif
|
||||
|
||||
#ifndef HAVE_GETTIMEOFDAY
|
||||
#ifdef HAVE_FTIME
|
||||
@ -3242,3 +3245,33 @@ tor_sleep_msec(int msec)
|
||||
}
|
||||
#endif
|
||||
|
||||
/** Emit the password prompt <b>prompt</b>, then read up to <b>buflen</b>
|
||||
* characters of passphrase into <b>output</b>. */
|
||||
ssize_t
|
||||
tor_getpass(const char *prompt, char *output, size_t buflen)
|
||||
{
|
||||
tor_assert(buflen <= SSIZE_MAX);
|
||||
#if defined(HAVE_READPASSPHRASE)
|
||||
char *pwd = readpassphrase(prompt, output, buflen, RPP_ECHO_OFF);
|
||||
if (pwd == NULL)
|
||||
return -1;
|
||||
return strlen(pwd);
|
||||
#elif defined(HAVE_GETPASS)
|
||||
/* XXX We shouldn't actually use this; it's deprecated to hell and back */
|
||||
memset(output, 0, buflen);
|
||||
char *pwd = getpass(prompt);
|
||||
if (pwd == NULL)
|
||||
return -1;
|
||||
ssize_t len = (ssize_t)strlen(pwd);
|
||||
strlcpy(output, pwd, buflen);
|
||||
memset(pwd, 0, len);
|
||||
return len;
|
||||
#else
|
||||
/* XXX This is even worse. */
|
||||
puts(prompt);
|
||||
ssize_t n = read(STDIN_FILENO, output, buflen);
|
||||
if (n < 0)
|
||||
return -1;
|
||||
return n;
|
||||
#endif
|
||||
}
|
||||
|
@ -708,6 +708,8 @@ STATIC int tor_ersatz_socketpair(int family, int type, int protocol,
|
||||
#endif
|
||||
#endif
|
||||
|
||||
ssize_t tor_getpass(const char *prompt, char *output, size_t buflen);
|
||||
|
||||
/* This needs some of the declarations above so we include it here. */
|
||||
#include "compat_threads.h"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user