2 Unix SMB/CIFS implementation.
3 Copyright (C) Jelmer Vernooij <jelmer@samba.org> 2007-2010
4 Copyright (C) Matthias Dieter Wallnöfer 2009
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "dsdb/samdb/samdb.h"
23 #include "lib/ldb/pyldb.h"
25 /* FIXME: These should be in a header file somewhere, once we finish moving
26 * away from SWIG .. */
27 #define PyErr_LDB_OR_RAISE(py_ldb, ldb) \
28 /* if (!PyLdb_Check(py_ldb)) { \
29 PyErr_SetString(py_ldb_get_exception(), "Ldb connection object required"); \
32 ldb = PyLdb_AsLdbContext(py_ldb);
34 static PyObject *py_samdb_server_site_name(PyObject *self, PyObject *args)
36 PyObject *py_ldb, *result;
37 struct ldb_context *ldb;
41 if (!PyArg_ParseTuple(args, "O", &py_ldb))
44 PyErr_LDB_OR_RAISE(py_ldb, ldb);
46 mem_ctx = talloc_new(NULL);
48 site = samdb_server_site_name(ldb, mem_ctx);
50 PyErr_SetString(PyExc_RuntimeError, "Failed to find server site");
55 result = PyString_FromString(site);
60 /* XXX: This function really should be in pyldb.c */
61 static PyObject *py_dsdb_set_opaque_integer(PyObject *self, PyObject *args)
65 int *old_val, *new_val;
66 char *py_opaque_name, *opaque_name_talloc;
67 struct ldb_context *ldb;
70 if (!PyArg_ParseTuple(args, "Osi", &py_ldb, &py_opaque_name, &value))
73 PyErr_LDB_OR_RAISE(py_ldb, ldb);
75 /* see if we have a cached copy */
76 old_val = (int *)ldb_get_opaque(ldb, py_opaque_name);
77 /* XXX: We shouldn't just blindly assume that the value that is
78 * already present has the size of an int and is not shared
79 * with other code that may rely on it not changing.
87 tmp_ctx = talloc_new(ldb);
88 if (tmp_ctx == NULL) {
93 new_val = talloc(tmp_ctx, int);
94 if (new_val == NULL) {
100 opaque_name_talloc = talloc_strdup(tmp_ctx, py_opaque_name);
101 if (opaque_name_talloc == NULL) {
102 talloc_free(tmp_ctx);
109 /* cache the domain_sid in the ldb */
110 if (ldb_set_opaque(ldb, opaque_name_talloc, new_val) != LDB_SUCCESS) {
111 talloc_free(tmp_ctx);
112 PyErr_SetString(PyExc_RuntimeError,
113 "Failed to set opaque integer into the ldb");
117 talloc_steal(ldb, new_val);
118 talloc_steal(ldb, opaque_name_talloc);
119 talloc_free(tmp_ctx);
124 static PyObject *py_dsdb_convert_schema_to_openldap(PyObject *self,
127 char *target_str, *mapping;
129 struct ldb_context *ldb;
133 if (!PyArg_ParseTuple(args, "Oss", &py_ldb, &target_str, &mapping))
136 PyErr_LDB_OR_RAISE(py_ldb, ldb);
138 retstr = dsdb_convert_schema_to_openldap(ldb, target_str, mapping);
139 if (retstr == NULL) {
140 PyErr_SetString(PyExc_RuntimeError,
141 "dsdb_convert_schema_to_openldap failed");
145 ret = PyString_FromString(retstr);
150 static PyMethodDef py_dsdb_methods[] = {
151 { "samdb_server_site_name", (PyCFunction)py_samdb_server_site_name,
152 METH_VARARGS, "Get the server site name as a string"},
153 { "dsdb_set_opaque_integer", (PyCFunction)py_dsdb_set_opaque_integer,
154 METH_VARARGS, NULL },
155 { "dsdb_convert_schema_to_openldap",
156 (PyCFunction)py_dsdb_convert_schema_to_openldap, METH_VARARGS,
157 "dsdb_convert_schema_to_openldap(ldb, target_str, mapping) -> str\n"
158 "Create an OpenLDAP schema from a schema." },
166 m = Py_InitModule3("dsdb", py_dsdb_methods,
167 "Python bindings for the directory service databases.");
171 /* "userAccountControl" flags */
172 PyModule_AddObject(m, "UF_NORMAL_ACCOUNT", PyInt_FromLong(UF_NORMAL_ACCOUNT));
173 PyModule_AddObject(m, "UF_TEMP_DUPLICATE_ACCOUNT", PyInt_FromLong(UF_TEMP_DUPLICATE_ACCOUNT));
174 PyModule_AddObject(m, "UF_SERVER_TRUST_ACCOUNT", PyInt_FromLong(UF_SERVER_TRUST_ACCOUNT));
175 PyModule_AddObject(m, "UF_WORKSTATION_TRUST_ACCOUNT", PyInt_FromLong(UF_WORKSTATION_TRUST_ACCOUNT));
176 PyModule_AddObject(m, "UF_INTERDOMAIN_TRUST_ACCOUNT", PyInt_FromLong(UF_INTERDOMAIN_TRUST_ACCOUNT));
177 PyModule_AddObject(m, "UF_PASSWD_NOTREQD", PyInt_FromLong(UF_PASSWD_NOTREQD));
178 PyModule_AddObject(m, "UF_ACCOUNTDISABLE", PyInt_FromLong(UF_ACCOUNTDISABLE));
180 /* "groupType" flags */
181 PyModule_AddObject(m, "GTYPE_SECURITY_BUILTIN_LOCAL_GROUP", PyInt_FromLong(GTYPE_SECURITY_BUILTIN_LOCAL_GROUP));
182 PyModule_AddObject(m, "GTYPE_SECURITY_GLOBAL_GROUP", PyInt_FromLong(GTYPE_SECURITY_GLOBAL_GROUP));
183 PyModule_AddObject(m, "GTYPE_SECURITY_DOMAIN_LOCAL_GROUP", PyInt_FromLong(GTYPE_SECURITY_DOMAIN_LOCAL_GROUP));
184 PyModule_AddObject(m, "GTYPE_SECURITY_UNIVERSAL_GROUP", PyInt_FromLong(GTYPE_SECURITY_UNIVERSAL_GROUP));
185 PyModule_AddObject(m, "GTYPE_DISTRIBUTION_GLOBAL_GROUP", PyInt_FromLong(GTYPE_DISTRIBUTION_GLOBAL_GROUP));
186 PyModule_AddObject(m, "GTYPE_DISTRIBUTION_DOMAIN_LOCAL_GROUP", PyInt_FromLong(GTYPE_DISTRIBUTION_DOMAIN_LOCAL_GROUP));
187 PyModule_AddObject(m, "GTYPE_DISTRIBUTION_UNIVERSAL_GROUP", PyInt_FromLong(GTYPE_DISTRIBUTION_UNIVERSAL_GROUP));
189 /* "sAMAccountType" flags */
190 PyModule_AddObject(m, "ATYPE_NORMAL_ACCOUNT", PyInt_FromLong(ATYPE_NORMAL_ACCOUNT));
191 PyModule_AddObject(m, "ATYPE_WORKSTATION_TRUST", PyInt_FromLong(ATYPE_WORKSTATION_TRUST));
192 PyModule_AddObject(m, "ATYPE_INTERDOMAIN_TRUST", PyInt_FromLong(ATYPE_INTERDOMAIN_TRUST));
193 PyModule_AddObject(m, "ATYPE_SECURITY_GLOBAL_GROUP", PyInt_FromLong(ATYPE_SECURITY_GLOBAL_GROUP));
194 PyModule_AddObject(m, "ATYPE_SECURITY_LOCAL_GROUP", PyInt_FromLong(ATYPE_SECURITY_LOCAL_GROUP));
195 PyModule_AddObject(m, "ATYPE_SECURITY_UNIVERSAL_GROUP", PyInt_FromLong(ATYPE_SECURITY_UNIVERSAL_GROUP));
196 PyModule_AddObject(m, "ATYPE_DISTRIBUTION_GLOBAL_GROUP", PyInt_FromLong(ATYPE_DISTRIBUTION_GLOBAL_GROUP));
197 PyModule_AddObject(m, "ATYPE_DISTRIBUTION_LOCAL_GROUP", PyInt_FromLong(ATYPE_DISTRIBUTION_LOCAL_GROUP));
198 PyModule_AddObject(m, "ATYPE_DISTRIBUTION_UNIVERSAL_GROUP", PyInt_FromLong(ATYPE_DISTRIBUTION_UNIVERSAL_GROUP));
200 /* "domainFunctionality", "forestFunctionality" flags in the rootDSE */
201 PyModule_AddObject(m, "DS_DOMAIN_FUNCTION_2000", PyInt_FromLong(DS_DOMAIN_FUNCTION_2000));
202 PyModule_AddObject(m, "DS_DOMAIN_FUNCTION_2003_MIXED", PyInt_FromLong(DS_DOMAIN_FUNCTION_2003_MIXED));
203 PyModule_AddObject(m, "DS_DOMAIN_FUNCTION_2003", PyInt_FromLong(DS_DOMAIN_FUNCTION_2003));
204 PyModule_AddObject(m, "DS_DOMAIN_FUNCTION_2008", PyInt_FromLong(DS_DOMAIN_FUNCTION_2008));
205 PyModule_AddObject(m, "DS_DOMAIN_FUNCTION_2008_R2", PyInt_FromLong(DS_DOMAIN_FUNCTION_2008_R2));
207 /* "domainControllerFunctionality" flags in the rootDSE */
208 PyModule_AddObject(m, "DS_DC_FUNCTION_2000", PyInt_FromLong(DS_DC_FUNCTION_2000));
209 PyModule_AddObject(m, "DS_DC_FUNCTION_2003", PyInt_FromLong(DS_DC_FUNCTION_2003));
210 PyModule_AddObject(m, "DS_DC_FUNCTION_2008", PyInt_FromLong(DS_DC_FUNCTION_2008));
211 PyModule_AddObject(m, "DS_DC_FUNCTION_2008_R2", PyInt_FromLong(DS_DC_FUNCTION_2008_R2));