2007-01-10 04:57:32 +03:00
/*
2008-10-27 13:35:07 +03:00
* Copyright ( c ) 2007 Kungliga Tekniska Högskolan
* ( Royal Institute of Technology , Stockholm , Sweden ) .
* All rights reserved .
2007-01-10 04:57:32 +03:00
*
2008-10-27 13:35:07 +03:00
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
2007-01-10 04:57:32 +03:00
*
2008-10-27 13:35:07 +03:00
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
2007-01-10 04:57:32 +03:00
*
2008-10-27 13:35:07 +03:00
* 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 .
2007-01-10 04:57:32 +03:00
*
2008-10-27 13:35:07 +03:00
* 3. Neither the name of the Institute nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission .
2007-01-10 04:57:32 +03:00
*
2008-10-27 13:35:07 +03:00
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ` ` 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 INSTITUTE OR CONTRIBUTORS 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 .
2007-01-10 04:57:32 +03:00
*/
# include "kdc_locl.h"
static krb5plugin_windc_ftable * windcft ;
static void * windcctx ;
/*
* Pick the first WINDC module that we find .
*/
krb5_error_code
2007-06-13 09:44:24 +04:00
krb5_kdc_windc_init ( krb5_context context )
2007-01-10 04:57:32 +03:00
{
struct krb5_plugin * list = NULL , * e ;
krb5_error_code ret ;
ret = _krb5_plugin_find ( context , PLUGIN_TYPE_DATA , " windc " , & list ) ;
if ( ret ! = 0 | | list = = NULL )
return 0 ;
for ( e = list ; e ! = NULL ; e = _krb5_plugin_get_next ( e ) ) {
windcft = _krb5_plugin_get_symbol ( e ) ;
2009-11-13 02:51:14 +03:00
if ( windcft - > minor_version < KRB5_WINDC_PLUGIN_MINOR )
2007-01-10 04:57:32 +03:00
continue ;
2011-07-15 11:10:30 +04:00
2007-01-10 04:57:32 +03:00
( * windcft - > init ) ( context , & windcctx ) ;
break ;
}
2009-10-03 17:36:44 +04:00
_krb5_plugin_free ( list ) ;
2007-01-10 04:57:32 +03:00
if ( e = = NULL ) {
2008-08-01 09:08:51 +04:00
krb5_set_error_message ( context , ENOENT , " Did not find any WINDC plugin " ) ;
2007-01-10 04:57:32 +03:00
windcft = NULL ;
return ENOENT ;
}
return 0 ;
}
2008-10-27 13:35:07 +03:00
krb5_error_code
2007-01-10 04:57:32 +03:00
_kdc_pac_generate ( krb5_context context ,
2008-10-27 13:35:07 +03:00
hdb_entry_ex * client ,
2016-05-20 09:29:30 +03:00
const krb5_keyblock * pk_reply_key ,
2007-01-10 04:57:32 +03:00
krb5_pac * pac )
{
* pac = NULL ;
if ( windcft = = NULL )
return 0 ;
2016-05-20 09:29:30 +03:00
if ( windcft - > pac_pk_generate ! = NULL & & pk_reply_key ! = NULL )
return ( windcft - > pac_pk_generate ) ( windcctx , context ,
client , pk_reply_key , pac ) ;
2007-01-10 04:57:32 +03:00
return ( windcft - > pac_generate ) ( windcctx , context , client , pac ) ;
}
2008-10-27 13:35:07 +03:00
krb5_error_code
_kdc_pac_verify ( krb5_context context ,
2007-01-10 04:57:32 +03:00
const krb5_principal client_principal ,
2011-06-28 15:24:50 +04:00
const krb5_principal delegated_proxy_principal ,
2007-01-10 04:57:32 +03:00
hdb_entry_ex * client ,
hdb_entry_ex * server ,
2010-09-28 07:07:53 +04:00
hdb_entry_ex * krbtgt ,
2010-08-15 18:31:28 +04:00
krb5_pac * pac ,
int * verified )
2007-01-10 04:57:32 +03:00
{
2010-08-15 18:31:28 +04:00
krb5_error_code ret ;
if ( windcft = = NULL )
return 0 ;
ret = windcft - > pac_verify ( windcctx , context ,
2011-06-28 15:24:50 +04:00
client_principal ,
delegated_proxy_principal ,
client , server , krbtgt , pac ) ;
2010-08-15 18:31:28 +04:00
if ( ret = = 0 )
* verified = 1 ;
return ret ;
2007-01-10 04:57:32 +03:00
}
krb5_error_code
2009-06-18 05:08:46 +04:00
_kdc_check_access ( krb5_context context ,
krb5_kdc_configuration * config ,
hdb_entry_ex * client_ex , const char * client_name ,
hdb_entry_ex * server_ex , const char * server_name ,
KDC_REQ * req ,
krb5_data * e_data )
2007-01-10 04:57:32 +03:00
{
if ( windcft = = NULL )
2009-06-18 05:08:46 +04:00
return kdc_check_flags ( context , config ,
client_ex , client_name ,
server_ex , server_name ,
req - > msg_type = = krb_as_req ) ;
2011-07-15 11:10:30 +04:00
return ( windcft - > client_access ) ( windcctx ,
context , config ,
client_ex , client_name ,
server_ex , server_name ,
2009-06-18 05:08:46 +04:00
req , e_data ) ;
2007-01-10 04:57:32 +03:00
}