2010-07-02 02:32:52 +04:00
/*
Unix SMB / CIFS implementation .
krb5 set password implementation
Copyright ( C ) Andrew Tridgell 2001
Copyright ( C ) Remus Koos 2001 ( remuskoos @ yahoo . com )
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 3 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# include "smb_krb5.h"
# include "ads.h"
2012-07-23 06:47:01 +04:00
# include "lib/param/loadparm.h"
2010-07-02 02:32:52 +04:00
# ifdef HAVE_KRB5
/* run kinit to setup our ccache */
int ads_kinit_password ( ADS_STRUCT * ads )
{
char * s ;
int ret ;
const char * account_name ;
fstring acct_name ;
2016-10-07 19:18:56 +03:00
if ( ads - > auth . password = = NULL | | ads - > auth . password [ 0 ] = = ' \0 ' ) {
return KRB5_LIBOS_CANTREADPWD ;
}
2010-07-02 02:32:52 +04:00
if ( ads - > auth . flags & ADS_AUTH_USER_CREDS ) {
account_name = ads - > auth . user_name ;
goto got_accountname ;
}
if ( IS_DC ) {
/* this will end up getting a ticket for DOMAIN@RUSTED.REA.LM */
account_name = lp_workgroup ( ) ;
} else {
/* always use the sAMAccountName for security = domain */
2011-06-09 09:31:03 +04:00
/* lp_netbios_name()$@REA.LM */
2010-07-02 02:32:52 +04:00
if ( lp_security ( ) = = SEC_DOMAIN ) {
2011-06-09 09:31:03 +04:00
fstr_sprintf ( acct_name , " %s$ " , lp_netbios_name ( ) ) ;
2010-07-02 02:32:52 +04:00
account_name = acct_name ;
}
else
2011-06-09 09:31:03 +04:00
/* This looks like host/lp_netbios_name()@REA.LM */
2010-07-02 02:32:52 +04:00
account_name = ads - > auth . user_name ;
}
got_accountname :
if ( asprintf ( & s , " %s@%s " , account_name , ads - > auth . realm ) = = - 1 ) {
return KRB5_CC_NOMEM ;
}
2012-09-07 22:14:08 +04:00
ret = kerberos_kinit_password_ext ( s , ads - > auth . password ,
ads - > auth . time_offset ,
& ads - > auth . tgt_expire , NULL ,
ads - > auth . ccache_name , false , false ,
2019-09-16 18:14:11 +03:00
ads - > auth . renewable ,
NULL , NULL , NULL , NULL ) ;
2010-07-02 02:32:52 +04:00
if ( ret ) {
DEBUG ( 0 , ( " kerberos_kinit_password %s failed: %s \n " ,
s , error_message ( ret ) ) ) ;
}
SAFE_FREE ( s ) ;
return ret ;
}
# endif