2010-05-31 18:12:05 +02:00
/*
Unix SMB / CIFS implementation .
Python interface to ldb - utility functions .
Copyright ( C ) 2007 - 2010 Jelmer Vernooij < jelmer @ samba . org >
* * NOTE ! The following LGPL license applies to the ldb
* * library . This does NOT imply that all of Samba is released
* * under the LGPL
This library is free software ; you can redistribute it and / or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation ; either
version 3 of the License , or ( at your option ) any later version .
This library 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
Lesser General Public License for more details .
You should have received a copy of the GNU Lesser General Public
License along with this library ; if not , see < http : //www.gnu.org/licenses/>.
*/
2023-11-09 11:35:56 +01:00
# include "lib/replace/system/python.h"
2010-12-12 21:40:03 +01:00
# include "ldb.h"
2010-05-31 18:12:05 +02:00
# include "pyldb.h"
static PyObject * ldb_module = NULL ;
2010-11-15 07:41:50 +02:00
/**
* Find out PyTypeObject in ldb module for a given typename
*/
static PyTypeObject * PyLdb_GetPyType ( const char * typename )
{
2018-05-03 11:17:55 +12:00
PyTypeObject * type = NULL ;
bool ok ;
2010-11-15 07:41:50 +02:00
if ( ldb_module = = NULL ) {
ldb_module = PyImport_ImportModule ( " ldb " ) ;
if ( ldb_module = = NULL ) {
return NULL ;
}
}
2018-05-03 11:17:55 +12:00
type = ( PyTypeObject * ) PyObject_GetAttrString ( ldb_module , typename ) ;
2010-11-15 07:41:50 +02:00
2018-05-03 11:17:55 +12:00
if ( type = = NULL ) {
PyErr_Format ( PyExc_NameError ,
" Unable to find type %s in ldb module " ,
typename ) ;
return NULL ;
}
ok = PyType_Check ( type ) ;
if ( ! ok ) {
PyErr_Format ( PyExc_TypeError ,
" Expected type ldb.%s, not %s " ,
typename , Py_TYPE ( type ) - > tp_name ) ;
Py_DECREF ( type ) ;
return NULL ;
}
return type ;
2010-11-15 07:41:50 +02:00
}
2018-05-03 12:10:21 +12:00
bool pyldb_check_type ( PyObject * obj , const char * typename )
{
bool ok = false ;
PyTypeObject * type = PyLdb_GetPyType ( typename ) ;
if ( type ! = NULL ) {
ok = PyObject_TypeCheck ( obj , type ) ;
Py_DECREF ( type ) ;
}
return ok ;
}
2010-05-31 18:12:05 +02:00
/**
* Obtain a ldb DN from a Python object .
*
* @ param mem_ctx Memory context
* @ param object Python object
* @ param ldb_ctx LDB context
* @ return Whether or not the conversion succeeded
*/
2011-08-07 17:08:56 +02:00
bool pyldb_Object_AsDn ( TALLOC_CTX * mem_ctx , PyObject * object ,
2010-05-31 18:12:05 +02:00
struct ldb_context * ldb_ctx , struct ldb_dn * * dn )
{
struct ldb_dn * odn ;
2010-11-15 07:41:50 +02:00
PyTypeObject * PyLdb_Dn_Type ;
2023-08-30 09:47:28 +12:00
bool is_dn ;
2010-05-31 18:12:05 +02:00
2019-06-15 23:14:49 +12:00
if ( ldb_ctx ! = NULL & & ( PyUnicode_Check ( object ) ) ) {
2023-08-25 14:20:50 +12:00
const char * odn_str = NULL ;
odn_str = PyUnicode_AsUTF8 ( object ) ;
if ( odn_str = = NULL ) {
return false ;
}
odn = ldb_dn_new ( mem_ctx , ldb_ctx , odn_str ) ;
if ( odn = = NULL ) {
PyErr_NoMemory ( ) ;
return false ;
}
2015-06-09 17:44:40 +02:00
* dn = odn ;
return true ;
}
if ( ldb_ctx ! = NULL & & PyBytes_Check ( object ) ) {
2023-08-25 14:20:50 +12:00
const char * odn_str = NULL ;
odn_str = PyBytes_AsString ( object ) ;
if ( odn_str = = NULL ) {
return false ;
}
odn = ldb_dn_new ( mem_ctx , ldb_ctx , odn_str ) ;
if ( odn = = NULL ) {
PyErr_NoMemory ( ) ;
return false ;
}
2010-05-31 18:12:05 +02:00
* dn = odn ;
return true ;
}
2010-11-15 07:41:50 +02:00
PyLdb_Dn_Type = PyLdb_GetPyType ( " Dn " ) ;
if ( PyLdb_Dn_Type = = NULL ) {
2010-05-31 18:12:05 +02:00
return false ;
2010-11-15 07:41:50 +02:00
}
2010-05-31 18:12:05 +02:00
2023-08-30 09:47:28 +12:00
is_dn = PyObject_TypeCheck ( object , PyLdb_Dn_Type ) ;
Py_DECREF ( PyLdb_Dn_Type ) ;
if ( is_dn ) {
2018-04-27 13:15:01 +12:00
* dn = pyldb_Dn_AS_DN ( object ) ;
2010-05-31 18:12:05 +02:00
return true ;
}
PyErr_SetString ( PyExc_TypeError , " Expected DN " ) ;
return false ;
}
2010-09-09 17:59:40 +10:00
2011-08-07 17:08:56 +02:00
PyObject * pyldb_Dn_FromDn ( struct ldb_dn * dn )
2010-09-09 17:59:40 +10:00
{
2023-08-25 14:22:15 +12:00
TALLOC_CTX * mem_ctx = NULL ;
struct ldb_dn * dn_ref = NULL ;
2010-09-09 17:59:40 +10:00
PyLdbDnObject * py_ret ;
PyTypeObject * PyLdb_Dn_Type ;
if ( dn = = NULL ) {
Py_RETURN_NONE ;
}
2023-08-25 14:22:15 +12:00
mem_ctx = talloc_new ( NULL ) ;
if ( mem_ctx = = NULL ) {
return PyErr_NoMemory ( ) ;
}
dn_ref = talloc_reference ( mem_ctx , dn ) ;
if ( dn_ref = = NULL ) {
talloc_free ( mem_ctx ) ;
return PyErr_NoMemory ( ) ;
}
2010-11-15 07:41:50 +02:00
PyLdb_Dn_Type = PyLdb_GetPyType ( " Dn " ) ;
if ( PyLdb_Dn_Type = = NULL ) {
2023-08-25 14:22:15 +12:00
talloc_free ( mem_ctx ) ;
2010-09-09 17:59:40 +10:00
return NULL ;
2010-11-15 07:41:50 +02:00
}
2010-09-09 17:59:40 +10:00
py_ret = ( PyLdbDnObject * ) PyLdb_Dn_Type - > tp_alloc ( PyLdb_Dn_Type , 0 ) ;
2023-08-30 09:47:28 +12:00
Py_DECREF ( PyLdb_Dn_Type ) ;
2010-09-09 17:59:40 +10:00
if ( py_ret = = NULL ) {
2023-08-25 14:22:15 +12:00
talloc_free ( mem_ctx ) ;
2010-09-09 17:59:40 +10:00
PyErr_NoMemory ( ) ;
return NULL ;
}
2023-08-25 14:22:15 +12:00
py_ret - > mem_ctx = mem_ctx ;
py_ret - > dn = dn ;
2010-09-09 17:59:40 +10:00
return ( PyObject * ) py_ret ;
}