2011-05-31 00:33:13 +02:00
/*
* Unix SMB / CIFS implementation .
* ads ( active directory ) utility library
*
* Copyright ( C ) Andrew Bartlett 2001
* Copyright ( C ) Andrew Tridgell 2001
* Copyright ( C ) Remus Koos ( remuskoos @ yahoo . com ) 2001
* Copyright ( C ) Alexey Kotovich 2002
* Copyright ( C ) Jim McDonough < jmcd @ us . ibm . com > 2002 - 2003
* Copyright ( C ) Luke Howard 2003
* Copyright ( C ) Guenther Deschner 2003 - 2008
* Copyright ( C ) Rakesh Patel 2004
* Copyright ( C ) Dan Perry 2004
* Copyright ( C ) Jeremy Allison 2004
* Copyright ( C ) Gerald Carter 2006
* Copyright ( C ) Stefan Metzmacher 2007
*
* 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/>.
*/
2011-05-31 00:34:17 +02:00
# ifndef _LIBADS_ADS_PROTO_H_
# define _LIBADS_ADS_PROTO_H_
2022-04-25 18:08:33 +02:00
struct cli_credentials ;
2019-08-13 17:41:40 +02:00
enum ads_sasl_state_e {
ADS_SASL_PLAIN = 0 ,
ADS_SASL_SIGN ,
ADS_SASL_SEAL ,
} ;
2010-07-02 00:32:52 +02:00
/* The following definitions come from libads/ads_struct.c */
2022-06-15 10:38:51 +02:00
ADS_STATUS ads_build_path ( const char * realm ,
const char * sep ,
const char * field ,
int reverse ,
char * * _path ) ;
2022-06-15 11:36:25 +02:00
ADS_STATUS ads_build_dn ( const char * realm , TALLOC_CTX * mem_ctx , char * * _dn ) ;
2010-07-02 00:32:52 +02:00
char * ads_build_domain ( const char * dn ) ;
2022-05-26 17:28:34 +02:00
ADS_STRUCT * ads_init ( TALLOC_CTX * mem_ctx ,
const char * realm ,
2010-07-02 00:32:52 +02:00
const char * workgroup ,
2019-08-13 17:41:40 +02:00
const char * ldap_server ,
enum ads_sasl_state_e sasl_state ) ;
2020-07-02 10:59:18 +02:00
bool ads_set_sasl_wrap_flags ( ADS_STRUCT * ads , unsigned flags ) ;
2010-07-02 00:32:52 +02:00
/* The following definitions come from libads/disp_sec.c */
void ads_disp_sd ( ADS_STRUCT * ads , TALLOC_CTX * mem_ctx , struct security_descriptor * sd ) ;
/* The following definitions come from libads/kerberos_keytab.c */
2018-02-08 17:33:08 +00:00
int ads_keytab_add_entry ( ADS_STRUCT * ads , const char * srvPrinc ,
bool update_ads ) ;
2022-10-26 11:36:01 +02:00
int ads_keytab_delete_entry ( ADS_STRUCT * ads , const char * srvPrinc ) ;
2010-07-02 00:32:52 +02:00
int ads_keytab_flush ( ADS_STRUCT * ads ) ;
int ads_keytab_create_default ( ADS_STRUCT * ads ) ;
int ads_keytab_list ( const char * keytab_name ) ;
2018-01-24 14:26:03 +00:00
/* The following definitions come from libads/net_ads_setspn.c */
bool ads_setspn_list ( ADS_STRUCT * ads , const char * machine ) ;
2018-01-24 14:41:06 +00:00
bool ads_setspn_add ( ADS_STRUCT * ads , const char * machine_name ,
const char * spn ) ;
2018-01-24 14:51:03 +00:00
bool ads_setspn_delete ( ADS_STRUCT * ads , const char * machine_name ,
const char * spn ) ;
2010-07-02 00:32:52 +02:00
/* The following definitions come from libads/krb5_errs.c */
/* The following definitions come from libads/ldap.c */
bool ads_sitename_match ( ADS_STRUCT * ads ) ;
bool ads_closest_dc ( ADS_STRUCT * ads ) ;
2024-03-05 17:45:35 +01:00
ADS_STATUS ads_connect_cldap_only ( ADS_STRUCT * ads ) ;
2022-04-27 13:11:26 +02:00
ADS_STATUS ads_connect_creds ( ADS_STRUCT * ads , struct cli_credentials * creds ) ;
2022-04-28 18:38:17 +02:00
ADS_STATUS ads_connect_simple_anon ( ADS_STRUCT * ads ) ;
2022-04-28 18:53:03 +02:00
ADS_STATUS ads_connect_machine ( ADS_STRUCT * ads ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_connect ( ADS_STRUCT * ads ) ;
ADS_STATUS ads_connect_user_creds ( ADS_STRUCT * ads ) ;
2020-08-07 20:18:50 -07:00
void ads_zero_ldap ( ADS_STRUCT * ads ) ;
2010-07-02 00:32:52 +02:00
void ads_disconnect ( ADS_STRUCT * ads ) ;
ADS_STATUS ads_do_search_all_fn ( ADS_STRUCT * ads , const char * bind_path ,
int scope , const char * expr , const char * * attrs ,
bool ( * fn ) ( ADS_STRUCT * , char * , void * * , void * ) ,
void * data_area ) ;
char * ads_parent_dn ( const char * dn ) ;
ADS_MODLIST ads_init_mods ( TALLOC_CTX * ctx ) ;
ADS_STATUS ads_mod_str ( TALLOC_CTX * ctx , ADS_MODLIST * mods ,
const char * name , const char * val ) ;
ADS_STATUS ads_mod_strlist ( TALLOC_CTX * ctx , ADS_MODLIST * mods ,
const char * name , const char * * vals ) ;
ADS_STATUS ads_gen_mod ( ADS_STRUCT * ads , const char * mod_dn , ADS_MODLIST mods ) ;
ADS_STATUS ads_gen_add ( ADS_STRUCT * ads , const char * new_dn , ADS_MODLIST mods ) ;
ADS_STATUS ads_del_dn ( ADS_STRUCT * ads , char * del_dn ) ;
char * ads_ou_string ( ADS_STRUCT * ads , const char * org_unit ) ;
char * ads_default_ou_string ( ADS_STRUCT * ads , const char * wknguid ) ;
ADS_STATUS ads_add_strlist ( TALLOC_CTX * ctx , ADS_MODLIST * mods ,
const char * name , const char * * vals ) ;
2015-04-18 08:40:14 -07:00
uint32_t ads_get_kvno ( ADS_STRUCT * ads , const char * account_name ) ;
2010-07-02 00:32:52 +02:00
uint32_t ads_get_machine_kvno ( ADS_STRUCT * ads , const char * machine_name ) ;
2014-09-24 09:22:03 +02:00
2014-09-24 09:23:58 +02:00
bool ads_element_in_array ( const char * * el_array , size_t num_el , const char * el ) ;
2014-09-24 09:22:03 +02:00
ADS_STATUS ads_get_service_principal_names ( TALLOC_CTX * mem_ctx ,
ADS_STRUCT * ads ,
const char * machine_name ,
char * * * spn_array ,
size_t * num_spns ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_clear_service_principal_names ( ADS_STRUCT * ads , const char * machine_name ) ;
2018-02-16 16:52:01 +00:00
ADS_STATUS ads_add_service_principal_names ( ADS_STRUCT * ads , const char * machine_name ,
const char * * spns ) ;
2016-03-11 16:04:52 +01:00
ADS_STATUS ads_create_machine_acct ( ADS_STRUCT * ads ,
const char * machine_name ,
2019-08-13 16:34:34 +02:00
const char * machine_password ,
2016-03-11 16:04:52 +01:00
const char * org_unit ,
2019-08-13 16:34:34 +02:00
uint32_t etype_list ,
const char * dns_domain_name ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_move_machine_acct ( ADS_STRUCT * ads , const char * machine_name ,
const char * org_unit , bool * moved ) ;
int ads_count_replies ( ADS_STRUCT * ads , void * res ) ;
2015-04-18 08:40:14 -07:00
ADS_STATUS ads_USN ( ADS_STRUCT * ads , uint32_t * usn ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_current_time ( ADS_STRUCT * ads ) ;
2015-04-18 08:40:14 -07:00
ADS_STATUS ads_domain_func_level ( ADS_STRUCT * ads , uint32_t * val ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_domain_sid ( ADS_STRUCT * ads , struct dom_sid * sid ) ;
ADS_STATUS ads_site_dn ( ADS_STRUCT * ads , TALLOC_CTX * mem_ctx , const char * * site_name ) ;
ADS_STATUS ads_site_dn_for_machine ( ADS_STRUCT * ads , TALLOC_CTX * mem_ctx , const char * computer_name , const char * * site_dn ) ;
ADS_STATUS ads_upn_suffixes ( ADS_STRUCT * ads , TALLOC_CTX * mem_ctx , char * * * suffixes , size_t * num_suffixes ) ;
ADS_STATUS ads_get_joinable_ous ( ADS_STRUCT * ads ,
TALLOC_CTX * mem_ctx ,
char * * * ous ,
size_t * num_ous ) ;
ADS_STATUS ads_get_sid_from_extended_dn ( TALLOC_CTX * mem_ctx ,
const char * extended_dn ,
enum ads_extended_dn_flags flags ,
struct dom_sid * sid ) ;
char * ads_get_dnshostname ( ADS_STRUCT * ads , TALLOC_CTX * ctx , const char * machine_name ) ;
2020-05-27 15:36:28 +02:00
ADS_STATUS ads_get_additional_dns_hostnames ( TALLOC_CTX * mem_ctx ,
ADS_STRUCT * ads ,
const char * machine_name ,
char * * * hostnames_array ,
size_t * num_hostnames ) ;
2010-07-02 00:32:52 +02:00
char * ads_get_upn ( ADS_STRUCT * ads , TALLOC_CTX * ctx , const char * machine_name ) ;
2018-01-12 14:22:34 +00:00
bool ads_has_samaccountname ( ADS_STRUCT * ads , TALLOC_CTX * ctx , const char * machine_name ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_join_realm ( ADS_STRUCT * ads , const char * machine_name ,
2015-04-18 08:40:14 -07:00
uint32_t account_type , const char * org_unit ) ;
2010-07-02 00:32:52 +02:00
ADS_STATUS ads_leave_realm ( ADS_STRUCT * ads , const char * hostname ) ;
ADS_STATUS ads_find_samaccount ( ADS_STRUCT * ads ,
TALLOC_CTX * mem_ctx ,
const char * samaccountname ,
2015-04-18 08:40:14 -07:00
uint32_t * uac_ret ,
2010-07-02 00:32:52 +02:00
const char * * dn_ret ) ;
ADS_STATUS ads_config_path ( ADS_STRUCT * ads ,
TALLOC_CTX * mem_ctx ,
char * * config_path ) ;
const char * ads_get_extended_right_name_by_guid ( ADS_STRUCT * ads ,
const char * config_path ,
TALLOC_CTX * mem_ctx ,
const struct GUID * rights_guid ) ;
ADS_STATUS ads_check_ou_dn ( TALLOC_CTX * mem_ctx ,
ADS_STRUCT * ads ,
const char * * account_ou ) ;
/* The following definitions come from libads/ldap_printer.c */
ADS_STATUS ads_mod_printer_entry ( ADS_STRUCT * ads , char * prt_dn ,
TALLOC_CTX * ctx , const ADS_MODLIST * mods ) ;
ADS_STATUS ads_add_printer_entry ( ADS_STRUCT * ads , char * prt_dn ,
TALLOC_CTX * ctx , ADS_MODLIST * mods ) ;
WERROR get_remote_printer_publishing_data ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
ADS_MODLIST * mods ,
const char * printer ) ;
/* The following definitions come from libads/ldap_user.c */
ADS_STATUS ads_add_user_acct ( ADS_STRUCT * ads , const char * user ,
const char * container , const char * fullname ) ;
ADS_STATUS ads_add_group_acct ( ADS_STRUCT * ads , const char * group ,
const char * container , const char * comment ) ;
/* The following definitions come from libads/ldap_utils.c */
ADS_STATUS ads_ranged_search ( ADS_STRUCT * ads ,
TALLOC_CTX * mem_ctx ,
int scope ,
const char * base ,
const char * filter ,
void * args ,
const char * range_attr ,
char * * * strings ,
size_t * num_strings ) ;
/* The following definitions come from libads/sasl.c */
2022-04-28 17:51:57 +02:00
NTSTATUS ads_simple_creds ( TALLOC_CTX * mem_ctx ,
const char * account_domain ,
const char * account_name ,
const char * password ,
struct cli_credentials * * _creds ) ;
2022-04-27 13:11:26 +02:00
ADS_STATUS ads_sasl_bind ( ADS_STRUCT * ads , struct cli_credentials * creds ) ;
2010-07-02 00:32:52 +02:00
/* The following definitions come from libads/sasl_wrapping.c */
2017-05-05 15:37:20 +03:00
ADS_STATUS ads_setup_sasl_wrapping ( struct ads_saslwrap * wrap , LDAP * ld ,
2010-07-02 00:32:52 +02:00
const struct ads_saslwrap_ops * ops ,
void * private_data ) ;
2017-05-05 15:37:20 +03:00
void ndr_print_ads_saslwrap_struct ( struct ndr_print * ndr ,
const char * name ,
const struct ads_saslwrap * r ) ;
2010-07-02 00:32:52 +02:00
2024-01-30 10:27:58 +01:00
/* The following definitions come from libads/tls_wrapping.c */
void ndr_print_ads_tlswrap_struct ( struct ndr_print * ndr ,
const char * name ,
const struct ads_tlswrap * r ) ;
ADS_STATUS ads_setup_tls_wrapping ( struct ads_tlswrap * wrap ,
LDAP * ld ,
const char * server_name ) ;
const DATA_BLOB * ads_tls_channel_bindings ( struct ads_tlswrap * wrap ) ;
2010-07-02 00:32:52 +02:00
/* The following definitions come from libads/util.c */
ADS_STATUS ads_change_trust_account_password ( ADS_STRUCT * ads , char * host_principal ) ;
2011-05-31 00:34:17 +02:00
2018-01-29 17:51:15 +00:00
struct spn_struct {
const char * serviceclass ;
const char * servicename ;
const char * host ;
int32_t port ;
} ;
/* parse a windows style SPN, returns NULL if parsing fails */
struct spn_struct * parse_spn ( TALLOC_CTX * ctx , const char * srvprinc ) ;
2011-05-31 00:34:17 +02:00
# endif /* _LIBADS_ADS_PROTO_H_ */