2010-01-26 11:43:54 -05:00
/*
Unix SMB / CIFS implementation .
PAC Glue between Samba and the KDC
Copyright ( C ) Andrew Bartlett < abartlet @ samba . org > 2005 - 2009
Copyright ( C ) Simo Sorce < idra @ samba . org > 2010
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/>.
*/
2023-05-08 13:30:40 +12:00
# include "system/kerberos.h"
# include "auth/kerberos/kerberos.h"
# include <krb5/krb5.h>
# include "lib/util/data_blob.h"
# include "lib/util/time.h"
# include "libcli/util/ntstatus.h"
# include "libcli/util/werror.h"
2022-09-27 14:51:54 +13:00
# include "librpc/gen_ndr/auth.h"
2023-05-08 13:30:40 +12:00
# include "kdc/samba_kdc.h"
s4:kdc: Add ‘samba_kdc_entry_pac’ wrapper type
With embedded Heimdal, we can mark a PAC as being trusted (i.e. not
issued by an RODC). This is convenient, as it saves us needing to carry
that information in flags, hoping it isn’t inadvertently lost.
System Heimdal and MIT Kerberos, however, don’t provide a way to mark a
PAC trusted. So we add a new wrapper type, ‘samba_kdc_entry_pac’, that
contains this extra information if ‘krb5_const_pac’ doesn’t contain it
already. As it also stores a pointer to the client entry, the
structure’s lifetime must therefore be carefully managed. Finally, it
keeps track of whether the PAC came across a trust, to know which is
useful in some circumstances.
Signed-off-by: Joseph Sutton <josephsutton@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
2023-09-27 13:15:15 +13:00
# include "lib/krb5_wrap/krb5_samba.h"
2023-10-05 15:33:42 +13:00
# include "auth/session.h"
2022-09-27 14:51:54 +13:00
2021-10-11 14:47:25 +02:00
enum samba_asserted_identity {
SAMBA_ASSERTED_IDENTITY_IGNORE = 0 ,
SAMBA_ASSERTED_IDENTITY_SERVICE ,
SAMBA_ASSERTED_IDENTITY_AUTHENTICATION_AUTHORITY ,
} ;
2022-03-07 10:24:14 +01:00
enum {
SAMBA_KDC_FLAG_PROTOCOL_TRANSITION = 0x00000001 ,
SAMBA_KDC_FLAG_CONSTRAINED_DELEGATION = 0x00000002 ,
} ;
2023-09-29 20:11:52 +13:00
bool samba_kdc_entry_is_trust ( const struct samba_kdc_entry * entry ) ;
s4:kdc: Add ‘samba_kdc_entry_pac’ wrapper type
With embedded Heimdal, we can mark a PAC as being trusted (i.e. not
issued by an RODC). This is convenient, as it saves us needing to carry
that information in flags, hoping it isn’t inadvertently lost.
System Heimdal and MIT Kerberos, however, don’t provide a way to mark a
PAC trusted. So we add a new wrapper type, ‘samba_kdc_entry_pac’, that
contains this extra information if ‘krb5_const_pac’ doesn’t contain it
already. As it also stores a pointer to the client entry, the
structure’s lifetime must therefore be carefully managed. Finally, it
keeps track of whether the PAC came across a trust, to know which is
useful in some circumstances.
Signed-off-by: Joseph Sutton <josephsutton@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
2023-09-27 13:15:15 +13:00
struct samba_kdc_entry_pac {
struct samba_kdc_entry * entry ;
krb5_const_pac pac ; /* NULL indicates that no PAC is present. */
bool is_from_trust : 1 ;
# ifndef HAVE_KRB5_PAC_IS_TRUSTED /* MIT */
bool pac_is_trusted : 1 ;
# endif /* HAVE_KRB5_PAC_IS_TRUSTED */
} ;
/*
* Return true if this entry has an associated PAC issued or signed by a KDC
* that our KDC trusts . We trust the main krbtgt account , but we don ’ t trust any
* RODC krbtgt besides ourselves .
*/
bool samba_krb5_pac_is_trusted ( const struct samba_kdc_entry_pac pac ) ;
# ifdef HAVE_KRB5_PAC_IS_TRUSTED /* Heimdal */
struct samba_kdc_entry_pac samba_kdc_entry_pac ( krb5_const_pac pac ,
struct samba_kdc_entry * entry ,
bool is_from_trust ) ;
# else /* MIT */
struct samba_kdc_entry_pac samba_kdc_entry_pac_from_trusted ( krb5_const_pac pac ,
struct samba_kdc_entry * entry ,
bool is_from_trust ,
bool is_trusted ) ;
# endif /* HAVE_KRB5_PAC_IS_TRUSTED */
2016-05-12 23:20:39 +02:00
krb5_error_code samba_kdc_encrypt_pac_credentials ( krb5_context context ,
const krb5_keyblock * pkreplykey ,
const DATA_BLOB * cred_ndr_blob ,
TALLOC_CTX * mem_ctx ,
DATA_BLOB * cred_info_blob ) ;
2010-01-26 11:43:54 -05:00
krb5_error_code samba_make_krb5_pac ( krb5_context context ,
2016-05-12 23:20:39 +02:00
const DATA_BLOB * logon_blob ,
const DATA_BLOB * cred_blob ,
2016-05-13 00:13:33 +02:00
const DATA_BLOB * upn_blob ,
2021-10-26 20:41:31 +13:00
const DATA_BLOB * pac_attrs_blob ,
2021-10-26 20:42:41 +13:00
const DATA_BLOB * requester_sid_blob ,
2016-05-12 23:20:39 +02:00
const DATA_BLOB * deleg_blob ,
2022-02-24 23:57:31 +01:00
const DATA_BLOB * client_claims_blob ,
const DATA_BLOB * device_info_blob ,
const DATA_BLOB * device_claims_blob ,
2021-10-07 15:12:35 +02:00
krb5_pac pac ) ;
2010-01-26 11:43:54 -05:00
2023-03-17 08:07:52 +13:00
bool samba_princ_needs_pac ( const struct samba_kdc_entry * skdc_entry ) ;
2010-01-26 11:43:54 -05:00
2023-09-05 14:04:47 +12:00
krb5_error_code samba_krbtgt_is_in_db ( const struct samba_kdc_entry * skdc_entry ,
2023-09-05 14:04:17 +12:00
bool * is_in_db ,
bool * is_trusted ) ;
2010-09-28 12:53:06 +10:00
2023-10-09 19:37:08 +13:00
krb5_error_code samba_kdc_get_user_info_dc ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
struct ldb_context * samdb ,
const struct samba_kdc_entry_pac entry ,
const struct auth_user_info_dc * * info_out ,
const struct PAC_DOMAIN_GROUP_MEMBERSHIP * * resource_groups_out ) ;
2023-10-03 13:39:48 +13:00
krb5_error_code samba_kdc_get_user_info_from_db ( TALLOC_CTX * mem_ctx ,
2023-10-03 14:53:17 +13:00
struct ldb_context * samdb ,
2023-10-03 13:39:48 +13:00
struct samba_kdc_entry * entry ,
const struct ldb_message * msg ,
2023-10-11 17:07:02 +13:00
const struct auth_user_info_dc * * info_out ) ;
2023-03-20 15:16:21 +13:00
2010-01-31 12:49:07 -05:00
krb5_error_code samba_kdc_map_policy_err ( NTSTATUS nt_status ) ;
NTSTATUS samba_kdc_check_client_access ( struct samba_kdc_entry * kdc_entry ,
const char * client_name ,
const char * workstation ,
bool password_change ) ;
2021-08-09 17:19:45 +02:00
2023-03-20 14:51:53 +13:00
krb5_error_code samba_kdc_verify_pac ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
2023-10-03 14:58:10 +13:00
struct ldb_context * samdb ,
2023-03-20 14:51:53 +13:00
uint32_t flags ,
2023-09-28 11:43:57 +13:00
const struct samba_kdc_entry_pac client ,
const struct samba_kdc_entry * krbtgt ) ;
2023-03-20 14:51:53 +13:00
2023-06-16 11:20:04 +12:00
struct authn_audit_info ;
2022-03-07 10:24:14 +01:00
krb5_error_code samba_kdc_update_pac ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
struct ldb_context * samdb ,
2023-06-16 14:24:50 +12:00
struct loadparm_context * lp_ctx ,
2022-03-07 10:24:14 +01:00
uint32_t flags ,
2023-09-28 11:43:57 +13:00
const struct samba_kdc_entry_pac client ,
2023-06-16 12:17:50 +12:00
const krb5_const_principal server_principal ,
2023-03-17 08:07:52 +13:00
const struct samba_kdc_entry * server ,
2023-06-16 12:17:50 +12:00
const krb5_const_principal delegated_proxy_principal ,
2023-09-28 11:43:57 +13:00
const struct samba_kdc_entry_pac delegated_proxy ,
const struct samba_kdc_entry_pac device ,
2023-06-16 14:49:11 +12:00
krb5_pac new_pac ,
struct authn_audit_info * * server_audit_info_out ,
NTSTATUS * status_out ) ;
2023-03-20 15:16:21 +13:00
NTSTATUS samba_kdc_get_logon_info_blob ( TALLOC_CTX * mem_ctx ,
const struct auth_user_info_dc * user_info_dc ,
enum auth_group_inclusion group_inclusion ,
DATA_BLOB * * _logon_info_blob ) ;
NTSTATUS samba_kdc_get_cred_ndr_blob ( TALLOC_CTX * mem_ctx ,
const struct samba_kdc_entry * p ,
DATA_BLOB * * _cred_ndr_blob ) ;
NTSTATUS samba_kdc_get_upn_info_blob ( TALLOC_CTX * mem_ctx ,
const struct auth_user_info_dc * user_info_dc ,
DATA_BLOB * * _upn_info_blob ) ;
NTSTATUS samba_kdc_get_pac_attrs_blob ( TALLOC_CTX * mem_ctx ,
uint64_t pac_attributes ,
DATA_BLOB * * _pac_attrs_blob ) ;
NTSTATUS samba_kdc_get_requester_sid_blob ( TALLOC_CTX * mem_ctx ,
const struct auth_user_info_dc * user_info_dc ,
DATA_BLOB * * _requester_sid_blob ) ;
NTSTATUS samba_kdc_get_claims_blob ( TALLOC_CTX * mem_ctx ,
2023-10-05 15:34:41 +13:00
struct samba_kdc_entry * p ,
2023-06-26 11:10:51 +12:00
const DATA_BLOB * * _claims_blob ) ;
2023-06-16 11:20:04 +12:00
krb5_error_code samba_kdc_allowed_to_authenticate_to ( TALLOC_CTX * mem_ctx ,
struct ldb_context * samdb ,
struct loadparm_context * lp_ctx ,
const struct samba_kdc_entry * client ,
const struct auth_user_info_dc * client_info ,
2023-10-09 18:19:36 +13:00
const struct auth_user_info_dc * device_info ,
const struct auth_claims auth_claims ,
2023-06-16 11:20:04 +12:00
const struct samba_kdc_entry * server ,
struct authn_audit_info * * server_audit_info_out ,
NTSTATUS * status_out ) ;
2023-06-16 11:22:28 +12:00
krb5_error_code samba_kdc_check_device ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
struct ldb_context * samdb ,
struct loadparm_context * lp_ctx ,
2023-09-28 11:43:57 +13:00
const struct samba_kdc_entry_pac device ,
2023-06-16 11:22:28 +12:00
const struct authn_kerberos_client_policy * client_policy ,
struct authn_audit_info * * client_audit_info_out ,
NTSTATUS * status_out ) ;
2023-08-21 13:55:27 +12:00
2023-10-05 15:33:42 +13:00
krb5_error_code samba_kdc_get_claims_data ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
struct ldb_context * samdb ,
struct samba_kdc_entry_pac entry ,
struct claims_data * * claims_data_out ) ;
krb5_error_code samba_kdc_get_claims_data_from_pac ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
struct samba_kdc_entry_pac entry ,
struct claims_data * * claims_data_out ) ;
krb5_error_code samba_kdc_get_claims_data_from_db ( struct ldb_context * samdb ,
struct samba_kdc_entry * entry ,
struct claims_data * * claims_data_out ) ;
2023-08-21 13:55:27 +12:00
NTSTATUS samba_kdc_add_asserted_identity ( enum samba_asserted_identity ai ,
struct auth_user_info_dc * user_info_dc ) ;
2023-10-09 15:19:01 +13:00
NTSTATUS samba_kdc_add_claims_valid ( struct auth_user_info_dc * user_info_dc ) ;
2024-02-27 11:23:03 +13:00
NTSTATUS samba_kdc_add_fresh_public_key_identity ( struct auth_user_info_dc * user_info_dc ) ;