NTSTATUS status;
WERROR werror;
uint32_t needed;
- struct spoolss_StringArray2 _key_buffer;
+ union spoolss_KeyNames _key_buffer;
+ uint32_t _ndr_size;
status = rpccli_spoolss_EnumPrinterKey(cli, mem_ctx,
handle,
key_name,
+ &_ndr_size,
&_key_buffer,
offered,
&needed,
status = rpccli_spoolss_EnumPrinterKey(cli, mem_ctx,
handle,
key_name,
+ &_ndr_size,
&_key_buffer,
offered,
&needed,
&werror);
}
- *key_buffer = _key_buffer.string;
+ *key_buffer = _key_buffer.string_array;
return werror;
}
goto done;
}
- array = talloc_zero_array(r->out.key_buffer, const char *, num_keys + 1);
+ array = talloc_zero_array(r->out.key_buffer, const char *, num_keys + 2);
if (!array) {
result = WERR_NOMEM;
goto done;
}
+ if (!num_keys) {
+ array[0] = talloc_strdup(array, "");
+ if (!array[0]) {
+ result = WERR_NOMEM;
+ goto done;
+ }
+ }
+
for (i=0; i < num_keys; i++) {
DEBUG(10,("_spoolss_EnumPrinterKey: adding keyname: %s\n",
goto done;
}
+ *r->out._ndr_size = r->in.offered / 2;
*r->out.needed = blob.length;
if (r->in.offered < *r->out.needed) {
result = WERR_MORE_DATA;
} else {
result = WERR_OK;
- r->out.key_buffer->string = array;
+ r->out.key_buffer->string_array = array;
}
done: