2005-05-10 06:01:25 +04:00
/*
Unix SMB / CIFS implementation .
a async CLDAP library
Copyright ( C ) Andrew Tridgell 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
2007-07-10 06:07:03 +04:00
the Free Software Foundation ; either version 3 of the License , or
2005-05-10 06:01:25 +04:00
( 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
2007-07-10 06:07:03 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-05-10 06:01:25 +04:00
*/
2008-10-11 23:31:42 +04:00
# include "../lib/util/asn1.h"
2008-09-24 01:14:40 +04:00
# include "../libcli/netlogon.h"
2005-05-10 06:01:25 +04:00
2006-01-03 20:27:33 +03:00
struct ldap_message ;
2005-05-10 06:01:25 +04:00
enum cldap_request_state { CLDAP_REQUEST_SEND ,
CLDAP_REQUEST_WAIT ,
CLDAP_REQUEST_DONE ,
2007-04-05 11:37:21 +04:00
CLDAP_REQUEST_ERROR } ;
2005-05-10 06:01:25 +04:00
/*
a cldap request packet
*/
struct cldap_request {
struct cldap_request * next , * prev ;
struct cldap_socket * cldap ;
enum cldap_request_state state ;
2007-04-05 11:37:21 +04:00
NTSTATUS status ;
2005-05-10 06:01:25 +04:00
/* where to send the request */
2006-01-10 01:12:53 +03:00
struct socket_address * dest ;
2005-05-10 06:01:25 +04:00
/* timeout between retries (seconds) */
int timeout ;
int num_retries ;
2007-08-27 22:10:19 +04:00
bool is_reply ;
2005-05-12 12:25:35 +04:00
2005-05-10 06:01:25 +04:00
/* the ldap message_id */
int message_id ;
2008-12-29 22:24:57 +03:00
struct tevent_timer * te ;
2005-05-10 06:01:25 +04:00
/* the encoded request */
DATA_BLOB encoded ;
/* the reply data */
2007-05-21 10:12:06 +04:00
struct asn1_data * asn1 ;
2005-05-10 06:01:25 +04:00
/* information on what to do on completion */
struct {
void ( * fn ) ( struct cldap_request * ) ;
void * private ;
} async ;
} ;
/*
context structure for operations on cldap packets
*/
struct cldap_socket {
struct socket_context * sock ;
2008-12-29 22:24:57 +03:00
struct tevent_context * event_ctx ;
2008-02-21 19:17:37 +03:00
struct smb_iconv_convenience * iconv_convenience ;
2005-05-10 06:01:25 +04:00
/* the fd event */
2008-12-29 22:24:57 +03:00
struct tevent_fd * fde ;
2005-05-10 06:01:25 +04:00
/* a queue of outgoing requests */
struct cldap_request * send_queue ;
/* mapping from message_id to pending request */
struct idr_context * idr ;
/* what to do with incoming request packets */
struct {
void ( * handler ) ( struct cldap_socket * , struct ldap_message * ,
2006-01-10 01:12:53 +03:00
struct socket_address * ) ;
2005-05-10 06:01:25 +04:00
void * private ;
} incoming ;
} ;
/*
a general cldap search request
*/
struct cldap_search {
struct {
const char * dest_address ;
2007-12-02 18:20:29 +03:00
uint16_t dest_port ;
2005-05-10 06:01:25 +04:00
const char * filter ;
const char * * attributes ;
int timeout ;
int retries ;
} in ;
struct {
struct ldap_SearchResEntry * response ;
struct ldap_Result * result ;
} out ;
} ;
struct cldap_socket * cldap_socket_init ( TALLOC_CTX * mem_ctx ,
2008-12-29 22:24:57 +03:00
struct tevent_context * event_ctx ,
2008-02-21 19:17:37 +03:00
struct smb_iconv_convenience * iconv_convenience ) ;
2005-05-11 08:48:30 +04:00
NTSTATUS cldap_set_incoming_handler ( struct cldap_socket * cldap ,
void ( * handler ) ( struct cldap_socket * , struct ldap_message * ,
2006-01-10 01:12:53 +03:00
struct socket_address * ) ,
2005-05-11 08:48:30 +04:00
void * private ) ;
2005-05-10 06:01:25 +04:00
struct cldap_request * cldap_search_send ( struct cldap_socket * cldap ,
struct cldap_search * io ) ;
NTSTATUS cldap_search_recv ( struct cldap_request * req , TALLOC_CTX * mem_ctx ,
struct cldap_search * io ) ;
NTSTATUS cldap_search ( struct cldap_socket * cldap , TALLOC_CTX * mem_ctx ,
struct cldap_search * io ) ;
2005-05-12 12:25:35 +04:00
/*
a general cldap reply
*/
struct cldap_reply {
uint32_t messageid ;
2006-01-10 01:12:53 +03:00
struct socket_address * dest ;
2005-05-12 12:25:35 +04:00
struct ldap_SearchResEntry * response ;
struct ldap_Result * result ;
} ;
NTSTATUS cldap_reply_send ( struct cldap_socket * cldap , struct cldap_reply * io ) ;
2006-11-15 20:08:45 +03:00
NTSTATUS cldap_empty_reply ( struct cldap_socket * cldap ,
uint32_t message_id ,
struct socket_address * src ) ;
NTSTATUS cldap_error_reply ( struct cldap_socket * cldap ,
uint32_t message_id ,
struct socket_address * src ,
int resultcode ,
const char * errormessage ) ;
2005-05-10 06:01:25 +04:00
/*
a netlogon cldap request
*/
struct cldap_netlogon {
struct {
const char * dest_address ;
2007-12-04 01:33:16 +03:00
uint16_t dest_port ;
2005-05-10 06:01:25 +04:00
const char * realm ;
const char * host ;
2005-05-13 10:08:49 +04:00
const char * user ;
const char * domain_guid ;
const char * domain_sid ;
int acct_control ;
uint32_t version ;
2008-05-16 07:03:01 +04:00
bool map_response ;
2005-05-10 06:01:25 +04:00
} in ;
struct {
2008-05-16 07:03:01 +04:00
struct netlogon_samlogon_response netlogon ;
2005-05-10 06:01:25 +04:00
} out ;
} ;
struct cldap_request * cldap_netlogon_send ( struct cldap_socket * cldap ,
struct cldap_netlogon * io ) ;
NTSTATUS cldap_netlogon_recv ( struct cldap_request * req ,
TALLOC_CTX * mem_ctx ,
struct cldap_netlogon * io ) ;
NTSTATUS cldap_netlogon ( struct cldap_socket * cldap ,
TALLOC_CTX * mem_ctx , struct cldap_netlogon * io ) ;
2005-05-12 12:25:35 +04:00
NTSTATUS cldap_netlogon_reply ( struct cldap_socket * cldap ,
uint32_t message_id ,
2006-01-10 01:12:53 +03:00
struct socket_address * src ,
2005-05-12 12:25:35 +04:00
uint32_t version ,
2008-05-16 07:03:01 +04:00
struct netlogon_samlogon_response * netlogon ) ;