⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 common.c

📁 samba最新软件
💻 C
字号:
/*    Unix SMB/CIFS mplementation.   LDAP protocol helper functions for SAMBA      Copyright (C) Stefan Metzmacher 2004   Copyright (C) Simo Sorce 2004       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/>.   */#include "includes.h"#include "libcli/ldap/ldap_client.h"#include "torture/smbtorture.h"#include "torture/ldap/proto.h"NTSTATUS torture_ldap_bind(struct ldap_connection *conn, const char *userdn, const char *password){	NTSTATUS status;	status = ldap_bind_simple(conn, userdn, password);	if (!NT_STATUS_IS_OK(status)) {		printf("Failed to bind with provided credentials - %s\n", 		       nt_errstr(status));	}	return status;}NTSTATUS torture_ldap_bind_sasl(struct ldap_connection *conn, 				struct cli_credentials *creds, 				struct loadparm_context *lp_ctx){        NTSTATUS status;	status = ldap_bind_sasl(conn, creds, lp_ctx);	if (!NT_STATUS_IS_OK(status)) {		printf("Failed sasl bind with provided credentials - %s\n", 		       nt_errstr(status));	} 	return status;}/* open a ldap connection to a server */NTSTATUS torture_ldap_connection(struct torture_context *tctx, 					  struct ldap_connection **conn, 					  const char *url){	NTSTATUS status;	if (!url) {		printf("You must specify a url string\n");		return NT_STATUS_INVALID_PARAMETER;	}	*conn = ldap4_new_connection(tctx, tctx->lp_ctx, tctx->ev);	status = ldap_connect(*conn, url);	if (!NT_STATUS_IS_OK(status)) {		printf("Failed to connect to ldap server '%s' - %s\n",		       url, nt_errstr(status));	}	return status;}/* open a ldap connection to a server */NTSTATUS torture_ldap_connection2(struct torture_context *tctx, struct ldap_connection **conn, 				const char *url, const char *userdn, const char *password){        NTSTATUS status;	status = torture_ldap_connection(tctx, conn, url);	NT_STATUS_NOT_OK_RETURN(status);	status = ldap_bind_simple(*conn, userdn, password);	if (!NT_STATUS_IS_OK(status)) {		printf("Failed a simple ldap bind - %s\n", ldap_errstr(*conn, tctx, status));	} 	return status;}/* close an ldap connection to a server */NTSTATUS torture_ldap_close(struct ldap_connection *conn){	talloc_free(conn);	return NT_STATUS_OK;}NTSTATUS torture_ldap_init(void){	struct torture_suite *suite = torture_suite_create(talloc_autofree_context(), "LDAP");	torture_suite_add_simple_test(suite, "BENCH-CLDAP", torture_bench_cldap);	torture_suite_add_simple_test(suite, "BASIC", torture_ldap_basic);	torture_suite_add_simple_test(suite, "CLDAP", torture_cldap);	torture_suite_add_simple_test(suite, "SCHEMA", torture_ldap_schema);	torture_suite_add_simple_test(suite, "UPTODATEVECTOR", torture_ldap_uptodatevector);	suite->description = talloc_strdup(suite, "LDAP and CLDAP tests");	torture_register_suite(suite);	return NT_STATUS_OK;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -