2009-12-23 15:17:16 -05:00
/*
2009-07-27 13:48:45 +10:00
Unix SMB / CIFS implementation .
KDC structures
Copyright ( C ) Andrew Tridgell 2005
Copyright ( C ) Andrew Bartlett < abartlet @ samba . org > 2005
2010-01-28 00:19:59 -05:00
Copyright ( C ) Simo Sorce < idra @ samba . org > 2010
2009-12-23 15:17:16 -05:00
2009-07-27 13:48:45 +10:00
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 .
2009-12-23 15:17:16 -05:00
2009-07-27 13:48:45 +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 .
2009-12-23 15:17:16 -05:00
2009-07-27 13:48:45 +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/>.
*/
2011-03-19 00:43:50 +01:00
# ifndef _SAMBA_KDC_H_
# define _SAMBA_KDC_H_
2023-05-08 13:16:10 +12:00
# include "lib/replace/replace.h"
# include "system/time.h"
# include "libcli/util/ntstatus.h"
2012-04-19 17:54:57 -04:00
struct samba_kdc_policy {
time_t svc_tkt_lifetime ;
time_t usr_tkt_lifetime ;
time_t renewal_lifetime ;
} ;
2010-01-28 00:08:36 -05:00
struct samba_kdc_base_context {
2009-07-27 16:09:25 +10:00
struct tevent_context * ev_ctx ;
struct loadparm_context * lp_ctx ;
2017-02-21 14:07:54 +13:00
struct imessaging_context * msg_ctx ;
2009-07-27 16:09:25 +10:00
} ;
2010-01-28 00:08:36 -05:00
struct samba_kdc_seq ;
struct samba_kdc_db_context {
struct tevent_context * ev_ctx ;
struct loadparm_context * lp_ctx ;
2017-02-21 14:07:54 +13:00
struct imessaging_context * msg_ctx ;
2010-01-28 00:08:36 -05:00
struct ldb_context * samdb ;
2010-01-28 01:27:11 -05:00
struct samba_kdc_seq * seq_ctx ;
2010-09-28 13:05:37 +10:00
bool rodc ;
unsigned int my_krbtgt_number ;
struct ldb_dn * krbtgt_dn ;
2012-04-19 17:54:57 -04:00
struct samba_kdc_policy policy ;
2010-01-28 00:08:36 -05:00
} ;
2010-01-28 00:19:59 -05:00
struct samba_kdc_entry {
struct samba_kdc_db_context * kdc_db_ctx ;
2022-03-22 17:04:22 +01:00
const struct sdb_entry * db_entry ; /* this is only temporary valid */
const void * kdc_entry ; /* this is a reference to hdb_entry/krb5_db_entry */
2009-07-27 13:48:45 +10:00
struct ldb_message * msg ;
struct ldb_dn * realm_dn ;
2022-03-18 11:13:40 +13:00
struct auth_user_info_dc * user_info_dc ;
2023-05-04 15:06:40 +12:00
const struct authn_kerberos_client_policy * client_policy ;
const struct authn_server_policy * server_policy ;
2018-02-01 11:44:21 +01:00
bool is_krbtgt ;
bool is_rodc ;
bool is_trust ;
2021-12-24 16:59:12 +13:00
uint32_t supported_enctypes ;
2022-03-16 09:21:03 +01:00
NTSTATUS reject_status ;
2009-07-27 13:48:45 +10:00
} ;
2011-03-19 00:43:50 +01:00
2011-11-30 07:45:25 +11:00
extern struct hdb_method hdb_samba4_interface ;
2022-05-24 17:53:49 +12:00
# define CHANGEPW_LIFETIME 60*2 /* 2 minutes */
2011-03-19 00:43:50 +01:00
# endif /* _SAMBA_KDC_H_ */