1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00
samba-mirror/source4/auth/credentials/credentials.i
Andrew Bartlett 142fbfb3c1 Fix and test python scripts and kerberos
This fixes up the python credentials interface in a number of areas,
with the aim of supporting '-k yes' as a command line option.  (This
enables the use of kerberos).

As such, I've had to change the get_credentials call to take a
loadparm context, so that the credentials can be initialised
correctly.

The test_kinit script has been modified to prove that this continues
to work, as well as to provide greater code coverage of the kerberos
paths.

Andrew Bartlett
(This used to be commit 727ef40c2b)
2008-03-28 21:57:15 +11:00

127 lines
3.5 KiB
OpenEdge ABL

/*
Unix SMB/CIFS implementation.
Copyright (C) Jelmer Vernooij <jelmer@samba.org> 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/>.
*/
%module(package="samba.credentials") credentials
%{
/* Include headers */
#include <stdint.h>
#include <stdbool.h>
#include "includes.h"
#include "auth/credentials/credentials.h"
#include "param/param.h"
#include "lib/cmdline/credentials.h"
typedef struct cli_credentials cli_credentials;
%}
%import "carrays.i"
%import "typemaps.i"
%import "param/param.i"
%typemap(default,noblock=1) struct cli_credentials * {
$1 = NULL;
}
%constant int AUTO_USE_KERBEROS = CRED_AUTO_USE_KERBEROS;
%constant int DONT_USE_KERBEROS = CRED_DONT_USE_KERBEROS;
%constant int MUST_USE_KERBEROS = CRED_MUST_USE_KERBEROS;
%{
#include "librpc/gen_ndr/samr.h" /* for struct samr_Password */
%}
%typemap(out,noblock=1) struct samr_Password * {
$result = PyString_FromStringAndSize((char *)$1->hash, 16);
}
%talloctype(cli_credentials);
%rename(Credentials) cli_credentials;
typedef struct cli_credentials {
%extend {
cli_credentials(void) {
return cli_credentials_init(NULL);
}
/* username */
const char *get_username(void);
bool set_username(const char *value,
enum credentials_obtained=CRED_SPECIFIED);
/* password */
const char *get_password(void);
bool set_password(const char *val,
enum credentials_obtained=CRED_SPECIFIED);
/* domain */
const char *get_domain(void);
bool set_domain(const char *val,
enum credentials_obtained=CRED_SPECIFIED);
/* realm */
const char *get_realm(void);
bool set_realm(const char *val,
enum credentials_obtained=CRED_SPECIFIED);
/* Kerberos */
void set_kerberos_state(enum credentials_use_kerberos use_kerberos);
void parse_string(const char *text,
enum credentials_obtained=CRED_SPECIFIED);
/* bind dn */
const char *get_bind_dn(void);
bool set_bind_dn(const char *bind_dn);
void set_anonymous();
/* workstation name */
const char *get_workstation(void);
bool set_workstation(const char *workstation,
enum credentials_obtained obtained=CRED_SPECIFIED);
void guess(struct loadparm_context *lp_ctx);
bool is_anonymous(void);
const struct samr_Password *get_nt_hash(TALLOC_CTX *mem_ctx);
bool authentication_requested(void);
bool wrong_password(void);
bool set_cmdline_callbacks();
}
} cli_credentials;
%{
struct cli_credentials *cli_credentials_from_py_object(PyObject *py_obj)
{
struct cli_credentials *ret;
if (py_obj == Py_None) {
return cli_credentials_init_anon(NULL);
}
if (SWIG_ConvertPtr(py_obj, (void *)&ret, SWIGTYPE_p_cli_credentials, 0 | 0 ) < 0) {
return NULL;
}
return ret;
}
%}