summaryrefslogtreecommitdiff
path: root/source3/printing
diff options
context:
space:
mode:
Diffstat (limited to 'source3/printing')
-rw-r--r--source3/printing/nt_printing.c77
1 files changed, 61 insertions, 16 deletions
diff --git a/source3/printing/nt_printing.c b/source3/printing/nt_printing.c
index 9572ec334e..57c65e5eca 100644
--- a/source3/printing/nt_printing.c
+++ b/source3/printing/nt_printing.c
@@ -768,7 +768,6 @@ static void free_nt_printer_info_level_2(NT_PRINTER_INFO_LEVEL_2 **info_ptr)
free_nt_printer_param(&tofree);
}
- free(info);
*info_ptr = NULL;
}
@@ -782,7 +781,7 @@ static int unpack_devicemode(NT_DEVICEMODE **nt_devmode, char *buf, int buflen)
ZERO_STRUCT(devmode);
- len += tdb_unpack(buf+len, buflen-len, "p", *nt_devmode);
+ len += tdb_unpack(buf+len, buflen-len, "p", nt_devmode);
if (!*nt_devmode) return len;
@@ -860,7 +859,6 @@ static uint32 get_a_printer_2_default(NT_PRINTER_INFO_LEVEL_2 **info_ptr, fstrin
int snum;
NT_PRINTER_INFO_LEVEL_2 info;
NT_DEVICEMODE devmode;
- SMB_STRUCT_STAT sbuf;
ZERO_STRUCT(info);
ZERO_STRUCT(devmode);
@@ -878,16 +876,7 @@ static uint32 get_a_printer_2_default(NT_PRINTER_INFO_LEVEL_2 **info_ptr, fstrin
info.devmode = (NT_DEVICEMODE *)memdup(&devmode, sizeof(devmode));
- /*
- * put a better system here, please.
- */
- sbuf.st_mode = 0777;
- sbuf.st_uid = -1;
- sbuf.st_gid = -1;
- info.secdesc.len = convertperms_unix_to_sd(&sbuf, False,
- 0777,
- &info.secdesc.sec);
- info.secdesc.max_len = info.secdesc.len;
+ nt_printing_getsec(sharename, &info.secdesc);
*info_ptr = (NT_PRINTER_INFO_LEVEL_2 *)memdup(&info, sizeof(info));
if (! *info_ptr) return 2;
@@ -939,11 +928,10 @@ static uint32 get_a_printer_2(NT_PRINTER_INFO_LEVEL_2 **info_ptr, fstring sharen
info.parameters);
len += unpack_devicemode(&info.devmode,dbuf.dptr+len, dbuf.dsize-len);
-#if 0
- len += unpack_secdesc(&info.devmode,dbuf.dptr+len, dbuf.dsize-len);
-#endif
len += unpack_specifics(&info.specific,dbuf.dptr+len, dbuf.dsize-len);
+ nt_printing_getsec(sharename, &info.secdesc);
+
*info_ptr=memdup(&info, sizeof(info));
return 0;
@@ -1299,6 +1287,63 @@ void init_devicemode(NT_DEVICEMODE *nt_devmode)
}
+
+/****************************************************************************
+store a security desc for a printer
+****************************************************************************/
+uint32 nt_printing_setsec(char *printername, SEC_DESC_BUF *secdesc_ctr)
+{
+ prs_struct ps;
+ fstring key;
+ uint32 status;
+
+ prs_init(&ps, 0, 4, MARSHALL);
+ ps.is_dynamic = True;
+
+ if (!sec_io_desc_buf("nt_printing_setsec", secdesc_ctr, &ps, 1)) {
+ status = ERROR_INVALID_FUNCTION;
+ goto out;
+ }
+
+
+ slprintf(key, sizeof(key), "SECDESC/%s", printername);
+
+ if (tdb_prs_store(tdb, key, &ps)==0) {
+ status = 0;
+ } else {
+ DEBUG(1,("Failed to store secdesc for %s\n", printername));
+ status = ERROR_INVALID_FUNCTION;
+ }
+
+ out:
+ prs_mem_free(&ps);
+ return status;
+}
+
+/****************************************************************************
+get a security desc for a printer
+****************************************************************************/
+uint32 nt_printing_getsec(char *printername, SEC_DESC_BUF *secdesc_ctr)
+{
+ prs_struct ps;
+ fstring key;
+
+ slprintf(key, sizeof(key), "SECDESC/%s", printername);
+
+ if (tdb_prs_fetch(tdb, key, &ps)!=0 ||
+ !sec_io_desc_buf("nt_printing_getsec", secdesc_ctr, &ps, 1)) {
+ DEBUG(4,("using default secdesc for %s\n", printername));
+ secdesc_ctr->len = convertperms_unix_to_sd(NULL, False,
+ 0007,
+ &secdesc_ctr->sec);
+ secdesc_ctr->max_len = secdesc_ctr->len;
+ return 0;
+ }
+
+ prs_mem_free(&ps);
+ return 0;
+}
+
/* error code:
0: everything OK
1: level not implemented