mirror of
https://github.com/samba-team/samba.git
synced 2025-01-28 17:47:29 +03:00
added a MANGLE_DRIVER_PATH define to chooose whether we stuff with the
driver path do a rename etc. I turned it off by default as it is causing me no end of problems. The client will *cache* this path, and that screws things up badly as the temp directory is no longer there when it is needed. (This used to be commit 46f5f41c88b6ffa117d30f7702628b43dd456902)
This commit is contained in:
parent
5a0d520723
commit
dbf004bdab
@ -25,7 +25,9 @@
|
|||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
|
|
||||||
#define RELIES_ON_SMBD_FUNCTIONS_LINKED_INTO_SPOOLSSD
|
#ifndef MANGLE_DRIVER_PATH
|
||||||
|
#define MANGLE_DRIVER_PATH 0
|
||||||
|
#endif
|
||||||
|
|
||||||
extern int DEBUGLEVEL;
|
extern int DEBUGLEVEL;
|
||||||
extern pstring global_myname;
|
extern pstring global_myname;
|
||||||
@ -3892,7 +3894,7 @@ uint32 _spoolss_addprinterex( const UNISTR2 *uni_srv_name, uint32 level,
|
|||||||
Modify internal driver heirarchy.
|
Modify internal driver heirarchy.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifdef RELIES_ON_SMBD_FUNCTIONS_LINKED_INTO_SPOOLSSD
|
#if MANGLE_DRIVER_PATH
|
||||||
static uint32 modify_driver_heirarchy(NT_PRINTER_DRIVER_INFO_LEVEL *driver, uint32 level)
|
static uint32 modify_driver_heirarchy(NT_PRINTER_DRIVER_INFO_LEVEL *driver, uint32 level)
|
||||||
{
|
{
|
||||||
pstring path_old;
|
pstring path_old;
|
||||||
@ -3947,8 +3949,8 @@ uint32 _spoolss_addprinterdriver( const UNISTR2 *server_name,
|
|||||||
uint32 level,
|
uint32 level,
|
||||||
const SPOOL_PRINTER_DRIVER_INFO_LEVEL *info)
|
const SPOOL_PRINTER_DRIVER_INFO_LEVEL *info)
|
||||||
{
|
{
|
||||||
|
uint32 err = NT_STATUS_NO_PROBLEMO;
|
||||||
NT_PRINTER_DRIVER_INFO_LEVEL driver;
|
NT_PRINTER_DRIVER_INFO_LEVEL driver;
|
||||||
uint32 err;
|
|
||||||
ZERO_STRUCT(driver);
|
ZERO_STRUCT(driver);
|
||||||
|
|
||||||
convert_printer_driver_info(info, &driver, level);
|
convert_printer_driver_info(info, &driver, level);
|
||||||
@ -3956,16 +3958,13 @@ uint32 _spoolss_addprinterdriver( const UNISTR2 *server_name,
|
|||||||
if (add_a_printer_driver(driver, level)!=0)
|
if (add_a_printer_driver(driver, level)!=0)
|
||||||
return ERROR_ACCESS_DENIED;
|
return ERROR_ACCESS_DENIED;
|
||||||
|
|
||||||
#ifdef RELIES_ON_SMBD_FUNCTIONS_LINKED_INTO_SPOOLSSD
|
#if MANGLE_DRIVER_PATH
|
||||||
if ((err = modify_driver_heirarchy(&driver, level)) != 0) {
|
err = modify_driver_heirarchy(&driver, level);
|
||||||
free_a_printer_driver(driver, level);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
free_a_printer_driver(driver, level);
|
free_a_printer_driver(driver, level);
|
||||||
|
|
||||||
return NT_STATUS_NO_PROBLEMO;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -3990,7 +3989,7 @@ static uint32 getprinterdriverdir_level_1(UNISTR2 *name, UNISTR2 *uni_environmen
|
|||||||
unistr2_to_ascii(long_archi, uni_environment, sizeof(long_archi)-1);
|
unistr2_to_ascii(long_archi, uni_environment, sizeof(long_archi)-1);
|
||||||
get_short_archi(short_archi, long_archi);
|
get_short_archi(short_archi, long_archi);
|
||||||
|
|
||||||
#ifdef RELIES_ON_SMBD_FUNCTIONS_LINKED_INTO_SPOOLSSD
|
#if MANGLE_DRIVER_PATH
|
||||||
slprintf(path, sizeof(path)-1, "\\\\%s\\print$\\%s\\TMP_%s", global_myname, short_archi,
|
slprintf(path, sizeof(path)-1, "\\\\%s\\print$\\%s\\TMP_%s", global_myname, short_archi,
|
||||||
client_addr());
|
client_addr());
|
||||||
#else
|
#else
|
||||||
|
Loading…
x
Reference in New Issue
Block a user