pysmbd: Change to keyword based arguments
authorAndrew Bartlett <abartlet@samba.org>
Sat, 15 Dec 2012 10:17:30 +0000 (21:17 +1100)
committerJeremy Allison <jra@samba.org>
Tue, 8 Jan 2013 00:23:24 +0000 (16:23 -0800)
Reviewed-by: Jeremy Allison <jra@samba.org>
source3/smbd/pysmbd.c
source4/scripting/python/samba/ntacls.py

index bf595437b7eaf47becc12c57de7bfee5900a6630..1bac9c27d347ad611766c282e94222c029b2108d 100644 (file)
@@ -331,8 +331,9 @@ static SMB_ACL_T make_simple_acl(gid_t gid, mode_t chmod_mode)
 /*
   set a simple ACL on a file, as a test
  */
-static PyObject *py_smbd_set_simple_acl(PyObject *self, PyObject *args)
+static PyObject *py_smbd_set_simple_acl(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "mode", "gid", "service", NULL };
        NTSTATUS status;
        char *fname, *service = NULL;
        int mode, gid = -1;
@@ -340,7 +341,9 @@ static PyObject *py_smbd_set_simple_acl(PyObject *self, PyObject *args)
        TALLOC_CTX *frame;
        connection_struct *conn;
 
-       if (!PyArg_ParseTuple(args, "si|iz", &fname, &mode, &gid, &service))
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "si|iz",
+                                        discard_const_p(char *, kwnames),
+                                        &fname, &mode, &gid, &service))
                return NULL;
 
        acl = make_simple_acl(gid, mode);
@@ -365,8 +368,9 @@ static PyObject *py_smbd_set_simple_acl(PyObject *self, PyObject *args)
 /*
   chown a file
  */
-static PyObject *py_smbd_chown(PyObject *self, PyObject *args)
+static PyObject *py_smbd_chown(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "uid", "gid", "service", NULL };
        connection_struct *conn;
        NTSTATUS status = NT_STATUS_OK;
        int ret;
@@ -376,7 +380,9 @@ static PyObject *py_smbd_chown(PyObject *self, PyObject *args)
        TALLOC_CTX *frame;
        mode_t saved_umask;
 
-       if (!PyArg_ParseTuple(args, "sii|z", &fname, &uid, &gid, &service))
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "sii|z",
+                                        discard_const_p(char *, kwnames),
+                                        &fname, &uid, &gid, &service))
                return NULL;
 
        frame = talloc_stackframe();
@@ -408,8 +414,9 @@ static PyObject *py_smbd_chown(PyObject *self, PyObject *args)
 /*
   chown a file
  */
-static PyObject *py_smbd_unlink(PyObject *self, PyObject *args)
+static PyObject *py_smbd_unlink(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "service", NULL };
        connection_struct *conn;
        NTSTATUS status = NT_STATUS_OK;
        int ret;
@@ -419,7 +426,9 @@ static PyObject *py_smbd_unlink(PyObject *self, PyObject *args)
 
        frame = talloc_stackframe();
 
-       if (!PyArg_ParseTuple(args, "s|z", &fname, &service)) {
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "s|z",
+                                        discard_const_p(char *, kwnames),
+                                        &fname, &service)) {
                TALLOC_FREE(frame);
                return NULL;
        }
@@ -453,7 +462,7 @@ static PyObject *py_smbd_unlink(PyObject *self, PyObject *args)
 /*
   check if we have ACL support
  */
-static PyObject *py_smbd_have_posix_acls(PyObject *self, PyObject *args)
+static PyObject *py_smbd_have_posix_acls(PyObject *self)
 {
 #ifdef HAVE_POSIX_ACLS
        return PyBool_FromLong(true);
@@ -465,8 +474,9 @@ static PyObject *py_smbd_have_posix_acls(PyObject *self, PyObject *args)
 /*
   set the NT ACL on a file
  */
-static PyObject *py_smbd_set_nt_acl(PyObject *self, PyObject *args)
+static PyObject *py_smbd_set_nt_acl(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "security_info_sent", "sd", "service", NULL };
        NTSTATUS status;
        char *fname, *service = NULL;
        int security_info_sent;
@@ -477,7 +487,9 @@ static PyObject *py_smbd_set_nt_acl(PyObject *self, PyObject *args)
 
        frame = talloc_stackframe();
 
-       if (!PyArg_ParseTuple(args, "siO|z", &fname, &security_info_sent, &py_sd, &service)) {
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs,
+                                        "siO|z", discard_const_p(char *, kwnames),
+                                        &fname, &security_info_sent, &py_sd, &service)) {
                TALLOC_FREE(frame);
                return NULL;
        }
@@ -505,8 +517,9 @@ static PyObject *py_smbd_set_nt_acl(PyObject *self, PyObject *args)
 /*
   Return the NT ACL on a file
  */
-static PyObject *py_smbd_get_nt_acl(PyObject *self, PyObject *args)
+static PyObject *py_smbd_get_nt_acl(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "security_info_wanted", "service", NULL };
        char *fname, *service = NULL;
        int security_info_wanted;
        PyObject *py_sd;
@@ -515,7 +528,8 @@ static PyObject *py_smbd_get_nt_acl(PyObject *self, PyObject *args)
        connection_struct *conn;
        NTSTATUS status;
 
-       if (!PyArg_ParseTuple(args, "si|z", &fname, &security_info_wanted, &service)) {
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "si|z", discard_const_p(char *, kwnames),
+                                        &fname, &security_info_wanted, &service)) {
                TALLOC_FREE(tmp_ctx);
                return NULL;
        }
@@ -539,8 +553,9 @@ static PyObject *py_smbd_get_nt_acl(PyObject *self, PyObject *args)
 /*
   set the posix (or similar) ACL on a file
  */
-static PyObject *py_smbd_set_sys_acl(PyObject *self, PyObject *args)
+static PyObject *py_smbd_set_sys_acl(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "acl_type", "acl", "service", NULL };
        TALLOC_CTX *frame = talloc_stackframe();
        NTSTATUS status;
        char *fname, *service = NULL;
@@ -549,7 +564,9 @@ static PyObject *py_smbd_set_sys_acl(PyObject *self, PyObject *args)
        int acl_type;
        connection_struct *conn;
 
-       if (!PyArg_ParseTuple(args, "siO|z", &fname, &acl_type, &py_acl, &service)) {
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "siO|z",
+                                        discard_const_p(char *, kwnames),
+                                        &fname, &acl_type, &py_acl, &service)) {
                TALLOC_FREE(frame);
                return NULL;
        }
@@ -577,8 +594,9 @@ static PyObject *py_smbd_set_sys_acl(PyObject *self, PyObject *args)
 /*
   Return the posix (or similar) ACL on a file
  */
-static PyObject *py_smbd_get_sys_acl(PyObject *self, PyObject *args)
+static PyObject *py_smbd_get_sys_acl(PyObject *self, PyObject *args, PyObject *kwargs)
 {
+       const char * const kwnames[] = { "fname", "acl_type", "service", NULL };
        char *fname;
        PyObject *py_acl;
        struct smb_acl_t *acl;
@@ -593,7 +611,9 @@ static PyObject *py_smbd_get_sys_acl(PyObject *self, PyObject *args)
                return NULL;
        }
 
-       if (!PyArg_ParseTuple(args, "si|z", &fname, &acl_type, &service)) {
+       if (!PyArg_ParseTupleAndKeywords(args, kwargs, "si|z",
+                                        discard_const_p(char *, kwnames),
+                                        &fname, &acl_type, &service)) {
                TALLOC_FREE(frame);
                TALLOC_FREE(tmp_ctx);
                return NULL;
@@ -625,28 +645,28 @@ static PyObject *py_smbd_get_sys_acl(PyObject *self, PyObject *args)
 
 static PyMethodDef py_smbd_methods[] = {
        { "have_posix_acls",
-               (PyCFunction)py_smbd_have_posix_acls, METH_VARARGS,
+               (PyCFunction)py_smbd_have_posix_acls, METH_NOARGS,
                NULL },
        { "set_simple_acl",
-               (PyCFunction)py_smbd_set_simple_acl, METH_VARARGS,
+               (PyCFunction)py_smbd_set_simple_acl, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "set_nt_acl",
-               (PyCFunction)py_smbd_set_nt_acl, METH_VARARGS,
+               (PyCFunction)py_smbd_set_nt_acl, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "get_nt_acl",
-               (PyCFunction)py_smbd_get_nt_acl, METH_VARARGS,
+               (PyCFunction)py_smbd_get_nt_acl, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "get_sys_acl",
-               (PyCFunction)py_smbd_get_sys_acl, METH_VARARGS,
+               (PyCFunction)py_smbd_get_sys_acl, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "set_sys_acl",
-               (PyCFunction)py_smbd_set_sys_acl, METH_VARARGS,
+               (PyCFunction)py_smbd_set_sys_acl, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "chown",
-               (PyCFunction)py_smbd_chown, METH_VARARGS,
+               (PyCFunction)py_smbd_chown, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { "unlink",
-               (PyCFunction)py_smbd_unlink, METH_VARARGS,
+               (PyCFunction)py_smbd_unlink, METH_VARARGS|METH_KEYWORDS,
                NULL },
        { NULL }
 };
index 86fe062dc691735642b51b60e6a863261cc09039..53438d84bffbc088e3aa0d177b728a2797407c05 100644 (file)
@@ -81,7 +81,7 @@ def getntacl(lp, file, backend=None, eadbfile=None, direct_db_access=True, servi
         elif ntacl.version == 4:
             return ntacl.info.sd
     else:
-        return smbd.get_nt_acl(file, security.SECINFO_OWNER | security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, service)
+        return smbd.get_nt_acl(file, security.SECINFO_OWNER | security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, service=service)
 
 
 def setntacl(lp, file, sddl, domsid, backend=None, eadbfile=None, use_ntvfs=True, skip_invalid_chown=False, passdb=None, service=None):
@@ -117,7 +117,7 @@ def setntacl(lp, file, sddl, domsid, backend=None, eadbfile=None, use_ntvfs=True
                     sd2 = sd
                     sd2.owner_sid = administrator
 
-                    smbd.set_nt_acl(file, security.SECINFO_OWNER |security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd2, service)
+                    smbd.set_nt_acl(file, security.SECINFO_OWNER |security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd2, service=service)
 
                     # and then set an NTVFS ACL (which does not set the posix ACL) to pretend the owner really was set
                     use_ntvfs = True
@@ -130,7 +130,7 @@ def setntacl(lp, file, sddl, domsid, backend=None, eadbfile=None, use_ntvfs=True
                 # This won't work in test environments, as it tries a real (rather than xattr-based fake) chown
 
                 os.chown(file, 0, 0)
-                smbd.set_nt_acl(file, security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd, service)
+                smbd.set_nt_acl(file, security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd, service=service)
 
     if use_ntvfs:
         (backend_obj, dbname) = checkset_backend(lp, backend, eadbfile)
@@ -151,7 +151,7 @@ def setntacl(lp, file, sddl, domsid, backend=None, eadbfile=None, use_ntvfs=True
             samba.xattr_native.wrap_setxattr(file, xattr.XATTR_NTACL_NAME,
                                              ndr_pack(ntacl))
     else:
-        smbd.set_nt_acl(file, security.SECINFO_OWNER | security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd, service)
+        smbd.set_nt_acl(file, security.SECINFO_OWNER | security.SECINFO_GROUP | security.SECINFO_DACL | security.SECINFO_SACL, sd, service=service)
 
 
 def ldapmask2filemask(ldm):