#include "scripting/python/modules.h"
#include "lib/talloc/pytalloc.h"
#include <tevent.h>
+#include "librpc/rpc/pyrpc_util.h"
static PyObject *py_get_name_by_authtype(PyObject *self, PyObject *args)
{
if (!PyArg_ParseTuple(args, "i", &type))
return NULL;
- security = (struct gensec_security *)py_talloc_get_ptr(self);
+ security = py_talloc_get_type(self, struct gensec_security);
name = gensec_get_name_by_authtype(security, type);
if (name == NULL)
static PyObject *py_gensec_session_info(PyObject *self)
{
NTSTATUS status;
- struct gensec_security *security = (struct gensec_security *)py_talloc_get_ptr(self);
+ PyObject *py_session_info;
+ struct gensec_security *security = py_talloc_get_type(self, struct gensec_security);
struct auth_session_info *info;
if (security->ops == NULL) {
PyErr_SetString(PyExc_RuntimeError, "no mechanism selected");
return NULL;
}
- /* FIXME */
- Py_RETURN_NONE;
+ py_session_info = py_return_ndr_struct("samba.auth", "session_info",
+ info, info);
+ return py_session_info;
}
static PyObject *py_gensec_start_mech_by_name(PyObject *self, PyObject *args)
{
char *name;
- struct gensec_security *security = (struct gensec_security *)py_talloc_get_ptr(self);
+ struct gensec_security *security = py_talloc_get_type(self, struct gensec_security);
NTSTATUS status;
if (!PyArg_ParseTuple(args, "s", &name))
static PyObject *py_gensec_start_mech_by_authtype(PyObject *self, PyObject *args)
{
int authtype, level;
- struct gensec_security *security = (struct gensec_security *)py_talloc_get_ptr(self);
+ struct gensec_security *security = py_talloc_get_type(self, struct gensec_security);
NTSTATUS status;
if (!PyArg_ParseTuple(args, "ii", &authtype, &level))
return NULL;
static PyObject *py_auth_session_get_security_token(PyObject *self, void *closure)
{
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
PyObject *py_security_token;
py_security_token = py_return_ndr_struct("samba.dcerpc.security", "token",
session->security_token, session->security_token);
static int py_auth_session_set_security_token(PyObject *self, PyObject *value, void *closure)
{
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
session->security_token = talloc_reference(session, py_talloc_get_ptr(value));
return 0;
}
static PyObject *py_auth_session_get_session_key(PyObject *self, void *closure)
{
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
return PyString_FromStringAndSize((char *)session->session_key.data, session->session_key.length);
}
static int py_auth_session_set_session_key(PyObject *self, PyObject *value, void *closure)
{
DATA_BLOB val;
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
val.data = (uint8_t *)PyString_AsString(value);
val.length = PyString_Size(value);
static PyObject *py_auth_session_get_credentials(PyObject *self, void *closure)
{
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
PyObject *py_credentials;
/* This is evil, as the credentials are not IDL structures */
py_credentials = py_return_ndr_struct("samba.credentials", "Credentials", session->credentials, session->credentials);
static int py_auth_session_set_credentials(PyObject *self, PyObject *value, void *closure)
{
- struct auth_session_info *session = (struct auth_session_info *)py_talloc_get_ptr(self);
+ struct auth_session_info *session = py_talloc_get_type(self, struct auth_session_info);
session->credentials = talloc_reference(session, PyCredentials_AsCliCredentials(value));
return 0;
}