2 Unix SMB/CIFS implementation.
3 Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2007
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>.
19 %module(package="samba.credentials") credentials
28 #include "auth/credentials/credentials.h"
29 #include "param/param.h"
30 #include "lib/cmdline/credentials.h"
31 typedef struct cli_credentials cli_credentials;
36 %import "param/param.i"
38 %typemap(default,noblock=1) struct cli_credentials * {
42 %constant int AUTO_USE_KERBEROS = CRED_AUTO_USE_KERBEROS;
43 %constant int DONT_USE_KERBEROS = CRED_DONT_USE_KERBEROS;
44 %constant int MUST_USE_KERBEROS = CRED_MUST_USE_KERBEROS;
47 #include "librpc/gen_ndr/samr.h" /* for struct samr_Password */
50 %typemap(out,noblock=1) struct samr_Password * {
51 $result = PyString_FromStringAndSize((char *)$1->hash, 16);
54 %talloctype(cli_credentials);
55 %rename(Credentials) cli_credentials;
56 typedef struct cli_credentials {
58 cli_credentials(void) {
59 return cli_credentials_init(NULL);
62 const char *get_username(void);
63 bool set_username(const char *value,
64 enum credentials_obtained=CRED_SPECIFIED);
67 const char *get_password(void);
68 bool set_password(const char *val,
69 enum credentials_obtained=CRED_SPECIFIED);
72 const char *get_domain(void);
73 bool set_domain(const char *val,
74 enum credentials_obtained=CRED_SPECIFIED);
77 const char *get_realm(void);
78 bool set_realm(const char *val,
79 enum credentials_obtained=CRED_SPECIFIED);
82 void set_kerberos_state(enum credentials_use_kerberos use_kerberos);
84 void parse_string(const char *text,
85 enum credentials_obtained=CRED_SPECIFIED);
88 const char *get_bind_dn(void);
89 bool set_bind_dn(const char *bind_dn);
93 /* workstation name */
94 const char *get_workstation(void);
95 bool set_workstation(const char *workstation,
96 enum credentials_obtained obtained=CRED_SPECIFIED);
98 NTSTATUS set_machine_account(struct loadparm_context *lp_ctx);
100 void guess(struct loadparm_context *lp_ctx);
101 bool is_anonymous(void);
103 const struct samr_Password *get_nt_hash(TALLOC_CTX *mem_ctx);
105 bool authentication_requested(void);
107 bool wrong_password(void);
109 bool set_cmdline_callbacks();
114 struct cli_credentials *cli_credentials_from_py_object(PyObject *py_obj)
116 struct cli_credentials *ret;
118 if (py_obj == Py_None) {
119 return cli_credentials_init_anon(NULL);
122 if (SWIG_ConvertPtr(py_obj, (void *)&ret, SWIGTYPE_p_cli_credentials, 0 | 0 ) < 0) {