2 * Unix SMB/CIFS implementation.
3 * RPC Pipe client / server routines
4 * Copyright (C) Gerald Carter 2005.
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 "rpc_client.h"
24 /*******************************************************************
25 *******************************************************************/
27 WERROR
rpccli_svcctl_enumerate_services( struct rpc_pipe_client
*cli
, TALLOC_CTX
*mem_ctx
,
28 POLICY_HND
*hSCM
, uint32 type
, uint32 state
,
29 uint32
*returned
, ENUM_SERVICES_STATUS
**service_array
)
31 SVCCTL_Q_ENUM_SERVICES_STATUS in
;
32 SVCCTL_R_ENUM_SERVICES_STATUS out
;
33 prs_struct qbuf
, rbuf
;
35 ENUM_SERVICES_STATUS
*services
;
41 /* setup the request */
43 memcpy( &in
.handle
, hSCM
, sizeof(POLICY_HND
) );
49 /* first time is to get the buffer size */
52 CLI_DO_RPC_WERR( cli
, mem_ctx
, PI_SVCCTL
, SVCCTL_ENUM_SERVICES_STATUS_W
,
55 svcctl_io_q_enum_services_status
,
56 svcctl_io_r_enum_services_status
,
57 WERR_GENERAL_FAILURE
);
59 /* second time with correct buffer size...should be ok */
61 if ( W_ERROR_EQUAL( out
.status
, WERR_MORE_DATA
) ) {
62 in
.buffer_size
= out
.needed
;
64 CLI_DO_RPC_WERR( cli
, mem_ctx
, PI_SVCCTL
, SVCCTL_ENUM_SERVICES_STATUS_W
,
67 svcctl_io_q_enum_services_status
,
68 svcctl_io_r_enum_services_status
,
69 WERR_GENERAL_FAILURE
);
72 if ( !W_ERROR_IS_OK(out
.status
) )
75 /* pull out the data */
77 if ( !(services
= TALLOC_ARRAY( mem_ctx
, ENUM_SERVICES_STATUS
, out
.returned
)) )
83 for ( i
=0; i
<out
.returned
; i
++ ) {
84 svcctl_io_enum_services_status( "", &services
[i
], &out
.buffer
, 0 );
87 *service_array
= services
;
88 *returned
= out
.returned
;
93 /*******************************************************************
94 *******************************************************************/
96 WERROR
rpccli_svcctl_query_config(struct rpc_pipe_client
*cli
, TALLOC_CTX
*mem_ctx
,
97 POLICY_HND
*hService
, SERVICE_CONFIG
*config
)
99 SVCCTL_Q_QUERY_SERVICE_CONFIG in
;
100 SVCCTL_R_QUERY_SERVICE_CONFIG out
;
101 prs_struct qbuf
, rbuf
;
106 memcpy( &in
.handle
, hService
, sizeof(POLICY_HND
) );
110 CLI_DO_RPC_WERR( cli
, mem_ctx
, PI_SVCCTL
, SVCCTL_QUERY_SERVICE_CONFIG_W
,
113 svcctl_io_q_query_service_config
,
114 svcctl_io_r_query_service_config
,
115 WERR_GENERAL_FAILURE
);
117 if ( W_ERROR_EQUAL( out
.status
, WERR_INSUFFICIENT_BUFFER
) ) {
118 in
.buffer_size
= out
.needed
;
120 CLI_DO_RPC_WERR( cli
, mem_ctx
, PI_SVCCTL
, SVCCTL_QUERY_SERVICE_CONFIG_W
,
123 svcctl_io_q_query_service_config
,
124 svcctl_io_r_query_service_config
,
125 WERR_GENERAL_FAILURE
);
128 if ( !W_ERROR_IS_OK( out
.status
) )
131 memcpy( config
, &out
.config
, sizeof(SERVICE_CONFIG
) );
133 config
->executablepath
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
134 config
->loadordergroup
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
135 config
->dependencies
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
136 config
->startname
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
137 config
->displayname
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
139 if ( out
.config
.executablepath
) {
140 config
->executablepath
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
141 copy_unistr2( config
->executablepath
, out
.config
.executablepath
);
144 if ( out
.config
.loadordergroup
) {
145 config
->loadordergroup
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
146 copy_unistr2( config
->loadordergroup
, out
.config
.loadordergroup
);
149 if ( out
.config
.dependencies
) {
150 config
->dependencies
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
151 copy_unistr2( config
->dependencies
, out
.config
.dependencies
);
154 if ( out
.config
.startname
) {
155 config
->startname
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
156 copy_unistr2( config
->startname
, out
.config
.startname
);
159 if ( out
.config
.displayname
) {
160 config
->displayname
= TALLOC_ZERO_P( mem_ctx
, UNISTR2
);
161 copy_unistr2( config
->displayname
, out
.config
.displayname
);