2 * Unix SMB/CIFS implementation.
4 * Copyright (C) Guenther Deschner 2007-2008
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
21 #include "lib/netapi/netapi.h"
23 extern bool AllowDebugChange;
25 struct libnetapi_ctx *stat_ctx = NULL;
26 TALLOC_CTX *frame = NULL;
27 static bool libnetapi_initialized = false;
29 /****************************************************************
30 ****************************************************************/
32 NET_API_STATUS libnetapi_init(struct libnetapi_ctx **context)
34 struct libnetapi_ctx *ctx = NULL;
35 char *krb5_cc_env = NULL;
37 if (stat_ctx && libnetapi_initialized) {
39 return NET_API_STATUS_SUCCESS;
43 talloc_enable_leak_report();
45 frame = talloc_stackframe();
47 ctx = talloc_zero(frame, struct libnetapi_ctx);
50 return W_ERROR_V(WERR_NOMEM);
54 setup_logging("libnetapi", true);
57 x_setbuf(x_stderr, NULL);
58 AllowDebugChange = false;
62 if (!lp_load(get_dyn_CONFIGFILE(), true, false, false, false)) {
64 return W_ERROR_V(WERR_GENERAL_FAILURE);
67 AllowDebugChange = true;
73 BlockSignals(True, SIGPIPE);
75 krb5_cc_env = getenv(KRB5_ENV_CCNAME);
76 if (!krb5_cc_env || (strlen(krb5_cc_env) == 0)) {
77 ctx->krb5_cc_env = talloc_strdup(frame, "MEMORY:libnetapi");
78 setenv(KRB5_ENV_CCNAME, ctx->krb5_cc_env, 1);
81 libnetapi_initialized = true;
83 *context = stat_ctx = ctx;
85 return NET_API_STATUS_SUCCESS;
88 /****************************************************************
89 ****************************************************************/
91 NET_API_STATUS libnetapi_getctx(struct libnetapi_ctx **ctx)
95 return NET_API_STATUS_SUCCESS;
98 return libnetapi_init(ctx);
101 /****************************************************************
102 ****************************************************************/
104 NET_API_STATUS libnetapi_free(struct libnetapi_ctx *ctx)
107 if (ctx->krb5_cc_env) {
108 char *env = getenv(KRB5_ENV_CCNAME);
109 if (env && (strequal(ctx->krb5_cc_env, env))) {
110 unsetenv(KRB5_ENV_CCNAME);
128 return NET_API_STATUS_SUCCESS;
131 /****************************************************************
132 ****************************************************************/
134 NET_API_STATUS libnetapi_set_debuglevel(struct libnetapi_ctx *ctx,
135 const char *debuglevel)
137 AllowDebugChange = true;
138 ctx->debuglevel = talloc_strdup(ctx, debuglevel);
139 if (!debug_parse_levels(debuglevel)) {
140 return W_ERROR_V(WERR_GENERAL_FAILURE);
142 return NET_API_STATUS_SUCCESS;
145 /****************************************************************
146 ****************************************************************/
148 NET_API_STATUS libnetapi_get_debuglevel(struct libnetapi_ctx *ctx,
151 *debuglevel = ctx->debuglevel;
152 return NET_API_STATUS_SUCCESS;
155 /****************************************************************
156 ****************************************************************/
158 NET_API_STATUS libnetapi_set_username(struct libnetapi_ctx *ctx,
159 const char *username)
161 TALLOC_FREE(ctx->username);
162 ctx->username = talloc_strdup(ctx, username);
163 if (!ctx->username) {
164 return W_ERROR_V(WERR_NOMEM);
166 return NET_API_STATUS_SUCCESS;
169 NET_API_STATUS libnetapi_set_password(struct libnetapi_ctx *ctx,
170 const char *password)
172 TALLOC_FREE(ctx->password);
173 ctx->password = talloc_strdup(ctx, password);
174 if (!ctx->password) {
175 return W_ERROR_V(WERR_NOMEM);
177 return NET_API_STATUS_SUCCESS;
180 NET_API_STATUS libnetapi_set_workgroup(struct libnetapi_ctx *ctx,
181 const char *workgroup)
183 TALLOC_FREE(ctx->workgroup);
184 ctx->workgroup = talloc_strdup(ctx, workgroup);
185 if (!ctx->workgroup) {
186 return W_ERROR_V(WERR_NOMEM);
188 return NET_API_STATUS_SUCCESS;
191 /****************************************************************
192 ****************************************************************/
194 const char *libnetapi_errstr(NET_API_STATUS status)
196 if (status & 0xc0000000) {
197 return get_friendly_nt_error_msg(NT_STATUS(status));
200 return get_friendly_werror_msg(W_ERROR(status));
203 /****************************************************************
204 ****************************************************************/
206 NET_API_STATUS libnetapi_set_error_string(struct libnetapi_ctx *ctx,
207 const char *format, ...)
211 TALLOC_FREE(ctx->error_string);
213 va_start(args, format);
214 ctx->error_string = talloc_vasprintf(ctx, format, args);
217 if (!ctx->error_string) {
218 return W_ERROR_V(WERR_NOMEM);
220 return NET_API_STATUS_SUCCESS;
223 /****************************************************************
224 ****************************************************************/
226 const char *libnetapi_get_error_string(struct libnetapi_ctx *ctx,
227 NET_API_STATUS status)
229 struct libnetapi_ctx *tmp_ctx = ctx;
232 status = libnetapi_getctx(&tmp_ctx);
238 if (tmp_ctx->error_string) {
239 return tmp_ctx->error_string;
242 return libnetapi_errstr(status);
245 /****************************************************************
246 ****************************************************************/
248 NET_API_STATUS NetApiBufferFree(void *buffer)
251 return W_ERROR_V(WERR_INSUFFICIENT_BUFFER);
256 return NET_API_STATUS_SUCCESS;