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"
27 /****************************************************************
28 ****************************************************************/
30 WERROR
NetFileClose_r(struct libnetapi_ctx
*ctx
,
31 struct NetFileClose
*r
)
35 struct rpc_pipe_client
*pipe_cli
= NULL
;
37 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
38 &ndr_table_srvsvc
.syntax_id
,
40 if (!W_ERROR_IS_OK(werr
)) {
44 status
= rpccli_srvsvc_NetFileClose(pipe_cli
, ctx
,
48 if (!NT_STATUS_IS_OK(status
)) {
49 werr
= ntstatus_to_werror(status
);
57 /****************************************************************
58 ****************************************************************/
60 WERROR
NetFileClose_l(struct libnetapi_ctx
*ctx
,
61 struct NetFileClose
*r
)
63 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileClose
);
66 /****************************************************************
67 ****************************************************************/
69 static NTSTATUS
map_srvsvc_FileInfo_to_FILE_INFO_buffer(TALLOC_CTX
*mem_ctx
,
71 union srvsvc_NetFileInfo
*info
,
73 uint32_t *num_entries
)
75 struct FILE_INFO_2 i2
;
76 struct FILE_INFO_3 i3
;
80 i2
.fi2_id
= info
->info2
->fid
;
82 ADD_TO_ARRAY(mem_ctx
, struct FILE_INFO_2
, i2
,
83 (struct FILE_INFO_2
**)buffer
,
87 i3
.fi3_id
= info
->info3
->fid
;
88 i3
.fi3_permissions
= info
->info3
->permissions
;
89 i3
.fi3_num_locks
= info
->info3
->num_locks
;
90 i3
.fi3_pathname
= talloc_strdup(mem_ctx
, info
->info3
->path
);
91 i3
.fi3_username
= talloc_strdup(mem_ctx
, info
->info3
->user
);
93 NT_STATUS_HAVE_NO_MEMORY(i3
.fi3_pathname
);
94 NT_STATUS_HAVE_NO_MEMORY(i3
.fi3_username
);
96 ADD_TO_ARRAY(mem_ctx
, struct FILE_INFO_3
, i3
,
97 (struct FILE_INFO_3
**)buffer
,
101 return NT_STATUS_INVALID_INFO_CLASS
;
107 /****************************************************************
108 ****************************************************************/
110 WERROR
NetFileGetInfo_r(struct libnetapi_ctx
*ctx
,
111 struct NetFileGetInfo
*r
)
115 struct rpc_pipe_client
*pipe_cli
= NULL
;
116 union srvsvc_NetFileInfo info
;
117 uint32_t num_entries
= 0;
119 if (!r
->out
.buffer
) {
120 return WERR_INVALID_PARAM
;
123 switch (r
->in
.level
) {
128 return WERR_UNKNOWN_LEVEL
;
131 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
132 &ndr_table_srvsvc
.syntax_id
,
134 if (!W_ERROR_IS_OK(werr
)) {
138 status
= rpccli_srvsvc_NetFileGetInfo(pipe_cli
, ctx
,
144 if (!W_ERROR_IS_OK(werr
)) {
148 status
= map_srvsvc_FileInfo_to_FILE_INFO_buffer(ctx
,
153 if (!NT_STATUS_IS_OK(status
)) {
154 werr
= ntstatus_to_werror(status
);
161 /****************************************************************
162 ****************************************************************/
164 WERROR
NetFileGetInfo_l(struct libnetapi_ctx
*ctx
,
165 struct NetFileGetInfo
*r
)
167 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileGetInfo
);
170 /****************************************************************
171 ****************************************************************/
173 WERROR
NetFileEnum_r(struct libnetapi_ctx
*ctx
,
174 struct NetFileEnum
*r
)
178 struct rpc_pipe_client
*pipe_cli
= NULL
;
179 struct srvsvc_NetFileInfoCtr info_ctr
;
180 struct srvsvc_NetFileCtr2 ctr2
;
181 struct srvsvc_NetFileCtr3 ctr3
;
182 uint32_t num_entries
= 0;
185 if (!r
->out
.buffer
) {
186 return WERR_INVALID_PARAM
;
189 switch (r
->in
.level
) {
194 return WERR_UNKNOWN_LEVEL
;
197 werr
= libnetapi_open_pipe(ctx
, r
->in
.server_name
,
198 &ndr_table_srvsvc
.syntax_id
,
200 if (!W_ERROR_IS_OK(werr
)) {
204 ZERO_STRUCT(info_ctr
);
206 info_ctr
.level
= r
->in
.level
;
207 switch (r
->in
.level
) {
210 info_ctr
.ctr
.ctr2
= &ctr2
;
214 info_ctr
.ctr
.ctr3
= &ctr3
;
218 status
= rpccli_srvsvc_NetFileEnum(pipe_cli
, ctx
,
224 r
->out
.total_entries
,
225 r
->out
.resume_handle
,
227 if (NT_STATUS_IS_ERR(status
)) {
231 for (i
=0; i
< info_ctr
.ctr
.ctr2
->count
; i
++) {
232 union srvsvc_NetFileInfo _i
;
233 switch (r
->in
.level
) {
235 _i
.info2
= &info_ctr
.ctr
.ctr2
->array
[i
];
238 _i
.info3
= &info_ctr
.ctr
.ctr3
->array
[i
];
242 status
= map_srvsvc_FileInfo_to_FILE_INFO_buffer(ctx
,
247 if (!NT_STATUS_IS_OK(status
)) {
248 werr
= ntstatus_to_werror(status
);
253 if (r
->out
.entries_read
) {
254 *r
->out
.entries_read
= num_entries
;
257 if (r
->out
.total_entries
) {
258 *r
->out
.total_entries
= num_entries
;
265 /****************************************************************
266 ****************************************************************/
268 WERROR
NetFileEnum_l(struct libnetapi_ctx
*ctx
,
269 struct NetFileEnum
*r
)
271 LIBNETAPI_REDIRECT_TO_LOCALHOST(ctx
, r
, NetFileEnum
);