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 kdc_tcp_connection
*kdc_conn
;
58 struct iovec out_iov
[2];
61 typedef enum kdc_process_ret (*kdc_process_fn_t
)(struct kdc_server
*kdc
,
65 struct tsocket_address
*peer_addr
,
66 struct tsocket_address
*my_addr
,
70 /* hold information about one kdc socket */
72 struct kdc_server
*kdc
;
73 struct tsocket_address
*local_address
;
74 kdc_process_fn_t process
;
78 state of an open tcp connection
80 struct kdc_tcp_connection
{
81 /* stream connection we belong to */
82 struct stream_connection
*conn
;
84 /* the kdc_server the connection belongs to */
85 struct kdc_socket
*kdc_socket
;
87 struct tstream_context
*tstream
;
89 struct tevent_queue
*send_queue
;
93 enum kdc_process_ret
kpasswdd_process(struct kdc_server
*kdc
,
97 struct tsocket_address
*peer_addr
,
98 struct tsocket_address
*my_addr
,
101 /* from hdb-samba4.c */
102 NTSTATUS
hdb_samba4_create_kdc(struct samba_kdc_base_context
*base_ctx
,
103 krb5_context context
, struct HDB
**db
);
106 struct tevent_req
*kdc_udp_proxy_send(TALLOC_CTX
*mem_ctx
,
107 struct tevent_context
*ev
,
108 struct kdc_server
*kdc
,
111 NTSTATUS
kdc_udp_proxy_recv(struct tevent_req
*req
,
115 void kdc_tcp_proxy(struct kdc_server
*kdc
, struct kdc_tcp_connection
*kdc_conn
,
116 struct kdc_tcp_call
*call
, uint16_t port
);