8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-23 18:43:03 +01:00
This commit is contained in:
robocop 2012-01-19 06:26:12 +00:00
parent 5ad1da3891
commit 670b1a5d56

View File

@ -1123,15 +1123,14 @@ static bool accept_connection(rem_port* port, const P_CNCT* cnct)
**************************************/ **************************************/
// Default account to "guest" (in theory all packets contain a name) // Default account to "guest" (in theory all packets contain a name)
Firebird::string name("guest"), password; Firebird::string name("guest");
// Pick up account and password, if given // Pick up account, if given
Firebird::ClumpletReader id(Firebird::ClumpletReader::UnTagged, Firebird::ClumpletReader id(Firebird::ClumpletReader::UnTagged,
cnct->p_cnct_user_id.cstr_address, cnct->p_cnct_user_id.cstr_address,
cnct->p_cnct_user_id.cstr_length); cnct->p_cnct_user_id.cstr_length);
SLONG eff_gid = -1, eff_uid = -1;
bool user_verification = false; bool user_verification = false;
for (id.rewind(); !id.isEof(); id.moveNext()) for (id.rewind(); !id.isEof(); id.moveNext())
{ {
@ -1142,39 +1141,24 @@ static bool accept_connection(rem_port* port, const P_CNCT* cnct)
break; break;
case CNCT_passwd: case CNCT_passwd:
id.getString(password); //id.getString(password); obsolete
break; break;
case CNCT_group: case CNCT_group: // obsolete
{ break;
const size_t length = id.getClumpLength();
if (length != 0)
{
eff_gid = 0;
memcpy(&eff_gid, id.getBytes(), length);
eff_gid = ntohl(eff_gid);
}
break;
}
// this case indicates that the client has requested that // this case indicates that the client has requested that
// we force the user name/password to be verified against // we force the user name/password to be verified against
// the security database // the security database
case CNCT_user_verification: case CNCT_user_verification:
user_verification = true; user_verification = true;
break; break;
} }
} }
// See if user exists. If not, reject connection
if (user_verification)
{
eff_gid = eff_uid = -1;
}
#ifndef WIN_NT #ifndef WIN_NT
else // See if user exists. If not, reject connection
if (!user_verification)
{ {
if (!check_host(port)) if (!check_host(port))
{ {
@ -1195,7 +1179,8 @@ static bool accept_connection(rem_port* port, const P_CNCT* cnct)
Firebird::PathName home; Firebird::PathName home;
if (fb_utils::readenv("ISC_INET_SERVER_HOME", home)) if (fb_utils::readenv("ISC_INET_SERVER_HOME", home))
{ {
if (chdir(home.c_str())) { if (chdir(home.c_str()))
{
gds__log("inet_server: unable to cd to %s errno %d\n", home.c_str(), INET_ERRNO); gds__log("inet_server: unable to cd to %s errno %d\n", home.c_str(), INET_ERRNO);
// We continue after the error // We continue after the error
} }