2008-12-21 09:34:27 +03:00
/*
Unix SMB / CIFS implementation .
Samba utility functions
Copyright ( C ) Jelmer Vernooij < jelmer @ samba . org > 2007 - 2008
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/>.
*/
2009-10-23 09:23:01 +04:00
# include <Python.h>
2008-12-21 09:34:27 +03:00
# include "includes.h"
# include "param/param.h"
# include "param/loadparm.h"
2010-03-29 01:35:30 +04:00
# include "lib/talloc/pytalloc.h"
2011-02-05 02:34:51 +03:00
# include "dynconfig/dynconfig.h"
2008-12-21 09:34:27 +03:00
2011-03-19 02:44:36 +03:00
void initparam ( void ) ;
2008-12-23 13:25:06 +03:00
/* There's no Py_ssize_t in 2.4, apparently */
# if PY_MAJOR_VERSION == 2 && PY_MINOR_VERSION < 5
typedef int Py_ssize_t ;
typedef inquiry lenfunc ;
# endif
2009-02-05 12:04:01 +03:00
# define PyLoadparmContext_AsLoadparmContext(obj) py_talloc_get_type(obj, struct loadparm_context)
2010-06-20 15:40:49 +04:00
# define PyLoadparmService_AsLoadparmService(obj) py_talloc_get_type(obj, struct loadparm_service)
2008-12-21 09:34:27 +03:00
2010-11-22 02:07:21 +03:00
extern PyTypeObject PyLoadparmContext ;
extern PyTypeObject PyLoadparmService ;
2008-12-21 09:34:27 +03:00
2011-03-19 02:44:36 +03:00
static PyObject * PyLoadparmService_FromService ( struct loadparm_service * service )
2008-12-21 09:34:27 +03:00
{
2009-07-01 08:06:38 +04:00
return py_talloc_reference ( & PyLoadparmService , service ) ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_get_helper ( struct loadparm_context * lp_ctx , const char * service_name , const char * param_name )
{
2010-06-20 16:14:01 +04:00
struct parm_struct * parm = NULL ;
void * parm_ptr = NULL ;
int i ;
2008-12-21 09:34:27 +03:00
2010-06-20 17:04:42 +04:00
if ( service_name ! = NULL & & strwicmp ( service_name , GLOBAL_NAME ) & &
strwicmp ( service_name , GLOBAL_NAME2 ) ) {
2010-06-20 16:14:01 +04:00
struct loadparm_service * service ;
/* its a share parameter */
2010-07-16 08:32:42 +04:00
service = lpcfg_service ( lp_ctx , service_name ) ;
2010-06-20 16:14:01 +04:00
if ( service = = NULL ) {
return NULL ;
}
if ( strchr ( param_name , ' : ' ) ) {
/* its a parametric option on a share */
2010-07-16 08:32:42 +04:00
const char * type = talloc_strndup ( lp_ctx , param_name ,
2010-06-20 16:14:01 +04:00
strcspn ( param_name , " : " ) ) ;
const char * option = strchr ( param_name , ' : ' ) + 1 ;
const char * value ;
if ( type = = NULL | | option = = NULL ) {
return NULL ;
}
2010-07-16 08:32:42 +04:00
value = lpcfg_get_parametric ( lp_ctx , service , type , option ) ;
2010-06-20 16:14:01 +04:00
if ( value = = NULL ) {
return NULL ;
}
return PyString_FromString ( value ) ;
}
2008-12-21 09:34:27 +03:00
2010-07-16 08:32:42 +04:00
parm = lpcfg_parm_struct ( param_name ) ;
2011-06-29 08:15:32 +04:00
if ( parm = = NULL | | parm - > p_class = = P_GLOBAL ) {
2010-06-20 16:14:01 +04:00
return NULL ;
}
2010-07-16 08:32:42 +04:00
parm_ptr = lpcfg_parm_ptr ( lp_ctx , service , parm ) ;
2008-12-21 09:34:27 +03:00
} else if ( strchr ( param_name , ' : ' ) ) {
2010-06-20 16:14:01 +04:00
/* its a global parametric option */
2010-07-16 08:32:42 +04:00
const char * type = talloc_strndup ( lp_ctx ,
2010-06-20 16:14:01 +04:00
param_name , strcspn ( param_name , " : " ) ) ;
const char * option = strchr ( param_name , ' : ' ) + 1 ;
const char * value ;
if ( type = = NULL | | option = = NULL ) {
return NULL ;
}
2010-07-16 08:32:42 +04:00
value = lpcfg_get_parametric ( lp_ctx , NULL , type , option ) ;
2010-06-20 16:14:01 +04:00
if ( value = = NULL )
return NULL ;
return PyString_FromString ( value ) ;
} else {
/* its a global parameter */
2010-07-16 08:32:42 +04:00
parm = lpcfg_parm_struct ( param_name ) ;
2010-06-20 16:14:01 +04:00
if ( parm = = NULL ) {
return NULL ;
}
2010-07-16 08:32:42 +04:00
parm_ptr = lpcfg_parm_ptr ( lp_ctx , NULL , parm ) ;
2008-12-21 09:34:27 +03:00
}
2010-06-20 16:14:01 +04:00
if ( parm = = NULL | | parm_ptr = = NULL ) {
return NULL ;
2008-12-21 09:34:27 +03:00
}
/* construct and return the right type of python object */
switch ( parm - > type ) {
case P_STRING :
case P_USTRING :
return PyString_FromString ( * ( char * * ) parm_ptr ) ;
case P_BOOL :
return PyBool_FromLong ( * ( bool * ) parm_ptr ) ;
case P_INTEGER :
case P_OCTAL :
case P_BYTES :
return PyLong_FromLong ( * ( int * ) parm_ptr ) ;
case P_ENUM :
for ( i = 0 ; parm - > enum_list [ i ] . name ; i + + ) {
if ( * ( int * ) parm_ptr = = parm - > enum_list [ i ] . value ) {
return PyString_FromString ( parm - > enum_list [ i ] . name ) ;
}
}
return NULL ;
2010-12-08 08:27:38 +03:00
case P_CMDLIST :
2008-12-21 09:34:27 +03:00
case P_LIST :
{
int j ;
const char * * strlist = * ( const char * * * ) parm_ptr ;
2009-08-04 02:03:04 +04:00
PyObject * pylist ;
if ( strlist = = NULL ) {
return PyList_New ( 0 ) ;
}
pylist = PyList_New ( str_list_length ( strlist ) ) ;
2008-12-21 09:34:27 +03:00
for ( j = 0 ; strlist [ j ] ; j + + )
PyList_SetItem ( pylist , j ,
PyString_FromString ( strlist [ j ] ) ) ;
return pylist ;
}
break ;
}
return NULL ;
}
static PyObject * py_lp_ctx_load ( py_talloc_Object * self , PyObject * args )
{
char * filename ;
bool ret ;
if ( ! PyArg_ParseTuple ( args , " s " , & filename ) )
return NULL ;
2010-07-16 08:32:42 +04:00
ret = lpcfg_load ( PyLoadparmContext_AsLoadparmContext ( self ) , filename ) ;
2008-12-21 09:34:27 +03:00
if ( ! ret ) {
2008-12-22 01:05:35 +03:00
PyErr_Format ( PyExc_RuntimeError , " Unable to load file %s " , filename ) ;
2008-12-21 09:34:27 +03:00
return NULL ;
}
2009-01-06 06:13:57 +03:00
Py_RETURN_NONE ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_load_default ( py_talloc_Object * self )
{
bool ret ;
2010-07-16 08:32:42 +04:00
ret = lpcfg_load_default ( PyLoadparmContext_AsLoadparmContext ( self ) ) ;
2008-12-21 09:34:27 +03:00
if ( ! ret ) {
2008-12-22 01:05:35 +03:00
PyErr_SetString ( PyExc_RuntimeError , " Unable to load default file " ) ;
2008-12-21 09:34:27 +03:00
return NULL ;
}
2009-01-06 06:13:57 +03:00
Py_RETURN_NONE ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_get ( py_talloc_Object * self , PyObject * args )
{
char * param_name ;
char * section_name = NULL ;
PyObject * ret ;
2010-06-20 15:51:14 +04:00
if ( ! PyArg_ParseTuple ( args , " s|z " , & param_name , & section_name ) )
2008-12-21 09:34:27 +03:00
return NULL ;
2009-02-05 12:04:01 +03:00
ret = py_lp_ctx_get_helper ( PyLoadparmContext_AsLoadparmContext ( self ) , section_name , param_name ) ;
2008-12-21 09:34:27 +03:00
if ( ret = = NULL )
2009-01-06 06:13:57 +03:00
Py_RETURN_NONE ;
2008-12-21 09:34:27 +03:00
return ret ;
}
static PyObject * py_lp_ctx_is_myname ( py_talloc_Object * self , PyObject * args )
{
char * name ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
2010-07-16 08:32:42 +04:00
return PyBool_FromLong ( lpcfg_is_myname ( PyLoadparmContext_AsLoadparmContext ( self ) , name ) ) ;
2008-12-21 09:34:27 +03:00
}
2008-12-21 18:32:47 +03:00
static PyObject * py_lp_ctx_is_mydomain ( py_talloc_Object * self , PyObject * args )
{
char * name ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
2010-07-16 08:32:42 +04:00
return PyBool_FromLong ( lpcfg_is_mydomain ( PyLoadparmContext_AsLoadparmContext ( self ) , name ) ) ;
2008-12-21 18:32:47 +03:00
}
2008-12-21 09:34:27 +03:00
static PyObject * py_lp_ctx_set ( py_talloc_Object * self , PyObject * args )
{
char * name , * value ;
bool ret ;
if ( ! PyArg_ParseTuple ( args , " ss " , & name , & value ) )
return NULL ;
2010-07-16 08:32:42 +04:00
ret = lpcfg_set_cmdline ( PyLoadparmContext_AsLoadparmContext ( self ) , name , value ) ;
2008-12-21 09:34:27 +03:00
if ( ! ret ) {
PyErr_SetString ( PyExc_RuntimeError , " Unable to set parameter " ) ;
return NULL ;
}
2009-01-06 06:13:57 +03:00
Py_RETURN_NONE ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_private_path ( py_talloc_Object * self , PyObject * args )
{
char * name , * path ;
PyObject * ret ;
if ( ! PyArg_ParseTuple ( args , " s " , & name ) )
return NULL ;
2011-04-29 06:47:11 +04:00
path = lpcfg_private_path ( NULL , PyLoadparmContext_AsLoadparmContext ( self ) , name ) ;
2008-12-21 09:34:27 +03:00
ret = PyString_FromString ( path ) ;
talloc_free ( path ) ;
return ret ;
}
2009-06-16 04:24:43 +04:00
static PyObject * py_lp_ctx_services ( py_talloc_Object * self )
{
struct loadparm_context * lp_ctx = PyLoadparmContext_AsLoadparmContext ( self ) ;
PyObject * ret ;
int i ;
2010-07-16 08:32:42 +04:00
ret = PyList_New ( lpcfg_numservices ( lp_ctx ) ) ;
for ( i = 0 ; i < lpcfg_numservices ( lp_ctx ) ; i + + ) {
struct loadparm_service * service = lpcfg_servicebynum ( lp_ctx , i ) ;
2009-08-04 02:00:25 +04:00
if ( service ! = NULL ) {
2010-07-16 08:32:42 +04:00
PyList_SetItem ( ret , i , PyString_FromString ( lpcfg_servicename ( service ) ) ) ;
2009-08-04 02:00:25 +04:00
}
2009-06-16 04:24:43 +04:00
}
return ret ;
}
2010-06-20 15:29:35 +04:00
static PyObject * py_lp_dump ( PyObject * self , PyObject * args )
{
PyObject * py_stream ;
bool show_defaults = false ;
FILE * f ;
struct loadparm_context * lp_ctx = PyLoadparmContext_AsLoadparmContext ( self ) ;
if ( ! PyArg_ParseTuple ( args , " O|b " , & py_stream , & show_defaults ) )
return NULL ;
f = PyFile_AsFile ( py_stream ) ;
if ( f = = NULL ) {
PyErr_SetString ( PyExc_TypeError , " Not a file stream " ) ;
return NULL ;
}
2010-07-16 08:32:42 +04:00
lpcfg_dump ( lp_ctx , f , show_defaults , lpcfg_numservices ( lp_ctx ) ) ;
2010-06-20 15:29:35 +04:00
Py_RETURN_NONE ;
}
2011-06-02 09:43:40 +04:00
static PyObject * py_samdb_url ( PyObject * self )
{
struct loadparm_context * lp_ctx = PyLoadparmContext_AsLoadparmContext ( self ) ;
return PyString_FromFormat ( " tdb://%s/sam.ldb " , lpcfg_private_dir ( lp_ctx ) ) ;
}
2010-06-20 15:40:49 +04:00
2008-12-21 09:34:27 +03:00
static PyMethodDef py_lp_ctx_methods [ ] = {
{ " load " , ( PyCFunction ) py_lp_ctx_load , METH_VARARGS ,
" S.load(filename) -> None \n "
" Load specified file. " } ,
{ " load_default " , ( PyCFunction ) py_lp_ctx_load_default , METH_NOARGS ,
" S.load_default() -> None \n "
" Load default smb.conf file. " } ,
{ " is_myname " , ( PyCFunction ) py_lp_ctx_is_myname , METH_VARARGS ,
" S.is_myname(name) -> bool \n "
" Check whether the specified name matches one of our netbios names. " } ,
2008-12-21 18:32:47 +03:00
{ " is_mydomain " , ( PyCFunction ) py_lp_ctx_is_mydomain , METH_VARARGS ,
" S.is_mydomain(name) -> bool \n "
" Check whether the specified name matches our domain name. " } ,
2008-12-21 09:34:27 +03:00
{ " get " , ( PyCFunction ) py_lp_ctx_get , METH_VARARGS ,
" S.get(name, service_name) -> value \n "
" Find specified parameter. " } ,
{ " set " , ( PyCFunction ) py_lp_ctx_set , METH_VARARGS ,
" S.set(name, value) -> bool \n "
" Change a parameter. " } ,
{ " private_path " , ( PyCFunction ) py_lp_ctx_private_path , METH_VARARGS ,
" S.private_path(name) -> path \n " } ,
2009-06-16 04:24:43 +04:00
{ " services " , ( PyCFunction ) py_lp_ctx_services , METH_NOARGS ,
" S.services() -> list " } ,
2010-06-20 15:29:35 +04:00
{ " dump " , ( PyCFunction ) py_lp_dump , METH_VARARGS ,
" S.dump(stream, show_defaults=False) " } ,
2011-06-02 09:43:40 +04:00
{ " samdb_url " , ( PyCFunction ) py_samdb_url , METH_NOARGS ,
" S.samdb_url() -> string \n "
" Returns the current URL for sam.ldb. " } ,
2008-12-21 09:34:27 +03:00
{ NULL }
} ;
static PyObject * py_lp_ctx_default_service ( py_talloc_Object * self , void * closure )
{
2010-07-16 08:32:42 +04:00
return PyLoadparmService_FromService ( lpcfg_default_service ( PyLoadparmContext_AsLoadparmContext ( self ) ) ) ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_config_file ( py_talloc_Object * self , void * closure )
{
2010-07-16 08:32:42 +04:00
const char * configfile = lpcfg_configfile ( PyLoadparmContext_AsLoadparmContext ( self ) ) ;
2009-01-15 23:16:31 +03:00
if ( configfile = = NULL )
Py_RETURN_NONE ;
else
return PyString_FromString ( configfile ) ;
2008-12-21 09:34:27 +03:00
}
static PyGetSetDef py_lp_ctx_getset [ ] = {
2009-02-05 12:04:01 +03:00
{ discard_const_p ( char , " default_service " ) , ( getter ) py_lp_ctx_default_service , NULL , NULL } ,
{ discard_const_p ( char , " configfile " ) , ( getter ) py_lp_ctx_config_file , NULL ,
discard_const_p ( char , " Name of last config file that was loaded. " ) } ,
2008-12-21 09:34:27 +03:00
{ NULL }
} ;
static PyObject * py_lp_ctx_new ( PyTypeObject * type , PyObject * args , PyObject * kwargs )
{
2009-06-17 21:07:44 +04:00
py_talloc_Object * ret = ( py_talloc_Object * ) type - > tp_alloc ( type , 0 ) ;
if ( ret = = NULL ) {
PyErr_NoMemory ( ) ;
return NULL ;
}
ret - > talloc_ctx = talloc_new ( NULL ) ;
if ( ret - > talloc_ctx = = NULL ) {
PyErr_NoMemory ( ) ;
return NULL ;
}
2010-11-29 05:25:59 +03:00
ret - > ptr = loadparm_init_global ( false ) ;
2011-03-21 12:32:24 +03:00
if ( ret - > ptr = = NULL ) {
PyErr_NoMemory ( ) ;
return NULL ;
}
2009-06-17 21:07:44 +04:00
return ( PyObject * ) ret ;
2008-12-21 09:34:27 +03:00
}
static Py_ssize_t py_lp_ctx_len ( py_talloc_Object * self )
{
2010-07-16 08:32:42 +04:00
return lpcfg_numservices ( PyLoadparmContext_AsLoadparmContext ( self ) ) ;
2008-12-21 09:34:27 +03:00
}
static PyObject * py_lp_ctx_getitem ( py_talloc_Object * self , PyObject * name )
{
struct loadparm_service * service ;
if ( ! PyString_Check ( name ) ) {
PyErr_SetString ( PyExc_TypeError , " Only string subscripts are supported " ) ;
return NULL ;
}
2010-07-16 08:32:42 +04:00
service = lpcfg_service ( PyLoadparmContext_AsLoadparmContext ( self ) , PyString_AsString ( name ) ) ;
2008-12-21 09:34:27 +03:00
if ( service = = NULL ) {
PyErr_SetString ( PyExc_KeyError , " No such section " ) ;
return NULL ;
}
return PyLoadparmService_FromService ( service ) ;
}
static PyMappingMethods py_lp_ctx_mapping = {
. mp_length = ( lenfunc ) py_lp_ctx_len ,
. mp_subscript = ( binaryfunc ) py_lp_ctx_getitem ,
} ;
PyTypeObject PyLoadparmContext = {
2008-12-21 18:32:47 +03:00
. tp_name = " LoadParm " ,
2008-12-21 09:34:27 +03:00
. tp_basicsize = sizeof ( py_talloc_Object ) ,
. tp_getset = py_lp_ctx_getset ,
. tp_methods = py_lp_ctx_methods ,
. tp_new = py_lp_ctx_new ,
. tp_as_mapping = & py_lp_ctx_mapping ,
. tp_flags = Py_TPFLAGS_DEFAULT ,
} ;
2010-06-20 15:40:49 +04:00
static PyObject * py_lp_service_dump ( PyObject * self , PyObject * args )
{
PyObject * py_stream ;
bool show_defaults = false ;
FILE * f ;
struct loadparm_service * service = PyLoadparmService_AsLoadparmService ( self ) ;
struct loadparm_service * default_service ;
PyObject * py_default_service ;
if ( ! PyArg_ParseTuple ( args , " OO|b " , & py_stream , & py_default_service ,
& show_defaults ) )
return NULL ;
f = PyFile_AsFile ( py_stream ) ;
if ( f = = NULL ) {
PyErr_SetString ( PyExc_TypeError , " Not a file stream " ) ;
return NULL ;
}
if ( ! PyObject_TypeCheck ( py_default_service , & PyLoadparmService ) ) {
PyErr_SetNone ( PyExc_TypeError ) ;
return NULL ;
}
default_service = PyLoadparmService_AsLoadparmService ( py_default_service ) ;
2010-07-16 08:32:42 +04:00
lpcfg_dump_one ( f , show_defaults , service , default_service ) ;
2010-06-20 15:40:49 +04:00
Py_RETURN_NONE ;
}
static PyMethodDef py_lp_service_methods [ ] = {
{ " dump " , ( PyCFunction ) py_lp_service_dump , METH_VARARGS ,
" S.dump(f, default_service, show_defaults=False) " } ,
{ NULL }
} ;
2008-12-21 09:34:27 +03:00
PyTypeObject PyLoadparmService = {
. tp_name = " LoadparmService " ,
. tp_basicsize = sizeof ( py_talloc_Object ) ,
2010-06-20 15:40:49 +04:00
. tp_methods = py_lp_service_methods ,
2008-12-21 09:34:27 +03:00
. tp_flags = Py_TPFLAGS_DEFAULT ,
} ;
2009-01-16 17:05:15 +03:00
static PyObject * py_default_path ( PyObject * self )
{
return PyString_FromString ( lp_default_path ( ) ) ;
}
2011-02-05 02:34:51 +03:00
static PyObject * py_setup_dir ( PyObject * self )
{
return PyString_FromString ( dyn_SETUPDIR ) ;
}
2011-06-06 08:39:19 +04:00
static PyObject * py_modules_dir ( PyObject * self )
{
return PyString_FromString ( dyn_MODULESDIR ) ;
}
2009-01-16 17:05:15 +03:00
static PyMethodDef pyparam_methods [ ] = {
{ " default_path " , ( PyCFunction ) py_default_path , METH_NOARGS ,
" Returns the default smb.conf path. " } ,
2011-02-05 02:34:51 +03:00
{ " setup_dir " , ( PyCFunction ) py_setup_dir , METH_NOARGS ,
" Returns the compiled in location of provision tempates. " } ,
2011-06-06 08:39:19 +04:00
{ " modules_dir " , ( PyCFunction ) py_modules_dir , METH_NOARGS ,
" Returns the compiled in location of modules. " } ,
2009-01-16 17:05:15 +03:00
{ NULL }
} ;
2008-12-21 09:34:27 +03:00
void initparam ( void )
{
PyObject * m ;
2010-12-01 02:05:05 +03:00
PyTypeObject * talloc_type = PyTalloc_GetObjectType ( ) ;
if ( talloc_type = = NULL )
return ;
PyLoadparmContext . tp_base = talloc_type ;
PyLoadparmService . tp_base = talloc_type ;
2008-12-21 09:34:27 +03:00
if ( PyType_Ready ( & PyLoadparmContext ) < 0 )
return ;
2009-12-20 19:49:48 +03:00
if ( PyType_Ready ( & PyLoadparmService ) < 0 )
return ;
2009-01-16 17:05:15 +03:00
m = Py_InitModule3 ( " param " , pyparam_methods , " Parsing and writing Samba configuration files. " ) ;
2008-12-21 09:34:27 +03:00
if ( m = = NULL )
return ;
Py_INCREF ( & PyLoadparmContext ) ;
2008-12-21 18:32:47 +03:00
PyModule_AddObject ( m , " LoadParm " , ( PyObject * ) & PyLoadparmContext ) ;
2008-12-21 09:34:27 +03:00
}