(krb5_get_host_realm): make sure we don't recurse
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@18541 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -217,9 +217,10 @@ _krb5_get_host_realm_int (krb5_context context,
|
|||||||
|
|
||||||
krb5_error_code KRB5_LIB_FUNCTION
|
krb5_error_code KRB5_LIB_FUNCTION
|
||||||
krb5_get_host_realm(krb5_context context,
|
krb5_get_host_realm(krb5_context context,
|
||||||
const char *host,
|
const char *targethost,
|
||||||
krb5_realm **realms)
|
krb5_realm **realms)
|
||||||
{
|
{
|
||||||
|
const char *host = targethost;
|
||||||
char hostname[MAXHOSTNAMELEN];
|
char hostname[MAXHOSTNAMELEN];
|
||||||
krb5_error_code ret;
|
krb5_error_code ret;
|
||||||
int use_dns;
|
int use_dns;
|
||||||
@@ -239,11 +240,11 @@ krb5_get_host_realm(krb5_context context,
|
|||||||
use_dns = (strchr(host, '.') != NULL);
|
use_dns = (strchr(host, '.') != NULL);
|
||||||
|
|
||||||
ret = _krb5_get_host_realm_int (context, host, use_dns, realms);
|
ret = _krb5_get_host_realm_int (context, host, use_dns, realms);
|
||||||
if (ret) {
|
if (ret && targethost != NULL) {
|
||||||
/*
|
/*
|
||||||
* If there was no realm mapping for the host guess at the
|
* If there was no realm mapping for the host (and we wasn't
|
||||||
* local realm, maybe our KDC knows better then we do and we
|
* looking for ourself), guess at the local realm, maybe our
|
||||||
* get a referral back.
|
* KDC knows better then we do and we get a referral back.
|
||||||
*/
|
*/
|
||||||
ret = krb5_get_default_realms(context, realms);
|
ret = krb5_get_default_realms(context, realms);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
@@ -252,5 +253,5 @@ krb5_get_host_realm(krb5_context context,
|
|||||||
return KRB5_ERR_HOST_REALM_UNKNOWN;
|
return KRB5_ERR_HOST_REALM_UNKNOWN;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user