1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-13 13:18:06 +03:00

r19028: Implement getprinterinfo level 6 (only the status) and get rid of snum in the

getprinter calls. Survives the RPC-SAMBA3-SPOOLSS test which I will activate
when the Samba4 build farm has picked it up.

Volker
This commit is contained in:
Volker Lendecke 2006-10-02 08:38:54 +00:00 committed by Gerald (Jerry) Carter
parent 5d16aa61c6
commit d7248b6cfa
3 changed files with 251 additions and 80 deletions

View File

@ -984,6 +984,12 @@ typedef struct printer_info_5
} }
PRINTER_INFO_5; PRINTER_INFO_5;
typedef struct printer_info_6
{
uint32 status;
}
PRINTER_INFO_6;
#define SPOOL_DS_PUBLISH 1 #define SPOOL_DS_PUBLISH 1
#define SPOOL_DS_UPDATE 2 #define SPOOL_DS_UPDATE 2
#define SPOOL_DS_UNPUBLISH 4 #define SPOOL_DS_UNPUBLISH 4

View File

@ -2451,6 +2451,24 @@ BOOL smb_io_printer_info_5(const char *desc, RPC_BUFFER *buffer, PRINTER_INFO_5
return True; return True;
} }
/*******************************************************************
Parse a PRINTER_INFO_6 structure.
********************************************************************/
BOOL smb_io_printer_info_6(const char *desc, RPC_BUFFER *buffer,
PRINTER_INFO_6 *info, int depth)
{
prs_struct *ps=&buffer->prs;
prs_debug(ps, depth, desc, "smb_io_printer_info_6");
depth++;
if (!prs_uint32("status", ps, depth, &info->status))
return False;
return True;
}
/******************************************************************* /*******************************************************************
Parse a PRINTER_INFO_7 structure. Parse a PRINTER_INFO_7 structure.
********************************************************************/ ********************************************************************/
@ -3110,6 +3128,14 @@ uint32 spoolss_size_printer_info_5(PRINTER_INFO_5 *info)
return size; return size;
} }
/*******************************************************************
return the size required by a struct in the stream
********************************************************************/
uint32 spoolss_size_printer_info_6(PRINTER_INFO_6 *info)
{
return sizeof(uint32);
}
/******************************************************************* /*******************************************************************
return the size required by a struct in the stream return the size required by a struct in the stream
@ -6263,6 +6289,11 @@ void free_printer_info_5(PRINTER_INFO_5 *printer)
SAFE_FREE(printer); SAFE_FREE(printer);
} }
void free_printer_info_6(PRINTER_INFO_6 *printer)
{
SAFE_FREE(printer);
}
void free_printer_info_7(PRINTER_INFO_7 *printer) void free_printer_info_7(PRINTER_INFO_7 *printer)
{ {
SAFE_FREE(printer); SAFE_FREE(printer);

View File

@ -373,7 +373,8 @@ static WERROR delete_printer_handle(pipes_struct *p, POLICY_HND *hnd)
Return the snum of a printer corresponding to an handle. Return the snum of a printer corresponding to an handle.
****************************************************************************/ ****************************************************************************/
static BOOL get_printer_snum(pipes_struct *p, POLICY_HND *hnd, int *number) static BOOL get_printer_snum(pipes_struct *p, POLICY_HND *hnd, int *number,
struct share_params **params)
{ {
Printer_entry *Printer = find_printer_index_by_hnd(p, hnd); Printer_entry *Printer = find_printer_index_by_hnd(p, hnd);
@ -386,6 +387,13 @@ static BOOL get_printer_snum(pipes_struct *p, POLICY_HND *hnd, int *number)
case SPLHND_PRINTER: case SPLHND_PRINTER:
DEBUG(4,("short name:%s\n", Printer->sharename)); DEBUG(4,("short name:%s\n", Printer->sharename));
*number = print_queue_snum(Printer->sharename); *number = print_queue_snum(Printer->sharename);
if ((*number != -1) && (params != NULL)) {
*params = get_share_params(tmp_talloc_ctx(),
Printer->sharename);
if (*params == NULL) {
return False;
}
}
return (*number != -1); return (*number != -1);
case SPLHND_SERVER: case SPLHND_SERVER:
return False; return False;
@ -1626,7 +1634,7 @@ WERROR _spoolss_open_printer_ex( pipes_struct *p, SPOOL_Q_OPEN_PRINTER_EX *q_u,
/* NT doesn't let us connect to a printer if the connecting user /* NT doesn't let us connect to a printer if the connecting user
doesn't have print permission. */ doesn't have print permission. */
if (!get_printer_snum(p, handle, &snum)) { if (!get_printer_snum(p, handle, &snum, NULL)) {
close_printer_handle(p, handle); close_printer_handle(p, handle);
return WERR_BADFID; return WERR_BADFID;
} }
@ -1853,7 +1861,7 @@ static WERROR _spoolss_enddocprinter_internal(pipes_struct *p, POLICY_HND *handl
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
Printer->document_started=False; Printer->document_started=False;
@ -2445,7 +2453,7 @@ WERROR _spoolss_getprinterdata(pipes_struct *p, SPOOL_Q_GETPRINTERDATA *q_u, SPO
status = getprinterdata_printer_server( p->mem_ctx, value, type, data, needed, *out_size ); status = getprinterdata_printer_server( p->mem_ctx, value, type, data, needed, *out_size );
else else
{ {
if ( !get_printer_snum(p,handle, &snum) ) { if ( !get_printer_snum(p,handle, &snum, NULL) ) {
status = WERR_BADFID; status = WERR_BADFID;
goto done; goto done;
} }
@ -2663,7 +2671,7 @@ WERROR _spoolss_rffpcnex(pipes_struct *p, SPOOL_Q_RFFPCNEX *q_u, SPOOL_R_RFFPCNE
if ( Printer->printer_type == SPLHND_SERVER) if ( Printer->printer_type == SPLHND_SERVER)
snum = -1; snum = -1;
else if ( (Printer->printer_type == SPLHND_PRINTER) && else if ( (Printer->printer_type == SPLHND_PRINTER) &&
!get_printer_snum(p, handle, &snum) ) !get_printer_snum(p, handle, &snum, NULL) )
return WERR_BADFID; return WERR_BADFID;
client_ip.s_addr = inet_addr(p->conn->client_address); client_ip.s_addr = inet_addr(p->conn->client_address);
@ -3751,7 +3759,7 @@ static WERROR printer_notify_info(pipes_struct *p, POLICY_HND *hnd, SPOOL_NOTIFY
if ( !option ) if ( !option )
return WERR_BADFID; return WERR_BADFID;
get_printer_snum(p, hnd, &snum); get_printer_snum(p, hnd, &snum, NULL);
for (i=0; i<option->count; i++) { for (i=0; i<option->count; i++) {
option_type=&option->ctr.type[i]; option_type=&option->ctr.type[i];
@ -3869,7 +3877,9 @@ done:
* fill a printer_info_0 struct * fill a printer_info_0 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_0(Printer_entry *print_hnd, PRINTER_INFO_0 *printer, int snum) static BOOL construct_printer_info_0(Printer_entry *print_hnd,
PRINTER_INFO_0 *printer,
const struct share_params *params)
{ {
pstring chaine; pstring chaine;
int count; int count;
@ -3880,14 +3890,15 @@ static BOOL construct_printer_info_0(Printer_entry *print_hnd, PRINTER_INFO_0 *p
time_t setuptime; time_t setuptime;
print_status_struct status; print_status_struct status;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
count = print_queue_length(snum, &status); count = print_queue_length(params->service, &status);
/* check if we already have a counter for this printer */ /* check if we already have a counter for this printer */
for(session_counter = counter_list; session_counter; session_counter = session_counter->next) { for(session_counter = counter_list; session_counter; session_counter = session_counter->next) {
if (session_counter->snum == snum) if (session_counter->snum == params->service)
break; break;
} }
@ -3898,7 +3909,7 @@ static BOOL construct_printer_info_0(Printer_entry *print_hnd, PRINTER_INFO_0 *p
return False; return False;
} }
ZERO_STRUCTP(session_counter); ZERO_STRUCTP(session_counter);
session_counter->snum=snum; session_counter->snum=params->service;
session_counter->counter=0; session_counter->counter=0;
DLIST_ADD(counter_list, session_counter); DLIST_ADD(counter_list, session_counter);
} }
@ -3974,21 +3985,25 @@ static BOOL construct_printer_info_0(Printer_entry *print_hnd, PRINTER_INFO_0 *p
* construct_printer_info_1 * construct_printer_info_1
* fill a printer_info_1 struct * fill a printer_info_1 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_1(Printer_entry *print_hnd, uint32 flags, PRINTER_INFO_1 *printer, int snum) static BOOL construct_printer_info_1(Printer_entry *print_hnd, uint32 flags,
PRINTER_INFO_1 *printer,
const struct share_params *params)
{ {
pstring chaine; pstring chaine;
pstring chaine2; pstring chaine2;
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
printer->flags=flags; printer->flags=flags;
if (*ntprinter->info_2->comment == '\0') { if (*ntprinter->info_2->comment == '\0') {
init_unistr(&printer->comment, lp_comment(snum)); init_unistr(&printer->comment, lp_comment(params->service));
slprintf(chaine,sizeof(chaine)-1,"%s,%s,%s", ntprinter->info_2->printername, slprintf(chaine,sizeof(chaine)-1,"%s,%s,%s", ntprinter->info_2->printername,
ntprinter->info_2->drivername, lp_comment(snum)); ntprinter->info_2->drivername,
lp_comment(params->service));
} }
else { else {
init_unistr(&printer->comment, ntprinter->info_2->comment); /* saved comment. */ init_unistr(&printer->comment, ntprinter->info_2->comment); /* saved comment. */
@ -4112,26 +4127,29 @@ done:
* fill a printer_info_2 struct * fill a printer_info_2 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_2(Printer_entry *print_hnd, PRINTER_INFO_2 *printer, int snum) static BOOL construct_printer_info_2(Printer_entry *print_hnd,
PRINTER_INFO_2 *printer,
const struct share_params *params)
{ {
int count; int count;
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
print_status_struct status; print_status_struct status;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
count = print_queue_length(snum, &status); count = print_queue_length(params->service, &status);
init_unistr(&printer->servername, ntprinter->info_2->servername); /* servername*/ init_unistr(&printer->servername, ntprinter->info_2->servername); /* servername*/
init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/ init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/
init_unistr(&printer->sharename, lp_servicename(snum)); /* sharename */ init_unistr(&printer->sharename, lp_servicename(params->service)); /* sharename */
init_unistr(&printer->portname, ntprinter->info_2->portname); /* port */ init_unistr(&printer->portname, ntprinter->info_2->portname); /* port */
init_unistr(&printer->drivername, ntprinter->info_2->drivername); /* drivername */ init_unistr(&printer->drivername, ntprinter->info_2->drivername); /* drivername */
if (*ntprinter->info_2->comment == '\0') if (*ntprinter->info_2->comment == '\0')
init_unistr(&printer->comment, lp_comment(snum)); /* comment */ init_unistr(&printer->comment, lp_comment(params->service)); /* comment */
else else
init_unistr(&printer->comment, ntprinter->info_2->comment); /* saved comment. */ init_unistr(&printer->comment, ntprinter->info_2->comment); /* saved comment. */
@ -4151,7 +4169,8 @@ static BOOL construct_printer_info_2(Printer_entry *print_hnd, PRINTER_INFO_2 *p
printer->cjobs = count; /* jobs */ printer->cjobs = count; /* jobs */
printer->averageppm = ntprinter->info_2->averageppm; /* average pages per minute */ printer->averageppm = ntprinter->info_2->averageppm; /* average pages per minute */
if ( !(printer->devmode = construct_dev_mode(lp_const_servicename(snum))) ) if ( !(printer->devmode = construct_dev_mode(
lp_const_servicename(params->service))) )
DEBUG(8, ("Returning NULL Devicemode!\n")); DEBUG(8, ("Returning NULL Devicemode!\n"));
printer->secdesc = NULL; printer->secdesc = NULL;
@ -4176,12 +4195,15 @@ static BOOL construct_printer_info_2(Printer_entry *print_hnd, PRINTER_INFO_2 *p
* fill a printer_info_3 struct * fill a printer_info_3 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_3(Printer_entry *print_hnd, PRINTER_INFO_3 **pp_printer, int snum) static BOOL construct_printer_info_3(Printer_entry *print_hnd,
PRINTER_INFO_3 **pp_printer,
const struct share_params *params)
{ {
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
PRINTER_INFO_3 *printer = NULL; PRINTER_INFO_3 *printer = NULL;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
*pp_printer = NULL; *pp_printer = NULL;
@ -4216,11 +4238,14 @@ static BOOL construct_printer_info_3(Printer_entry *print_hnd, PRINTER_INFO_3 **
* fill a printer_info_4 struct * fill a printer_info_4 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_4(Printer_entry *print_hnd, PRINTER_INFO_4 *printer, int snum) static BOOL construct_printer_info_4(Printer_entry *print_hnd,
PRINTER_INFO_4 *printer,
const struct share_params *params)
{ {
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/ init_unistr(&printer->printername, ntprinter->info_2->printername); /* printername*/
@ -4236,11 +4261,14 @@ static BOOL construct_printer_info_4(Printer_entry *print_hnd, PRINTER_INFO_4 *p
* fill a printer_info_5 struct * fill a printer_info_5 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_5(Printer_entry *print_hnd, PRINTER_INFO_5 *printer, int snum) static BOOL construct_printer_info_5(Printer_entry *print_hnd,
PRINTER_INFO_5 *printer,
const struct share_params *params)
{ {
NT_PRINTER_INFO_LEVEL *ntprinter = NULL; NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2, lp_const_servicename(snum)))) if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False; return False;
init_unistr(&printer->printername, ntprinter->info_2->printername); init_unistr(&printer->printername, ntprinter->info_2->printername);
@ -4257,17 +4285,45 @@ static BOOL construct_printer_info_5(Printer_entry *print_hnd, PRINTER_INFO_5 *p
return True; return True;
} }
/********************************************************************
* construct_printer_info_6
* fill a printer_info_6 struct
********************************************************************/
static BOOL construct_printer_info_6(Printer_entry *print_hnd,
PRINTER_INFO_6 *printer,
const struct share_params *params)
{
NT_PRINTER_INFO_LEVEL *ntprinter = NULL;
int count;
print_status_struct status;
if (!W_ERROR_IS_OK(get_a_printer(print_hnd, &ntprinter, 2,
lp_const_servicename(params->service))))
return False;
count = print_queue_length(params->service, &status);
printer->status = nt_printq_status(status.status);
free_a_printer(&ntprinter, 2);
return True;
}
/******************************************************************** /********************************************************************
* construct_printer_info_7 * construct_printer_info_7
* fill a printer_info_7 struct * fill a printer_info_7 struct
********************************************************************/ ********************************************************************/
static BOOL construct_printer_info_7(Printer_entry *print_hnd, PRINTER_INFO_7 *printer, int snum) static BOOL construct_printer_info_7(Printer_entry *print_hnd,
PRINTER_INFO_7 *printer,
const struct share_params *params)
{ {
char *guid_str = NULL; char *guid_str = NULL;
struct GUID guid; struct GUID guid;
if (is_printer_published(print_hnd, snum, &guid)) { if (is_printer_published(print_hnd, params->service, &guid)) {
asprintf(&guid_str, "{%s}", smb_uuid_string_static(guid)); asprintf(&guid_str, "{%s}", smb_uuid_string_static(guid));
strupper_m(guid_str); strupper_m(guid_str);
init_unistr(&printer->guid, guid_str); init_unistr(&printer->guid, guid_str);
@ -4297,9 +4353,12 @@ static WERROR enum_all_printers_info_1(uint32 flags, RPC_BUFFER *buffer, uint32
for (snum=0; snum<n_services; snum++) { for (snum=0; snum<n_services; snum++) {
if (lp_browseable(snum) && lp_snum_ok(snum) && lp_print_ok(snum) ) { if (lp_browseable(snum) && lp_snum_ok(snum) && lp_print_ok(snum) ) {
struct share_params params;
params.service = snum;
DEBUG(4,("Found a printer in smb.conf: %s[%x]\n", lp_servicename(snum), snum)); DEBUG(4,("Found a printer in smb.conf: %s[%x]\n", lp_servicename(snum), snum));
if (construct_printer_info_1(NULL, flags, &current_prt, snum)) { if (construct_printer_info_1(NULL, flags, &current_prt, &params)) {
if((printers=SMB_REALLOC_ARRAY(printers, PRINTER_INFO_1, *returned +1)) == NULL) { if((printers=SMB_REALLOC_ARRAY(printers, PRINTER_INFO_1, *returned +1)) == NULL) {
DEBUG(2,("enum_all_printers_info_1: failed to enlarge printers buffer!\n")); DEBUG(2,("enum_all_printers_info_1: failed to enlarge printers buffer!\n"));
*returned=0; *returned=0;
@ -4483,9 +4542,11 @@ static WERROR enum_all_printers_info_2(RPC_BUFFER *buffer, uint32 offered, uint3
for (snum=0; snum<n_services; snum++) { for (snum=0; snum<n_services; snum++) {
if (lp_browseable(snum) && lp_snum_ok(snum) && lp_print_ok(snum) ) { if (lp_browseable(snum) && lp_snum_ok(snum) && lp_print_ok(snum) ) {
struct share_params params;
params.service = snum;
DEBUG(4,("Found a printer in smb.conf: %s[%x]\n", lp_servicename(snum), snum)); DEBUG(4,("Found a printer in smb.conf: %s[%x]\n", lp_servicename(snum), snum));
if (construct_printer_info_2(NULL, &current_prt, snum)) { if (construct_printer_info_2(NULL, &current_prt, &params)) {
if ( !(printers=SMB_REALLOC_ARRAY(printers, PRINTER_INFO_2, *returned +1)) ) { if ( !(printers=SMB_REALLOC_ARRAY(printers, PRINTER_INFO_2, *returned +1)) ) {
DEBUG(2,("enum_all_printers_info_2: failed to enlarge printers buffer!\n")); DEBUG(2,("enum_all_printers_info_2: failed to enlarge printers buffer!\n"));
*returned = 0; *returned = 0;
@ -4666,7 +4727,10 @@ WERROR _spoolss_enumprinters( pipes_struct *p, SPOOL_Q_ENUMPRINTERS *q_u, SPOOL_
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_0(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_0(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_0 *printer=NULL; PRINTER_INFO_0 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4674,7 +4738,7 @@ static WERROR getprinter_level_0(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_0)) == NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_0)) == NULL)
return WERR_NOMEM; return WERR_NOMEM;
construct_printer_info_0(print_hnd, printer, snum); construct_printer_info_0(print_hnd, printer, params);
/* check the required size. */ /* check the required size. */
*needed += spoolss_size_printer_info_0(printer); *needed += spoolss_size_printer_info_0(printer);
@ -4703,7 +4767,10 @@ out:
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_1(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_1(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_1 *printer=NULL; PRINTER_INFO_1 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4711,7 +4778,8 @@ static WERROR getprinter_level_1(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_1)) == NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_1)) == NULL)
return WERR_NOMEM; return WERR_NOMEM;
construct_printer_info_1(print_hnd, PRINTER_ENUM_ICON8, printer, snum); construct_printer_info_1(print_hnd, PRINTER_ENUM_ICON8, printer,
params);
/* check the required size. */ /* check the required size. */
*needed += spoolss_size_printer_info_1(printer); *needed += spoolss_size_printer_info_1(printer);
@ -4739,7 +4807,10 @@ out:
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_2(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_2(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_2 *printer=NULL; PRINTER_INFO_2 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4747,7 +4818,7 @@ static WERROR getprinter_level_2(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_2))==NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_2))==NULL)
return WERR_NOMEM; return WERR_NOMEM;
construct_printer_info_2(print_hnd, printer, snum); construct_printer_info_2(print_hnd, printer, params);
/* check the required size. */ /* check the required size. */
*needed += spoolss_size_printer_info_2(printer); *needed += spoolss_size_printer_info_2(printer);
@ -4776,12 +4847,15 @@ out:
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_3(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_3(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_3 *printer=NULL; PRINTER_INFO_3 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
if (!construct_printer_info_3(print_hnd, &printer, snum)) if (!construct_printer_info_3(print_hnd, &printer, params))
return WERR_NOMEM; return WERR_NOMEM;
/* check the required size. */ /* check the required size. */
@ -4810,7 +4884,10 @@ out:
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_4(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_4(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_4 *printer=NULL; PRINTER_INFO_4 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4818,7 +4895,7 @@ static WERROR getprinter_level_4(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_4))==NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_4))==NULL)
return WERR_NOMEM; return WERR_NOMEM;
if (!construct_printer_info_4(print_hnd, printer, snum)) { if (!construct_printer_info_4(print_hnd, printer, params)) {
SAFE_FREE(printer); SAFE_FREE(printer);
return WERR_NOMEM; return WERR_NOMEM;
} }
@ -4849,7 +4926,10 @@ out:
/**************************************************************************** /****************************************************************************
****************************************************************************/ ****************************************************************************/
static WERROR getprinter_level_5(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_5(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_5 *printer=NULL; PRINTER_INFO_5 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4857,7 +4937,7 @@ static WERROR getprinter_level_5(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_5))==NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_5))==NULL)
return WERR_NOMEM; return WERR_NOMEM;
if (!construct_printer_info_5(print_hnd, printer, snum)) { if (!construct_printer_info_5(print_hnd, printer, params)) {
free_printer_info_5(printer); free_printer_info_5(printer);
return WERR_NOMEM; return WERR_NOMEM;
} }
@ -4885,7 +4965,50 @@ out:
return result; return result;
} }
static WERROR getprinter_level_7(Printer_entry *print_hnd, int snum, RPC_BUFFER *buffer, uint32 offered, uint32 *needed) static WERROR getprinter_level_6(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{
PRINTER_INFO_6 *printer;
WERROR result = WERR_OK;
if ((printer = SMB_MALLOC_P(PRINTER_INFO_6)) == NULL) {
return WERR_NOMEM;
}
if (!construct_printer_info_6(print_hnd, printer, params)) {
free_printer_info_6(printer);
return WERR_NOMEM;
}
/* check the required size. */
*needed += spoolss_size_printer_info_6(printer);
if (*needed > offered) {
result = WERR_INSUFFICIENT_BUFFER;
goto out;
}
if (!rpcbuf_alloc_size(buffer, *needed)) {
result = WERR_NOMEM;
goto out;
}
/* fill the buffer with the structures */
smb_io_printer_info_6("", buffer, printer, 0);
out:
/* clear memory */
free_printer_info_6(printer);
return result;
}
static WERROR getprinter_level_7(Printer_entry *print_hnd,
const struct share_params *params,
RPC_BUFFER *buffer, uint32 offered,
uint32 *needed)
{ {
PRINTER_INFO_7 *printer=NULL; PRINTER_INFO_7 *printer=NULL;
WERROR result = WERR_OK; WERROR result = WERR_OK;
@ -4893,7 +5016,7 @@ static WERROR getprinter_level_7(Printer_entry *print_hnd, int snum, RPC_BUFFER
if((printer=SMB_MALLOC_P(PRINTER_INFO_7))==NULL) if((printer=SMB_MALLOC_P(PRINTER_INFO_7))==NULL)
return WERR_NOMEM; return WERR_NOMEM;
if (!construct_printer_info_7(print_hnd, printer, snum)) if (!construct_printer_info_7(print_hnd, printer, params))
return WERR_NOMEM; return WERR_NOMEM;
/* check the required size. */ /* check the required size. */
@ -4931,6 +5054,7 @@ WERROR _spoolss_getprinter(pipes_struct *p, SPOOL_Q_GETPRINTER *q_u, SPOOL_R_GET
uint32 offered = q_u->offered; uint32 offered = q_u->offered;
uint32 *needed = &r_u->needed; uint32 *needed = &r_u->needed;
Printer_entry *Printer=find_printer_index_by_hnd(p, handle); Printer_entry *Printer=find_printer_index_by_hnd(p, handle);
struct share_params *params;
int snum; int snum;
@ -4945,24 +5069,34 @@ WERROR _spoolss_getprinter(pipes_struct *p, SPOOL_Q_GETPRINTER *q_u, SPOOL_R_GET
*needed=0; *needed=0;
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, &params))
return WERR_BADFID; return WERR_BADFID;
switch (level) { switch (level) {
case 0: case 0:
return getprinter_level_0(Printer, snum, buffer, offered, needed); return getprinter_level_0(Printer, params, buffer, offered,
needed);
case 1: case 1:
return getprinter_level_1(Printer, snum, buffer, offered, needed); return getprinter_level_1(Printer, params, buffer, offered,
needed);
case 2: case 2:
return getprinter_level_2(Printer, snum, buffer, offered, needed); return getprinter_level_2(Printer, params, buffer, offered,
needed);
case 3: case 3:
return getprinter_level_3(Printer, snum, buffer, offered, needed); return getprinter_level_3(Printer, params, buffer, offered,
needed);
case 4: case 4:
return getprinter_level_4(Printer, snum, buffer, offered, needed); return getprinter_level_4(Printer, params, buffer, offered,
needed);
case 5: case 5:
return getprinter_level_5(Printer, snum, buffer, offered, needed); return getprinter_level_5(Printer, params, buffer, offered,
needed);
case 6:
return getprinter_level_6(Printer, params, buffer, offered,
needed);
case 7: case 7:
return getprinter_level_7(Printer, snum, buffer, offered, needed); return getprinter_level_7(Printer, params, buffer, offered,
needed);
} }
return WERR_UNKNOWN_LEVEL; return WERR_UNKNOWN_LEVEL;
} }
@ -5559,7 +5693,7 @@ WERROR _spoolss_getprinterdriver2(pipes_struct *p, SPOOL_Q_GETPRINTERDRIVER2 *q_
fstrcpy(servername, get_server_name( printer )); fstrcpy(servername, get_server_name( printer ));
unistr2_to_ascii(architecture, uni_arch, sizeof(architecture)-1); unistr2_to_ascii(architecture, uni_arch, sizeof(architecture)-1);
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
switch (level) { switch (level) {
@ -5615,7 +5749,7 @@ WERROR _spoolss_endpageprinter(pipes_struct *p, SPOOL_Q_ENDPAGEPRINTER *q_u, SPO
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
Printer->page_started=False; Printer->page_started=False;
@ -5664,7 +5798,7 @@ WERROR _spoolss_startdocprinter(pipes_struct *p, SPOOL_Q_STARTDOCPRINTER *q_u, S
} }
/* get the share number of the printer */ /* get the share number of the printer */
if (!get_printer_snum(p, handle, &snum)) { if (!get_printer_snum(p, handle, &snum, NULL)) {
return WERR_BADFID; return WERR_BADFID;
} }
@ -5716,7 +5850,7 @@ WERROR _spoolss_writeprinter(pipes_struct *p, SPOOL_Q_WRITEPRINTER *q_u, SPOOL_R
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
(*buffer_written) = (uint32)print_job_write(snum, Printer->jobid, (const char *)buffer, (*buffer_written) = (uint32)print_job_write(snum, Printer->jobid, (const char *)buffer,
@ -5752,7 +5886,7 @@ static WERROR control_printer(POLICY_HND *handle, uint32 command,
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
switch (command) { switch (command) {
@ -5797,7 +5931,7 @@ WERROR _spoolss_abortprinter(pipes_struct *p, SPOOL_Q_ABORTPRINTER *q_u, SPOOL_R
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
print_job_delete( &p->pipe_user, snum, Printer->jobid, &errcode ); print_job_delete( &p->pipe_user, snum, Printer->jobid, &errcode );
@ -5820,7 +5954,7 @@ static WERROR update_printer_sec(POLICY_HND *handle, uint32 level,
Printer_entry *Printer = find_printer_index_by_hnd(p, handle); Printer_entry *Printer = find_printer_index_by_hnd(p, handle);
if (!Printer || !get_printer_snum(p, handle, &snum)) { if (!Printer || !get_printer_snum(p, handle, &snum, NULL)) {
DEBUG(2,("update_printer_sec: Invalid handle (%s:%u:%u)\n", DEBUG(2,("update_printer_sec: Invalid handle (%s:%u:%u)\n",
OUR_HANDLE(handle))); OUR_HANDLE(handle)));
@ -6095,7 +6229,7 @@ static WERROR update_printer(pipes_struct *p, POLICY_HND *handle, uint32 level,
goto done; goto done;
} }
if (!get_printer_snum(p, handle, &snum)) { if (!get_printer_snum(p, handle, &snum, NULL)) {
result = WERR_BADFID; result = WERR_BADFID;
goto done; goto done;
} }
@ -6286,7 +6420,7 @@ static WERROR publish_or_unpublish_printer(pipes_struct *p, POLICY_HND *handle,
if (!Printer) if (!Printer)
return WERR_BADFID; return WERR_BADFID;
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
nt_printer_publish(Printer, snum, info7->action); nt_printer_publish(Printer, snum, info7->action);
@ -6356,7 +6490,7 @@ WERROR _spoolss_fcpn(pipes_struct *p, SPOOL_Q_FCPN *q_u, SPOOL_R_FCPN *r_u)
if ( Printer->printer_type == SPLHND_SERVER) if ( Printer->printer_type == SPLHND_SERVER)
snum = -1; snum = -1;
else if ( (Printer->printer_type == SPLHND_PRINTER) && else if ( (Printer->printer_type == SPLHND_PRINTER) &&
!get_printer_snum(p, handle, &snum) ) !get_printer_snum(p, handle, &snum, NULL) )
return WERR_BADFID; return WERR_BADFID;
srv_spoolss_replycloseprinter(snum, &Printer->notify.client_hnd); srv_spoolss_replycloseprinter(snum, &Printer->notify.client_hnd);
@ -6603,7 +6737,7 @@ WERROR _spoolss_enumjobs( pipes_struct *p, SPOOL_Q_ENUMJOBS *q_u, SPOOL_R_ENUMJO
/* lookup the printer snum and tdb entry */ /* lookup the printer snum and tdb entry */
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
wret = get_a_printer(NULL, &ntprinter, 2, lp_servicename(snum)); wret = get_a_printer(NULL, &ntprinter, 2, lp_servicename(snum));
@ -6657,7 +6791,7 @@ WERROR _spoolss_setjob(pipes_struct *p, SPOOL_Q_SETJOB *q_u, SPOOL_R_SETJOB *r_u
int snum; int snum;
WERROR errcode = WERR_BADFUNC; WERROR errcode = WERR_BADFUNC;
if (!get_printer_snum(p, handle, &snum)) { if (!get_printer_snum(p, handle, &snum, NULL)) {
return WERR_BADFID; return WERR_BADFID;
} }
@ -7883,7 +8017,7 @@ WERROR _spoolss_enumprinterdata(pipes_struct *p, SPOOL_Q_ENUMPRINTERDATA *q_u, S
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
result = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum)); result = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum));
@ -8048,7 +8182,7 @@ WERROR _spoolss_setprinterdata( pipes_struct *p, SPOOL_Q_SETPRINTERDATA *q_u, SP
return WERR_INVALID_PARAM; return WERR_INVALID_PARAM;
} }
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
/* /*
@ -8120,7 +8254,7 @@ WERROR _spoolss_resetprinter(pipes_struct *p, SPOOL_Q_RESETPRINTER *q_u, SPOOL_R
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
@ -8150,7 +8284,7 @@ WERROR _spoolss_deleteprinterdata(pipes_struct *p, SPOOL_Q_DELETEPRINTERDATA *q_
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) { if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) {
@ -8202,7 +8336,7 @@ WERROR _spoolss_addform( pipes_struct *p, SPOOL_Q_ADDFORM *q_u, SPOOL_R_ADDFORM
if ( Printer->printer_type == SPLHND_PRINTER ) if ( Printer->printer_type == SPLHND_PRINTER )
{ {
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum)); status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum));
@ -8273,7 +8407,7 @@ WERROR _spoolss_deleteform( pipes_struct *p, SPOOL_Q_DELETEFORM *q_u, SPOOL_R_DE
if ( Printer->printer_type == SPLHND_PRINTER ) if ( Printer->printer_type == SPLHND_PRINTER )
{ {
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum)); status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum));
@ -8341,7 +8475,7 @@ WERROR _spoolss_setform(pipes_struct *p, SPOOL_Q_SETFORM *q_u, SPOOL_R_SETFORM *
if ( Printer->printer_type == SPLHND_PRINTER ) if ( Printer->printer_type == SPLHND_PRINTER )
{ {
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum)); status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum));
@ -8827,7 +8961,7 @@ WERROR _spoolss_getjob( pipes_struct *p, SPOOL_Q_GETJOB *q_u, SPOOL_R_GETJOB *r_
*needed = 0; *needed = 0;
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
wstatus = get_a_printer(NULL, &ntprinter, 2, lp_servicename(snum)); wstatus = get_a_printer(NULL, &ntprinter, 2, lp_servicename(snum));
@ -8910,7 +9044,7 @@ WERROR _spoolss_getprinterdataex(pipes_struct *p, SPOOL_Q_GETPRINTERDATAEX *q_u,
goto done; goto done;
} }
if ( !get_printer_snum(p,handle, &snum) ) if ( !get_printer_snum(p,handle, &snum, NULL) )
return WERR_BADFID; return WERR_BADFID;
status = get_a_printer(Printer, &printer, 2, lp_servicename(snum)); status = get_a_printer(Printer, &printer, 2, lp_servicename(snum));
@ -8996,7 +9130,7 @@ WERROR _spoolss_setprinterdataex(pipes_struct *p, SPOOL_Q_SETPRINTERDATAEX *q_u,
return WERR_INVALID_PARAM; return WERR_INVALID_PARAM;
} }
if ( !get_printer_snum(p,handle, &snum) ) if ( !get_printer_snum(p,handle, &snum, NULL) )
return WERR_BADFID; return WERR_BADFID;
/* /*
@ -9083,7 +9217,7 @@ WERROR _spoolss_deleteprinterdataex(pipes_struct *p, SPOOL_Q_DELETEPRINTERDATAEX
return WERR_BADFID; return WERR_BADFID;
} }
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) { if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) {
@ -9135,7 +9269,7 @@ WERROR _spoolss_enumprinterkey(pipes_struct *p, SPOOL_Q_ENUMPRINTERKEY *q_u, SPO
return WERR_BADFID; return WERR_BADFID;
} }
if ( !get_printer_snum(p,handle, &snum) ) if ( !get_printer_snum(p,handle, &snum, NULL) )
return WERR_BADFID; return WERR_BADFID;
status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum)); status = get_a_printer(Printer, &printer, 2, lp_const_servicename(snum));
@ -9205,7 +9339,7 @@ WERROR _spoolss_deleteprinterkey(pipes_struct *p, SPOOL_Q_DELETEPRINTERKEY *q_u,
if ( !q_u->keyname.buffer ) if ( !q_u->keyname.buffer )
return WERR_INVALID_PARAM; return WERR_INVALID_PARAM;
if (!get_printer_snum(p, handle, &snum)) if (!get_printer_snum(p, handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) { if (Printer->access_granted != PRINTER_ACCESS_ADMINISTER) {
@ -9278,7 +9412,7 @@ WERROR _spoolss_enumprinterdataex(pipes_struct *p, SPOOL_Q_ENUMPRINTERDATAEX *q_
/* get the printer off of disk */ /* get the printer off of disk */
if (!get_printer_snum(p,handle, &snum)) if (!get_printer_snum(p,handle, &snum, NULL))
return WERR_BADFID; return WERR_BADFID;
ZERO_STRUCT(printer); ZERO_STRUCT(printer);