2012-03-30 15:48:54 -04:00
/*
2008-08-27 16:24:05 +10:00
Unix SMB / CIFS implementation .
Kerberos backend for GENSEC
2012-03-30 15:48:54 -04:00
2008-08-27 16:24:05 +10:00
Copyright ( C ) Andrew Bartlett < abartlet @ samba . org > 2004 - 2005
Copyright ( C ) Stefan Metzmacher < metze @ samba . org > 2004 - 2005
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 .
2012-03-30 15:48:54 -04:00
2008-08-27 16:24:05 +10:00
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 .
2012-03-30 15:48:54 -04:00
2008-08-27 16:24:05 +10:00
You should have received a copy of the GNU General Public License
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
/* This structure described here, so the RPC-PAC test can get at the PAC provided */
2012-03-30 15:48:54 -04:00
enum gensec_gssapi_sasl_state
2008-08-27 16:24:05 +10:00
{
STAGE_GSS_NEG ,
STAGE_SASL_SSF_NEG ,
STAGE_SASL_SSF_ACCEPT ,
STAGE_DONE
} ;
# define NEG_SEAL 0x4
# define NEG_SIGN 0x2
# define NEG_NONE 0x1
struct gensec_gssapi_state {
gss_ctx_id_t gssapi_context ;
gss_name_t server_name ;
gss_name_t client_name ;
2012-01-11 11:26:31 +11:00
OM_uint32 gss_want_flags , gss_got_flags ;
2012-01-11 11:52:13 +11:00
gss_cred_id_t delegated_cred_handle ;
2012-01-24 10:33:11 +01:00
2012-01-11 11:52:13 +11:00
/* gensec_gssapi only */
2012-03-02 22:01:48 +01:00
gss_krb5_lucid_context_v1_t * lucid ;
2008-08-27 16:24:05 +10:00
gss_OID gss_oid ;
2012-01-11 11:52:13 +11:00
struct gss_channel_bindings_struct * input_chan_bindings ;
2008-08-27 16:24:05 +10:00
struct smb_krb5_context * smb_krb5_context ;
struct gssapi_creds_container * client_cred ;
struct gssapi_creds_container * server_cred ;
bool sasl ; /* We have two different mechs in this file: One
* for SASL wrapped GSSAPI and another for normal
* GSSAPI */
enum gensec_gssapi_sasl_state sasl_state ;
uint8_t sasl_protection ; /* What was negotiated at the SASL
* layer , independent of the GSSAPI
* layer . . . */
size_t max_wrap_buf_size ;
int gss_exchange_count ;
size_t sig_size ;
2010-11-08 16:55:17 +11:00
const char * target_principal ;
2008-08-27 16:24:05 +10:00
} ;