mirror of
https://github.com/samba-team/samba.git
synced 2025-11-21 12:23:50 +03:00
idl. This allows us to pass a buffer of bytes returned from a spoolss call and convert it to a Python dictionary. Works for enumprinters level 1!
365 lines
8.3 KiB
C
365 lines
8.3 KiB
C
/* Tastes like -*- C -*- */
|
|
|
|
/*
|
|
Unix SMB/CIFS implementation.
|
|
|
|
Swig interface to librpc functions.
|
|
|
|
Copyright (C) Tim Potter 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 2 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, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
%module dcerpc
|
|
|
|
%{
|
|
|
|
/* This symbol is used in both includes.h and Python.h which causes an
|
|
annoying compiler warning. */
|
|
|
|
#ifdef HAVE_FSTAT
|
|
#undef HAVE_FSTAT
|
|
#endif
|
|
|
|
#include "includes.h"
|
|
|
|
#undef strcpy
|
|
|
|
PyObject *ntstatus_exception, *werror_exception;
|
|
|
|
/* Set up return of a dcerpc.NTSTATUS exception */
|
|
|
|
void set_ntstatus_exception(int status)
|
|
{
|
|
PyObject *obj = Py_BuildValue("(i,s)", status,
|
|
nt_errstr(NT_STATUS(status)));
|
|
|
|
PyErr_SetObject(ntstatus_exception, obj);
|
|
}
|
|
|
|
void set_werror_exception(int status)
|
|
{
|
|
PyObject *obj = Py_BuildValue("(i,s)", status,
|
|
win_errstr(W_ERROR(status)));
|
|
|
|
PyErr_SetObject(werror_exception, obj);
|
|
}
|
|
|
|
/* Conversion functions for scalar types */
|
|
|
|
uint8 uint8_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyInt_Check(obj) && !PyLong_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (uint8)PyLong_AsLong(obj);
|
|
else
|
|
return (uint8)PyInt_AsLong(obj);
|
|
}
|
|
|
|
PyObject *uint8_to_python(uint8 obj)
|
|
{
|
|
return PyInt_FromLong(obj);
|
|
}
|
|
|
|
uint16 uint16_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyInt_Check(obj) && !PyLong_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (uint16)PyLong_AsLong(obj);
|
|
else
|
|
return (uint16)PyInt_AsLong(obj);
|
|
}
|
|
|
|
PyObject *uint16_to_python(uint16 obj)
|
|
{
|
|
return PyInt_FromLong(obj);
|
|
}
|
|
|
|
uint32 uint32_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyLong_Check(obj) && !PyInt_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (uint32)PyLong_AsLong(obj);
|
|
else
|
|
return (uint32)PyInt_AsLong(obj);
|
|
}
|
|
|
|
PyObject *uint32_to_python(uint32 obj)
|
|
{
|
|
return PyLong_FromLong(obj);
|
|
}
|
|
|
|
int64 int64_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyLong_Check(obj) && !PyInt_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (int64)PyLong_AsLongLong(obj);
|
|
else
|
|
return (int64)PyInt_AsLong(obj);
|
|
}
|
|
|
|
PyObject *int64_to_python(int64 obj)
|
|
{
|
|
return PyLong_FromLongLong(obj);
|
|
}
|
|
|
|
uint64 uint64_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyLong_Check(obj) && !PyInt_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (uint64)PyLong_AsUnsignedLongLong(obj);
|
|
else
|
|
return (uint64)PyInt_AsLong(obj);
|
|
}
|
|
|
|
PyObject *uint64_to_python(uint64 obj)
|
|
{
|
|
return PyLong_FromUnsignedLongLong(obj);
|
|
}
|
|
|
|
NTTIME NTTIME_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyLong_Check(obj) && !PyInt_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (NTTIME)PyLong_AsUnsignedLongLong(obj);
|
|
else
|
|
return (NTTIME)PyInt_AsUnsignedLongMask(obj);
|
|
}
|
|
|
|
PyObject *NTTIME_to_python(NTTIME obj)
|
|
{
|
|
return PyLong_FromUnsignedLongLong(obj);
|
|
}
|
|
|
|
HYPER_T HYPER_T_from_python(PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (!PyLong_Check(obj) && !PyInt_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting int or long value for %s", name);
|
|
return 0;
|
|
}
|
|
|
|
if (PyLong_Check(obj))
|
|
return (HYPER_T)PyLong_AsUnsignedLongLong(obj);
|
|
else
|
|
return (HYPER_T)PyInt_AsUnsignedLongMask(obj);
|
|
}
|
|
|
|
PyObject *HYPER_T_to_python(HYPER_T obj)
|
|
{
|
|
return PyLong_FromUnsignedLongLong(obj);
|
|
}
|
|
|
|
/* Conversion functions for types that we don't want generated automatically.
|
|
This is mostly security realted stuff in misc.idl */
|
|
|
|
char *string_ptr_from_python(TALLOC_CTX *mem_ctx, PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return NULL;
|
|
}
|
|
|
|
if (obj == Py_None)
|
|
return NULL;
|
|
|
|
if (!PyString_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting string value for %s", name);
|
|
return NULL;
|
|
}
|
|
|
|
return PyString_AsString(obj);
|
|
}
|
|
|
|
PyObject *string_ptr_to_python(TALLOC_CTX *mem_ctx, char *obj)
|
|
{
|
|
if (obj == NULL) {
|
|
Py_INCREF(Py_None);
|
|
return Py_None;
|
|
}
|
|
|
|
return PyString_FromString(obj);
|
|
}
|
|
|
|
#define dom_sid2_ptr_to_python dom_sid_ptr_to_python
|
|
#define dom_sid2_ptr_from_python dom_sid_ptr_from_python
|
|
|
|
void DATA_BLOB_ptr_from_python(TALLOC_CTX *mem_ctx, DATA_BLOB **s,
|
|
PyObject *obj, char *name)
|
|
{
|
|
if (obj == NULL) {
|
|
PyErr_Format(PyExc_ValueError, "Expecting key %s", name);
|
|
return;
|
|
}
|
|
|
|
if (obj == Py_None) {
|
|
*s = NULL;
|
|
return;
|
|
}
|
|
|
|
if (!PyString_Check(obj)) {
|
|
PyErr_Format(PyExc_TypeError, "Expecting string value for key '%s'", name);
|
|
return;
|
|
}
|
|
|
|
*s = talloc(mem_ctx, sizeof(DATA_BLOB));
|
|
|
|
(*s)->length = PyString_Size(obj);
|
|
(*s)->data = PyString_AsString(obj);
|
|
}
|
|
|
|
PyObject *DATA_BLOB_to_python(DATA_BLOB obj)
|
|
{
|
|
return PyString_FromStringAndSize(obj.data, obj.length);
|
|
}
|
|
|
|
%}
|
|
|
|
%include "samba.i"
|
|
|
|
%pythoncode %{
|
|
NTSTATUS = _dcerpc.NTSTATUS
|
|
WERROR = _dcerpc.WERROR
|
|
%}
|
|
|
|
%init %{
|
|
setup_logging("python", DEBUG_STDOUT);
|
|
lp_load(dyn_CONFIGFILE, True, False, False);
|
|
load_interfaces();
|
|
ntstatus_exception = PyErr_NewException("_dcerpc.NTSTATUS", NULL, NULL);
|
|
werror_exception = PyErr_NewException("_dcerpc.WERROR", NULL, NULL);
|
|
PyDict_SetItemString(d, "NTSTATUS", ntstatus_exception);
|
|
PyDict_SetItemString(d, "WERROR", werror_exception);
|
|
%}
|
|
|
|
%typemap(in, numinputs=0) struct dcerpc_pipe **OUT (struct dcerpc_pipe *temp_dcerpc_pipe) {
|
|
$1 = &temp_dcerpc_pipe;
|
|
}
|
|
|
|
%typemap(in, numinputs=0) TALLOC_CTX * {
|
|
$1 = talloc_init("$symname");
|
|
}
|
|
|
|
%typemap(freearg) TALLOC_CTX * {
|
|
talloc_free($1);
|
|
}
|
|
|
|
%typemap(argout) struct dcerpc_pipe ** {
|
|
long status = PyLong_AsLong(resultobj);
|
|
|
|
/* Throw exception if result was not OK */
|
|
|
|
if (status != 0) {
|
|
set_ntstatus_exception(status);
|
|
return NULL;
|
|
}
|
|
|
|
/* Set REF_ALLOC flag so we don't have to do too much extra
|
|
mucking around with ref variables in ndr unmarshalling. */
|
|
|
|
(*$1)->flags |= DCERPC_NDR_REF_ALLOC;
|
|
|
|
/* Return swig handle on dcerpc_pipe */
|
|
|
|
resultobj = SWIG_NewPointerObj(*$1, SWIGTYPE_p_dcerpc_pipe, 0);
|
|
}
|
|
|
|
%types(struct dcerpc_pipe *);
|
|
|
|
%rename(pipe_connect) dcerpc_pipe_connect;
|
|
|
|
NTSTATUS dcerpc_pipe_connect(struct dcerpc_pipe **OUT,
|
|
const char *binding,
|
|
const char *pipe_uuid,
|
|
uint32 pipe_version,
|
|
const char *domain,
|
|
const char *username,
|
|
const char *password);
|
|
|
|
%typemap(in) DATA_BLOB * (DATA_BLOB temp_data_blob) {
|
|
temp_data_blob.data = PyString_AsString($input);
|
|
temp_data_blob.length = PyString_Size($input);
|
|
$1 = &temp_data_blob;
|
|
}
|
|
|
|
%include "librpc/gen_ndr/misc.i"
|
|
%include "librpc/gen_ndr/lsa.i"
|
|
%include "librpc/gen_ndr/samr.i"
|
|
%include "librpc/gen_ndr/winreg.i"
|
|
%include "librpc/gen_ndr/spoolss.i"
|
|
|
|
/* The status codes must be included last otherwise the automatically
|
|
generated .i files get confused. This is kind of yucky. */
|
|
|
|
%include "status_codes.i"
|