2 * Unix SMB/CIFS implementation.
4 * Copyright (C) Guenther Deschner 2008
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, see <http://www.gnu.org/licenses/>.
22 #include "librpc/gen_ndr/libnetapi.h"
23 #include "lib/netapi/netapi.h"
24 #include "lib/netapi/netapi_private.h"
25 #include "lib/netapi/libnetapi.h"
26 #include "../librpc/gen_ndr/cli_srvsvc.h"
28 /****************************************************************
29 ****************************************************************/
31 WERROR
NetFileClose_r(struct libnetapi_ctx
*ctx
,
32 struct NetFileClose
*r
)
36 struct rpc_pipe_client
*pipe_cli
= NULL
;
38 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
39 &ndr_table_srvsvc
.syntax_id
,
41 if (!W_ERROR_IS_OK(werr
)) {
45 status
= rpccli_srvsvc_NetFileClose(pipe_cli
, ctx
,
49 if (!NT_STATUS_IS_OK(status
)) {
50 werr
= ntstatus_to_werror(status
);
58 /****************************************************************
59 ****************************************************************/
61 WERROR
NetFileClose_l(struct libnetapi_ctx
*ctx
,
62 struct NetFileClose
*r
)
64 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileClose
);
67 /****************************************************************
68 ****************************************************************/
70 static NTSTATUS
map_srvsvc_FileInfo_to_FILE_INFO_buffer(TALLOC_CTX
*mem_ctx
,
72 union srvsvc_NetFileInfo
*info
,
74 uint32_t *num_entries
)
76 struct FILE_INFO_2 i2
;
77 struct FILE_INFO_3 i3
;
81 i2
.fi2_id
= info
->info2
->fid
;
83 ADD_TO_ARRAY(mem_ctx
, struct FILE_INFO_2
, i2
,
84 (struct FILE_INFO_2
**)buffer
,
88 i3
.fi3_id
= info
->info3
->fid
;
89 i3
.fi3_permissions
= info
->info3
->permissions
;
90 i3
.fi3_num_locks
= info
->info3
->num_locks
;
91 i3
.fi3_pathname
= talloc_strdup(mem_ctx
, info
->info3
->path
);
92 i3
.fi3_username
= talloc_strdup(mem_ctx
, info
->info3
->user
);
94 NT_STATUS_HAVE_NO_MEMORY(i3
.fi3_pathname
);
95 NT_STATUS_HAVE_NO_MEMORY(i3
.fi3_username
);
97 ADD_TO_ARRAY(mem_ctx
, struct FILE_INFO_3
, i3
,
98 (struct FILE_INFO_3
**)buffer
,
102 return NT_STATUS_INVALID_INFO_CLASS
;
108 /****************************************************************
109 ****************************************************************/
111 WERROR
NetFileGetInfo_r(struct libnetapi_ctx
*ctx
,
112 struct NetFileGetInfo
*r
)
116 struct rpc_pipe_client
*pipe_cli
= NULL
;
117 union srvsvc_NetFileInfo info
;
118 uint32_t num_entries
= 0;
120 if (!r
->out
.buffer
) {
121 return WERR_INVALID_PARAM
;
124 switch (r
->in
.level
) {
129 return WERR_UNKNOWN_LEVEL
;
132 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
133 &ndr_table_srvsvc
.syntax_id
,
135 if (!W_ERROR_IS_OK(werr
)) {
139 status
= rpccli_srvsvc_NetFileGetInfo(pipe_cli
, ctx
,
145 if (!W_ERROR_IS_OK(werr
)) {
149 status
= map_srvsvc_FileInfo_to_FILE_INFO_buffer(ctx
,
154 if (!NT_STATUS_IS_OK(status
)) {
155 werr
= ntstatus_to_werror(status
);
162 /****************************************************************
163 ****************************************************************/
165 WERROR
NetFileGetInfo_l(struct libnetapi_ctx
*ctx
,
166 struct NetFileGetInfo
*r
)
168 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileGetInfo
);
171 /****************************************************************
172 ****************************************************************/
174 WERROR
NetFileEnum_r(struct libnetapi_ctx
*ctx
,
175 struct NetFileEnum
*r
)
179 struct rpc_pipe_client
*pipe_cli
= NULL
;
180 struct srvsvc_NetFileInfoCtr info_ctr
;
181 struct srvsvc_NetFileCtr2 ctr2
;
182 struct srvsvc_NetFileCtr3 ctr3
;
183 uint32_t num_entries
= 0;
186 if (!r
->out
.buffer
) {
187 return WERR_INVALID_PARAM
;
190 switch (r
->in
.level
) {
195 return WERR_UNKNOWN_LEVEL
;
198 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
199 &ndr_table_srvsvc
.syntax_id
,
201 if (!W_ERROR_IS_OK(werr
)) {
205 ZERO_STRUCT(info_ctr
);
207 info_ctr
.level
= r
->in
.level
;
208 switch (r
->in
.level
) {
211 info_ctr
.ctr
.ctr2
= &ctr2
;
215 info_ctr
.ctr
.ctr3
= &ctr3
;
219 status
= rpccli_srvsvc_NetFileEnum(pipe_cli
, ctx
,
225 r
->out
.total_entries
,
226 r
->out
.resume_handle
,
228 if (NT_STATUS_IS_ERR(status
)) {
232 for (i
=0; i
< info_ctr
.ctr
.ctr2
->count
; i
++) {
233 union srvsvc_NetFileInfo _i
;
234 switch (r
->in
.level
) {
236 _i
.info2
= &info_ctr
.ctr
.ctr2
->array
[i
];
239 _i
.info3
= &info_ctr
.ctr
.ctr3
->array
[i
];
243 status
= map_srvsvc_FileInfo_to_FILE_INFO_buffer(ctx
,
248 if (!NT_STATUS_IS_OK(status
)) {
249 werr
= ntstatus_to_werror(status
);
254 if (r
->out
.entries_read
) {
255 *r
->out
.entries_read
= num_entries
;
258 if (r
->out
.total_entries
) {
259 *r
->out
.total_entries
= num_entries
;
266 /****************************************************************
267 ****************************************************************/
269 WERROR
NetFileEnum_l(struct libnetapi_ctx
*ctx
,
270 struct NetFileEnum
*r
)
272 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileEnum
);