2 Unix SMB/CIFS implementation.
6 Copyright (C) Andrew Tridgell 2005
7 Copyright (C) Andrew Bartlett <abartlet@samba.org> 2005
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>.
26 #include "system/kerberos.h"
27 #include "auth/kerberos/kerberos.h"
30 #include <krb5/windc_plugin.h>
31 #include "kdc/samba_kdc.h"
33 struct tsocket_address
;
36 top level context structure for the kdc server
39 struct task_server
*task
;
40 krb5_kdc_configuration
*config
;
41 struct smb_krb5_context
*smb_krb5_context
;
42 struct samba_kdc_base_context
*base_ctx
;
43 struct ldb_context
*samdb
;
45 uint32_t proxy_timeout
;
48 enum kdc_process_ret
{
54 struct tsocket_address
*src
;
59 /* hold information about one kdc/kpasswd udp socket */
60 struct kdc_udp_socket
{
61 struct kdc_socket
*kdc_socket
;
62 struct tdgram_context
*dgram
;
63 struct tevent_queue
*send_queue
;
67 struct kdc_tcp_connection
*kdc_conn
;
71 struct iovec out_iov
[2];
74 typedef enum kdc_process_ret (*kdc_process_fn_t
)(struct kdc_server
*kdc
,
78 struct tsocket_address
*peer_addr
,
79 struct tsocket_address
*my_addr
,
83 /* hold information about one kdc socket */
85 struct kdc_server
*kdc
;
86 struct tsocket_address
*local_address
;
87 kdc_process_fn_t process
;
91 state of an open tcp connection
93 struct kdc_tcp_connection
{
94 /* stream connection we belong to */
95 struct stream_connection
*conn
;
97 /* the kdc_server the connection belongs to */
98 struct kdc_socket
*kdc_socket
;
100 struct tstream_context
*tstream
;
102 struct tevent_queue
*send_queue
;
106 enum kdc_process_ret
kpasswdd_process(struct kdc_server
*kdc
,
110 struct tsocket_address
*peer_addr
,
111 struct tsocket_address
*my_addr
,
114 /* from hdb-samba4.c */
115 NTSTATUS
hdb_samba4_create_kdc(struct samba_kdc_base_context
*base_ctx
,
116 krb5_context context
, struct HDB
**db
);
119 void kdc_udp_proxy(struct kdc_server
*kdc
, struct kdc_udp_socket
*sock
,
120 struct kdc_udp_call
*call
, uint16_t port
);
122 void kdc_tcp_proxy(struct kdc_server
*kdc
, struct kdc_tcp_connection
*kdc_conn
,
123 struct kdc_tcp_call
*call
, uint16_t port
);