SRVSVC pipe
Richard Sharpe
rsharpe at richardsharpe.com
Wed Nov 19 08:20:01 GMT 2003
On Wed, 19 Nov 2003, Stefan Metzmacher wrote:
> Hi tridge,
>
> here's the start of my srvsvc.idl and torture test
>
> I'll try to find some more info levels of the working calls
> and I will try to add more calls the next days...
Ethereal has lots of IDL for srvsvc and wkssvc just for the taking.
Regards
-----
Richard Sharpe, rsharpe[at]ns.aus.com, rsharpe[at]samba.org,
sharpe[at]ethereal.com, http://www.richardsharpe.com
-------------- next part --------------
/*
srvsvc interface definitions
*/
[ uuid(4b324fc8-1670-01d3-1278-5a47bf6ee188),
version(3.0),
pointer_default(unique)
] interface srvsvc
{
/******************/
/* Function: 0x00 */
NTSTATUS srvsvc_00(
);
/******************/
/* Function: 0x01 */
NTSTATUS srvsvc_01(
);
/******************/
/* Function: 0x02 */
NTSTATUS srvsvc_02(
);
/******************/
/* Function: 0x03 */
NTSTATUS srvsvc_03(
);
/******************/
/* Function: 0x04 */
NTSTATUS srvsvc_04(
);
/******************/
/* Function: 0x05 */
NTSTATUS srvsvc_05(
);
/******************/
/* Function: 0x06 */
NTSTATUS srvsvc_06(
);
/******************/
/* Function: 0x07 */
NTSTATUS srvsvc_07(
);
/******************/
/* Function: 0x08 */
typedef struct {
uint32 conn_id;
} srvsvc_NetConn0;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetConn0 *array;
} srvsvc_NetConnCtr0;
typedef struct {
uint32 conn_id;
uint32 conn_type;
uint32 num_open;
uint32 num_users;
uint32 conn_time;
unistr *user;
unistr *client;
} srvsvc_NetConn1;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetConn1 *array;
} srvsvc_NetConnCtr1;
typedef struct {
} srvsvc_NetConnCtrDefault;
typedef [nodiscriminant,public] union {
case(0) srvsvc_NetConnCtr0 *ctr0;
case(1) srvsvc_NetConnCtr1 *ctr1;
default srvsvc_NetConnCtrDefault ctrDefault;
} srvsvc_NetConnSubCtr;
typedef struct {
uint32 level;
uint32 level2;
[switch_is(level)] srvsvc_NetConnSubCtr subctr;
} srvsvc_NetConnCtr;
WERROR srvsvc_NetConnEnum(
[in] unistr *server_unc,
[in] unistr *path,
[in,out] srvsvc_NetConnCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x09 */
typedef struct {
uint32 fid;
} srvsvc_NetFile2;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetFile2 *array;
} srvsvc_NetFileCtr2;
typedef struct {
uint32 fid;
uint32 permissions;
uint32 num_locks;
unistr *path;
unistr *user;
} srvsvc_NetFile3;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetFile3 *array;
} srvsvc_NetFileCtr3;
typedef struct {
} srvsvc_NetFileCtrDefault;
typedef [nodiscriminant,public] union {
case(2) srvsvc_NetFileCtr2 *ctr2;
case(3) srvsvc_NetFileCtr3 *ctr3;
default srvsvc_NetFileCtrDefault ctrDefault;
} srvsvc_NetFileSubCtr;
typedef struct {
uint32 level;
uint32 level2;
[switch_is(level)] srvsvc_NetFileSubCtr subctr;
} srvsvc_NetFileCtr;
WERROR srvsvc_NetFileEnum(
[in] unistr *server_unc,
[in] unistr *path,
[in] unistr *user,
[in,out] srvsvc_NetFileCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x0a */
NTSTATUS srvsvc_0a(
);
/******************/
/* Function: 0x0b */
NTSTATUS srvsvc_NET_FILE_CLOSE(
);
/******************/
/* Function: 0x0c */
typedef struct {
unistr *client;
} srvsvc_NetSess0;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetSess0 *array;
} srvsvc_NetSessCtr0;
typedef struct {
unistr *client;
unistr *user;
uint32 num_open;
uint32 time;
uint32 idle_time;
uint32 user_flags;
} srvsvc_NetSess1;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetSess1 *array;
} srvsvc_NetSessCtr1;
typedef struct {
unistr *client;
unistr *user;
uint32 num_open;
uint32 time;
uint32 idle_time;
uint32 user_flags;
unistr *client_type;
} srvsvc_NetSess2;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetSess2 *array;
} srvsvc_NetSessCtr2;
typedef struct {
unistr *client;
unistr *user;
uint32 time;
uint32 idle_time;
} srvsvc_NetSess10;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetSess10 *array;
} srvsvc_NetSessCtr10;
typedef struct {
unistr *client;
unistr *user;
uint32 num_open;
uint32 time;
uint32 idle_time;
uint32 user_flags;
unistr *client_type;
unistr *transport;
} srvsvc_NetSess502;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetSess502 *array;
} srvsvc_NetSessCtr502;
typedef struct {
} srvsvc_NetSessCtrDefault;
typedef [nodiscriminant,public] union {
case(0) srvsvc_NetSessCtr0 *ctr0;
case(1) srvsvc_NetSessCtr1 *ctr1;
case(2) srvsvc_NetSessCtr2 *ctr2;
case(10) srvsvc_NetSessCtr10 *ctr10;
case(502) srvsvc_NetSessCtr502 *ctr502;
default srvsvc_NetSessCtrDefault ctrDefault;
} srvsvc_NetSessSubCtr;
typedef struct {
uint32 level;
uint32 level2;
[switch_is(level)] srvsvc_NetSessSubCtr subctr;
} srvsvc_NetSessCtr;
WERROR srvsvc_NetSessEnum(
[in] unistr *server_unc,
[in] unistr *client,
[in] unistr *user,
[in,out] srvsvc_NetSessCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x0d */
NTSTATUS srvsvc_0d(
);
/******************/
/* Function: 0x0e */
NTSTATUS srvsvc_NET_SHARE_ADD(
);
/******************/
/* Function: 0x0f */
typedef struct {
unistr *name;
} srvsvc_NetShare0;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetShare0 *array;
} srvsvc_NetShareCtr0;
typedef struct {
unistr *name;
uint32 type;
unistr *comment;
} srvsvc_NetShare1;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetShare1 *array;
} srvsvc_NetShareCtr1;
typedef struct {
unistr *name;
uint32 type;
unistr *comment;
uint32 permissions;
uint32 max_users;
uint32 current_users;
unistr *path;
uint32 *password;
} srvsvc_NetShare2;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetShare2 *array;
} srvsvc_NetShareCtr2;
typedef struct {
unistr *name;
uint32 type;
unistr *comment;
uint32 csc_policy;
} srvsvc_NetShare501;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetShare501 *array;
} srvsvc_NetShareCtr501;
typedef struct {
unistr *name;
uint32 type;
unistr *comment;
uint32 permissions;
uint32 max_users;
uint32 current_users;
unistr *path;
uint32 *password;
uint32 unknown;
[subcontext] security_descriptor *sd;
} srvsvc_NetShare502;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetShare502 *array;
} srvsvc_NetShareCtr502;
typedef struct {
} srvsvc_NetShareCtrDefault;
typedef [nodiscriminant,public] union {
case(0) srvsvc_NetShareCtr0 *ctr0;
case(1) srvsvc_NetShareCtr1 *ctr1;
case(2) srvsvc_NetShareCtr2 *ctr2;
case(501) srvsvc_NetShareCtr501 *ctr501;
case(502) srvsvc_NetShareCtr502 *ctr502;
default srvsvc_NetShareCtrDefault ctrDefault;
} srvsvc_NetShareSubCtr;
typedef struct {
uint32 level;
uint32 level2;
[switch_is(level)] srvsvc_NetShareSubCtr subctr;
} srvsvc_NetShareCtr;
WERROR srvsvc_NetShareEnumAll(
[in] unistr *server_unc,
[in,out] srvsvc_NetShareCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x10 */
NTSTATUS srvsvc_NET_SHARE_GET_INFO(
);
/******************/
/* Function: 0x11 */
NTSTATUS srvsvc_NET_SHARE_SET_INFO(
);
/******************/
/* Function: 0x12 */
NTSTATUS srvsvc_NET_SHARE_DEL(
);
/******************/
/* Function: 0x13 */
NTSTATUS srvsvc_NET_SHARE_DEL_STICKY(
);
/******************/
/* Function: 0x14 */
NTSTATUS srvsvc_14(
);
/******************/
/* Function: 0x15 */
NTSTATUS srvsvc_NET_SRV_GET_INFO(
);
/******************/
/* Function: 0x16 */
NTSTATUS srvsvc_NET_SRV_SET_INFO(
);
/******************/
/* Function: 0x17 */
typedef struct {
uint32 unknown;
uint32 size;
[size_is(size)] uint8 *disk;
} srvsvc_NetDisk0;
typedef struct {
uint32 count;
uint32 unknown1;
uint32 unknown2;
[size_is(count)] srvsvc_NetDisk0 *array;
} srvsvc_NetDiskCtr0;
typedef struct {
uint32 dummy;
} srvsvc_NetDisk1;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetDisk1 *array;
} srvsvc_NetDiskCtr1;
typedef struct {
uint32 dummy;
} srvsvc_NetDisk2;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetDisk2 *array;
} srvsvc_NetDiskCtr2;
typedef struct {
uint32 dummy;
} srvsvc_NetDisk3;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetDisk3 *array;
} srvsvc_NetDiskCtr3;
typedef struct {
} srvsvc_NetDiskCtrDefault;
typedef [nodiscriminant,public] union {
case(0) srvsvc_NetDiskCtr0 ctr0;
case(1) srvsvc_NetDiskCtr1 ctr1;
case(2) srvsvc_NetDiskCtr2 ctr2;
case(3) srvsvc_NetDiskCtr3 ctr3;
default srvsvc_NetDiskCtrDefault ctrDefault;
} srvsvc_NetDiskSubCtr;
typedef struct {
uint32 num1;
srvsvc_NetDiskCtr0 *ctr0;
} srvsvc_NetDiskCtr;
WERROR srvsvc_NetDiskEnum(
[in] unistr *server_unc,
[in] uint32 level,
[in] uint32 unknown1,
[in] uint32 unknown2,
[in] uint32 preferred_len,
[out] srvsvc_NetDiskCtr ctr,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x18 */
NTSTATUS srvsvc_18(
);
/******************/
/* Function: 0x19 */
NTSTATUS srvsvc_19(
);
/******************/
/* Function: 0x1a */
typedef struct {
uint32 count;
[size_is(count)] uint8 *addr;
} srvsvc_TransportAddress;
typedef struct {
uint32 vcs;
unistr *name;
srvsvc_TransportAddress *addr;
uint32 addr_len;
unistr *net_addr;
} srvsvc_NetTransport0;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetTransport0 *array;
} srvsvc_NetTransportCtr0;
typedef struct {
uint32 vcs;
unistr *name;
srvsvc_TransportAddress *addr;
uint32 addr_len;
unistr *net_addr;
unistr *domain;
} srvsvc_NetTransport1;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetTransport1 *array;
} srvsvc_NetTransportCtr1;
typedef struct {
uint32 dummy;
} srvsvc_NetTransport2;
typedef struct {
uint32 count;
[size_is(count)] srvsvc_NetTransport2 *array;
} srvsvc_NetTransportCtr2;
typedef struct {
} srvsvc_NetTransportCtrDefault;
typedef [nodiscriminant,public] union {
case(0) srvsvc_NetTransportCtr0 *ctr0;
case(1) srvsvc_NetTransportCtr1 *ctr1;
case(2) srvsvc_NetTransportCtr2 *ctr2;
default srvsvc_NetTransportCtrDefault ctrDefault;
} srvsvc_NetTransportSubCtr;
typedef struct {
uint32 level;
uint32 level2;
[switch_is(level)] srvsvc_NetTransportSubCtr subctr;
} srvsvc_NetTransportCtr;
WERROR srvsvc_NetTransportEnum(
[in] unistr *server_unc,
[in,out] srvsvc_NetTransportCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x1b */
NTSTATUS srvsvc_1b(
);
/******************/
/* Function: 0x1c */
NTSTATUS srvsvc_NET_REMOTE_TOD(
);
/******************/
/* Function: 0x1d */
NTSTATUS srvsvc_1d(
);
/******************/
/* Function: 0x1e */
NTSTATUS srvsvc_1e(
);
/******************/
/* Function: 0x1f */
NTSTATUS srvsvc_1f(
);
/******************/
/* Function: 0x20 */
NTSTATUS srvsvc_20(
);
/******************/
/* Function: 0x21 */
NTSTATUS srvsvc_NET_NAME_VALIDATE(
);
/******************/
/* Function: 0x22 */
NTSTATUS srvsvc_22(
);
/******************/
/* Function: 0x23 */
NTSTATUS srvsvc_23(
);
/******************/
/* Function: 0x24 */
WERROR srvsvc_NetShareEnum(
[in] unistr *server_unc,
[in,out] srvsvc_NetShareCtr ctr,
[in] uint32 preferred_len,
[out] uint32 total,
[in,out] uint32 *resume_handle
);
/******************/
/* Function: 0x25 */
NTSTATUS srvsvc_25(
);
/******************/
/* Function: 0x26 */
NTSTATUS srvsvc_26(
);
/******************/
/* Function: 0x27 */
NTSTATUS srvsvc_NET_FILE_QUERY_SECDESC(
);
/******************/
/* Function: 0x28 */
NTSTATUS srvsvc_NET_FILE_SET_SECDESC(
);
}
-------------- next part --------------
/*
Unix SMB/CIFS implementation.
test suite for srvsvc rpc operations
Copyright (C) Stefan (metze)3 Metzmacher 2003
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include "includes.h"
static BOOL test_NetConnEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetConnEnum r;
struct srvsvc_NetConnCtr0 c0;
uint32 levels[] = {0, 1};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.path = talloc_asprintf(mem_ctx,"%s","ADMIN$");
r.in.ctr.subctr.ctr0 = &c0;
r.in.ctr.subctr.ctr0->count = 0;
r.in.ctr.subctr.ctr0->array = NULL;
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetConnEnum level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetConnEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetConnEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
static BOOL test_NetFileEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetFileEnum r;
struct srvsvc_NetFileCtr3 c3;
uint32 levels[] = {2, 3};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.path = NULL;
r.in.user = NULL;
r.in.ctr.subctr.ctr3 = &c3;
r.in.ctr.subctr.ctr3->count = 0;
r.in.ctr.subctr.ctr3->array = NULL;
r.in.preferred_len = (uint32)4096;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetFileEnum level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetFileEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetFileEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
static BOOL test_NetSessEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetSessEnum r;
struct srvsvc_NetSessCtr0 c0;
uint32 levels[] = {0, 1, 2, 10, 502};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.client = NULL;
r.in.user = NULL;
r.in.ctr.subctr.ctr0 = &c0;
r.in.ctr.subctr.ctr0->count = 0;
r.in.ctr.subctr.ctr0->array = NULL;
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetSessEnum level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetSessEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetSessEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
static BOOL test_NetShareEnumAll(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetShareEnumAll r;
struct srvsvc_NetShareCtr0 c0;
uint32 levels[] = {0, 1, 2, 501, 502};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.ctr.subctr.ctr0 = &c0;
r.in.ctr.subctr.ctr0->count = 0;
r.in.ctr.subctr.ctr0->array = NULL;
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetShareEnumAll level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetShareEnumAll(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetShareEnumAll level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
#if 0
static BOOL test_NetDiskEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetDiskEnum r;
struct srvsvc_NetDiskCtr0 c0;
uint32 levels[] = {0, 1, 2, 3};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.level = levels[i];
ZERO_STRUCT(r.out);
printf("testing NetDiskEnum level %u\n", r.in.level);
status = dcerpc_srvsvc_NetDiskEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
NDR_PRINT_OUT_DEBUG(srvsvc_NetDiskEnum, &r);
printf("NetDiskEnum level %u failed - %s\n", r.in.level, nt_errstr(status));
ret = False;
}
}
return True;
}
static BOOL test_NetTransportEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetTransportEnum r;
struct srvsvc_NetTransportCtr0 c0;
uint32 levels[] = {0, 1};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.ctr.subctr.ctr0 = &c0;
r.in.ctr.subctr.ctr0->count = 0;
r.in.ctr.subctr.ctr0->array = NULL;
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetTransportEnum level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetTransportEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetTransportEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
#endif
static BOOL test_NetShareEnum(struct dcerpc_pipe *p,
TALLOC_CTX *mem_ctx)
{
NTSTATUS status;
struct srvsvc_NetShareEnum r;
struct srvsvc_NetShareCtr0 c0;
uint32 levels[] = {0, 1, 2, 502};
int i;
BOOL ret = True;
r.in.server_unc = talloc_asprintf(mem_ctx,"\\\\%s",dcerpc_server_name(p));
r.in.ctr.subctr.ctr0 = &c0;
r.in.ctr.subctr.ctr0->count = 0;
r.in.ctr.subctr.ctr0->array = NULL;
r.in.preferred_len = (uint32)-1;
r.in.resume_handle = NULL;
for (i=0;i<ARRAY_SIZE(levels);i++) {
r.in.ctr.level = levels[i];
r.in.ctr.level2 = levels[i];
printf("testing NetShareEnum level %u\n", r.in.ctr.level);
status = dcerpc_srvsvc_NetShareEnum(p, mem_ctx, &r);
if (!NT_STATUS_IS_OK(status)) {
printf("NetShareEnum level %u failed - %s\n", r.in.ctr.level, nt_errstr(status));
ret = False;
}
}
return True;
}
BOOL torture_rpc_srvsvc(int dummy)
{
NTSTATUS status;
struct dcerpc_pipe *p;
TALLOC_CTX *mem_ctx;
BOOL ret = True;
mem_ctx = talloc_init("torture_rpc_srvsvc");
status = torture_rpc_connection(&p,
DCERPC_SRVSVC_NAME,
DCERPC_SRVSVC_UUID,
DCERPC_SRVSVC_VERSION);
if (!NT_STATUS_IS_OK(status)) {
return False;
}
p->flags |= DCERPC_DEBUG_PRINT_BOTH;
if (!test_NetConnEnum(p, mem_ctx)) {
ret = False;
}
if (!test_NetFileEnum(p, mem_ctx)) {
ret = False;
}
if (!test_NetSessEnum(p, mem_ctx)) {
ret = False;
}
if (!test_NetShareEnumAll(p, mem_ctx)) {
ret = False;
}
#if 0
if (!test_NetDiskEnum(p, mem_ctx)) {
ret = False;
}
if (!test_NetTransportEnum(p, mem_ctx)) {
ret = False;
}
#endif
if (!test_NetShareEnum(p, mem_ctx)) {
ret = False;
}
torture_rpc_close(p);
return ret;
}
More information about the samba-technical
mailing list