2002-07-04 07:08:40 +04:00
|
|
|
/*
|
2002-07-07 06:17:36 +04:00
|
|
|
*
|
|
|
|
* Copyright (c) 2001 Gert Doering. All rights reserved.
|
|
|
|
*
|
2002-07-04 07:08:40 +04:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*/
|
2002-02-19 23:27:55 +03:00
|
|
|
#include "includes.h"
|
2003-05-02 17:42:25 +04:00
|
|
|
#include "ssh.h"
|
|
|
|
#include "log.h"
|
|
|
|
#include "servconf.h"
|
2002-02-19 23:27:55 +03:00
|
|
|
|
|
|
|
#ifdef _AIX
|
|
|
|
|
|
|
|
#include <uinfo.h>
|
2002-02-24 23:25:46 +03:00
|
|
|
#include <../xmalloc.h>
|
2002-02-19 23:27:55 +03:00
|
|
|
|
2003-05-02 17:42:25 +04:00
|
|
|
extern ServerOptions options;
|
|
|
|
|
2002-02-19 23:27:55 +03:00
|
|
|
/*
|
2002-07-04 07:08:40 +04:00
|
|
|
* AIX has a "usrinfo" area where logname and other stuff is stored -
|
|
|
|
* a few applications actually use this and die if it's not set
|
|
|
|
*
|
|
|
|
* NOTE: TTY= should be set, but since no one uses it and it's hard to
|
|
|
|
* acquire due to privsep code. We will just drop support.
|
2002-02-19 23:27:55 +03:00
|
|
|
*/
|
|
|
|
void
|
2002-07-04 07:08:40 +04:00
|
|
|
aix_usrinfo(struct passwd *pw)
|
2002-02-19 23:27:55 +03:00
|
|
|
{
|
|
|
|
u_int i;
|
2003-05-18 18:13:38 +04:00
|
|
|
size_t len;
|
2002-07-04 07:08:40 +04:00
|
|
|
char *cp;
|
2002-02-19 23:27:55 +03:00
|
|
|
|
2003-05-18 18:13:38 +04:00
|
|
|
len = sizeof("LOGNAME= NAME= ") + (2 * strlen(pw->pw_name));
|
|
|
|
cp = xmalloc(len);
|
|
|
|
|
2003-05-19 03:33:15 +04:00
|
|
|
i = snprintf(cp, len, "LOGNAME=%s%cNAME=%s%c", pw->pw_name, '\0',
|
|
|
|
pw->pw_name, '\0');
|
2002-02-19 23:27:55 +03:00
|
|
|
if (usrinfo(SETUINFO, cp, i) == -1)
|
|
|
|
fatal("Couldn't set usrinfo: %s", strerror(errno));
|
|
|
|
debug3("AIX/UsrInfo: set len %d", i);
|
2003-05-18 18:13:38 +04:00
|
|
|
|
2002-02-19 23:27:55 +03:00
|
|
|
xfree(cp);
|
|
|
|
}
|
|
|
|
|
2003-07-08 16:59:59 +04:00
|
|
|
#ifdef WITH_AIXAUTHENTICATE
|
|
|
|
/*
|
|
|
|
* Remove embedded newlines in string (if any).
|
|
|
|
* Used before logging messages returned by AIX authentication functions
|
|
|
|
* so the message is logged on one line.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
aix_remove_embedded_newlines(char *p)
|
|
|
|
{
|
|
|
|
if (p == NULL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (; *p; p++) {
|
|
|
|
if (*p == '\n')
|
|
|
|
*p = ' ';
|
|
|
|
}
|
|
|
|
/* Remove trailing whitespace */
|
|
|
|
if (*--p == ' ')
|
|
|
|
*p = '\0';
|
|
|
|
}
|
|
|
|
#endif /* WITH_AIXAUTHENTICATE */
|
|
|
|
|
2003-05-02 17:42:25 +04:00
|
|
|
# ifdef CUSTOM_FAILED_LOGIN
|
|
|
|
/*
|
|
|
|
* record_failed_login: generic "login failed" interface function
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
record_failed_login(const char *user, const char *ttyname)
|
|
|
|
{
|
2003-06-03 06:45:27 +04:00
|
|
|
char *hostname = get_canonical_hostname(options.use_dns);
|
2003-05-18 18:13:38 +04:00
|
|
|
|
2003-07-08 14:52:12 +04:00
|
|
|
# ifdef AIX_LOGINFAILED_3ARG
|
|
|
|
loginfailed((char *)user, hostname, (char *)ttyname);
|
|
|
|
# else
|
|
|
|
loginfailed((char *)user, hostname, (char *)ttyname, AUDIT_FAIL_AUTH);
|
|
|
|
# endif
|
2003-05-02 17:42:25 +04:00
|
|
|
}
|
|
|
|
# endif /* CUSTOM_FAILED_LOGIN */
|
2002-02-19 23:27:55 +03:00
|
|
|
#endif /* _AIX */
|
|
|
|
|