- markus@cvs.openbsd.org 2001/06/26 04:07:06
[ssh-agent.1 ssh-agent.c] add debug flag
This commit is contained in:
parent
cd392284ac
commit
d94580c708
|
@ -19,6 +19,9 @@
|
||||||
- markus@cvs.openbsd.org 2001/06/26 02:47:07
|
- markus@cvs.openbsd.org 2001/06/26 02:47:07
|
||||||
[ssh-keygen.c]
|
[ssh-keygen.c]
|
||||||
allow loading a private RSA key to a cyberflex card.
|
allow loading a private RSA key to a cyberflex card.
|
||||||
|
- markus@cvs.openbsd.org 2001/06/26 04:07:06
|
||||||
|
[ssh-agent.1 ssh-agent.c]
|
||||||
|
add debug flag
|
||||||
|
|
||||||
20010629
|
20010629
|
||||||
- (bal) Removed net_aton() since we don't use it any more
|
- (bal) Removed net_aton() since we don't use it any more
|
||||||
|
@ -5846,4 +5849,4 @@
|
||||||
- Wrote replacements for strlcpy and mkdtemp
|
- Wrote replacements for strlcpy and mkdtemp
|
||||||
- Released 1.0pre1
|
- Released 1.0pre1
|
||||||
|
|
||||||
$Id: ChangeLog,v 1.1349 2001/07/04 03:44:03 mouring Exp $
|
$Id: ChangeLog,v 1.1350 2001/07/04 03:48:02 mouring Exp $
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
.\" $OpenBSD: ssh-agent.1,v 1.24 2001/04/10 09:13:21 itojun Exp $
|
.\" $OpenBSD: ssh-agent.1,v 1.25 2001/06/26 04:07:06 markus Exp $
|
||||||
.\"
|
.\"
|
||||||
.\" Author: Tatu Ylonen <ylo@cs.hut.fi>
|
.\" Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
.\" Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
.\" Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -48,6 +48,8 @@
|
||||||
.Op Fl c Li | Fl s
|
.Op Fl c Li | Fl s
|
||||||
.Nm ssh-agent
|
.Nm ssh-agent
|
||||||
.Fl k
|
.Fl k
|
||||||
|
.Nm ssh-agent
|
||||||
|
.Fl d
|
||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
.Nm
|
.Nm
|
||||||
is a program to hold private keys used for public key authentication
|
is a program to hold private keys used for public key authentication
|
||||||
|
@ -80,6 +82,10 @@ does not look like it's a csh style of shell.
|
||||||
Kill the current agent (given by the
|
Kill the current agent (given by the
|
||||||
.Ev SSH_AGENT_PID
|
.Ev SSH_AGENT_PID
|
||||||
environment variable).
|
environment variable).
|
||||||
|
.It Fl d
|
||||||
|
Debug mode. When this option is specified
|
||||||
|
.Nm
|
||||||
|
will fork.
|
||||||
.El
|
.El
|
||||||
.Pp
|
.Pp
|
||||||
If a commandline is given, this is executed as a subprocess of the agent.
|
If a commandline is given, this is executed as a subprocess of the agent.
|
||||||
|
|
31
ssh-agent.c
31
ssh-agent.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh-agent.c,v 1.56 2001/06/25 08:25:40 markus Exp $ */
|
/* $OpenBSD: ssh-agent.c,v 1.57 2001/06/26 04:07:06 markus Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
RCSID("$OpenBSD: ssh-agent.c,v 1.56 2001/06/25 08:25:40 markus Exp $");
|
RCSID("$OpenBSD: ssh-agent.c,v 1.57 2001/06/26 04:07:06 markus Exp $");
|
||||||
|
|
||||||
#include <openssl/evp.h>
|
#include <openssl/evp.h>
|
||||||
#include <openssl/md5.h>
|
#include <openssl/md5.h>
|
||||||
|
@ -706,7 +706,7 @@ usage(void)
|
||||||
int
|
int
|
||||||
main(int ac, char **av)
|
main(int ac, char **av)
|
||||||
{
|
{
|
||||||
int sock, c_flag = 0, k_flag = 0, s_flag = 0, ch;
|
int sock, c_flag = 0, d_flag = 0, k_flag = 0, s_flag = 0, ch;
|
||||||
struct sockaddr_un sunaddr;
|
struct sockaddr_un sunaddr;
|
||||||
#ifdef HAVE_SETRLIMIT
|
#ifdef HAVE_SETRLIMIT
|
||||||
struct rlimit rlim;
|
struct rlimit rlim;
|
||||||
|
@ -726,9 +726,9 @@ main(int ac, char **av)
|
||||||
seed_rng();
|
seed_rng();
|
||||||
|
|
||||||
#ifdef __GNU_LIBRARY__
|
#ifdef __GNU_LIBRARY__
|
||||||
while ((ch = getopt(ac, av, "+cks")) != -1) {
|
while ((ch = getopt(ac, av, "+cdks")) != -1) {
|
||||||
#else /* __GNU_LIBRARY__ */
|
#else /* __GNU_LIBRARY__ */
|
||||||
while ((ch = getopt(ac, av, "cks")) != -1) {
|
while ((ch = getopt(ac, av, "cdks")) != -1) {
|
||||||
#endif /* __GNU_LIBRARY__ */
|
#endif /* __GNU_LIBRARY__ */
|
||||||
switch (ch) {
|
switch (ch) {
|
||||||
case 'c':
|
case 'c':
|
||||||
|
@ -744,6 +744,11 @@ main(int ac, char **av)
|
||||||
usage();
|
usage();
|
||||||
s_flag++;
|
s_flag++;
|
||||||
break;
|
break;
|
||||||
|
case 'd':
|
||||||
|
if (d_flag)
|
||||||
|
usage();
|
||||||
|
d_flag++;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
usage();
|
usage();
|
||||||
}
|
}
|
||||||
|
@ -751,10 +756,10 @@ main(int ac, char **av)
|
||||||
ac -= optind;
|
ac -= optind;
|
||||||
av += optind;
|
av += optind;
|
||||||
|
|
||||||
if (ac > 0 && (c_flag || k_flag || s_flag))
|
if (ac > 0 && (c_flag || k_flag || s_flag || d_flag))
|
||||||
usage();
|
usage();
|
||||||
|
|
||||||
if (ac == 0 && !c_flag && !k_flag && !s_flag) {
|
if (ac == 0 && !c_flag && !k_flag && !s_flag && !d_flag) {
|
||||||
shell = getenv("SHELL");
|
shell = getenv("SHELL");
|
||||||
if (shell != NULL && strncmp(shell + strlen(shell) - 3, "csh", 3) == 0)
|
if (shell != NULL && strncmp(shell + strlen(shell) - 3, "csh", 3) == 0)
|
||||||
c_flag = 1;
|
c_flag = 1;
|
||||||
|
@ -827,6 +832,14 @@ main(int ac, char **av)
|
||||||
* Fork, and have the parent execute the command, if any, or present
|
* Fork, and have the parent execute the command, if any, or present
|
||||||
* the socket data. The child continues as the authentication agent.
|
* the socket data. The child continues as the authentication agent.
|
||||||
*/
|
*/
|
||||||
|
if (d_flag) {
|
||||||
|
log_init(__progname, SYSLOG_LEVEL_DEBUG1, SYSLOG_FACILITY_AUTH, 1);
|
||||||
|
format = c_flag ? "setenv %s %s;\n" : "%s=%s; export %s;\n";
|
||||||
|
printf(format, SSH_AUTHSOCKET_ENV_NAME, socket_name,
|
||||||
|
SSH_AUTHSOCKET_ENV_NAME);
|
||||||
|
printf("echo Agent pid %d;\n", parent_pid);
|
||||||
|
goto skip;
|
||||||
|
}
|
||||||
pid = fork();
|
pid = fork();
|
||||||
if (pid == -1) {
|
if (pid == -1) {
|
||||||
perror("fork");
|
perror("fork");
|
||||||
|
@ -869,6 +882,8 @@ main(int ac, char **av)
|
||||||
perror("setsid");
|
perror("setsid");
|
||||||
cleanup_exit(1);
|
cleanup_exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
skip:
|
||||||
if (atexit(cleanup_socket) < 0) {
|
if (atexit(cleanup_socket) < 0) {
|
||||||
perror("atexit");
|
perror("atexit");
|
||||||
cleanup_exit(1);
|
cleanup_exit(1);
|
||||||
|
@ -879,8 +894,10 @@ main(int ac, char **av)
|
||||||
alarm(10);
|
alarm(10);
|
||||||
}
|
}
|
||||||
idtab_init();
|
idtab_init();
|
||||||
|
if (!d_flag) {
|
||||||
signal(SIGINT, SIG_IGN);
|
signal(SIGINT, SIG_IGN);
|
||||||
signal(SIGPIPE, SIG_IGN);
|
signal(SIGPIPE, SIG_IGN);
|
||||||
|
}
|
||||||
signal(SIGHUP, cleanup_handler);
|
signal(SIGHUP, cleanup_handler);
|
||||||
signal(SIGTERM, cleanup_handler);
|
signal(SIGTERM, cleanup_handler);
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
Loading…
Reference in New Issue