summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source3/utils/net_rpc_service.c322
1 files changed, 254 insertions, 68 deletions
diff --git a/source3/utils/net_rpc_service.c b/source3/utils/net_rpc_service.c
index 8f04f24ac6..8968c46b70 100644
--- a/source3/utils/net_rpc_service.c
+++ b/source3/utils/net_rpc_service.c
@@ -19,7 +19,7 @@
#include "includes.h"
#include "utils/net.h"
#include "../librpc/gen_ndr/ndr_svcctl.h"
-#include "../librpc/gen_ndr/cli_svcctl.h"
+#include "../librpc/gen_ndr/ndr_svcctl_c.h"
struct svc_state_msg {
uint32 flag;
@@ -70,31 +70,47 @@ static WERROR query_service_state(struct rpc_pipe_client *pipe_hnd,
struct SERVICE_STATUS service_status;
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
/* now cycle until the status is actually 'watch_state' */
- status = rpccli_svcctl_OpenServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenServiceW(b, mem_ctx,
hSCM,
service,
SC_RIGHT_SVC_QUERY_STATUS,
&hService,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Failed to open service. [%s]\n"),
+ nt_errstr(status));
+ return result;
+ }
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Failed to open service. [%s]\n"),
win_errstr(result));
return result;
}
- status = rpccli_svcctl_QueryServiceStatus(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_QueryServiceStatus(b, mem_ctx,
&hService,
&service_status,
&result);
-
- if (NT_STATUS_IS_OK(status) && W_ERROR_IS_OK(result) ) {
- *state = service_status.state;
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result)) {
+ goto done;
}
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
+ *state = service_status.state;
+
+ done:
+ if (is_valid_policy_hnd(&hService)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
+ }
return result;
}
@@ -149,17 +165,24 @@ static WERROR control_service(struct rpc_pipe_client *pipe_hnd,
NTSTATUS status;
struct SERVICE_STATUS service_status;
uint32 state = 0;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
/* Open the Service */
- status = rpccli_svcctl_OpenServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenServiceW(b, mem_ctx,
hSCM,
service,
(SC_RIGHT_SVC_STOP|SC_RIGHT_SVC_PAUSE_CONTINUE),
&hService,
&result);
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Failed to open service. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Failed to open service. [%s]\n"),
win_errstr(result));
goto done;
@@ -167,13 +190,19 @@ static WERROR control_service(struct rpc_pipe_client *pipe_hnd,
/* get the status */
- status = rpccli_svcctl_ControlService(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_ControlService(b, mem_ctx,
&hService,
control,
&service_status,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Control service request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Control service request failed. [%s]\n"),
win_errstr(result));
goto done;
@@ -186,7 +215,10 @@ static WERROR control_service(struct rpc_pipe_client *pipe_hnd,
d_printf(_("%s service is %s.\n"), service, svc_status_string(state));
done:
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
+ if (is_valid_policy_hnd(&hService)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
+ }
return result;
}
@@ -208,6 +240,7 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
int i;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
uint8_t *buffer = NULL;
uint32_t buf_size = 0;
@@ -220,13 +253,19 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
return NT_STATUS_OK;
}
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
@@ -234,7 +273,7 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
}
do {
- status = rpccli_svcctl_EnumServicesStatusW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_EnumServicesStatusW(b, mem_ctx,
&hSCM,
SERVICE_TYPE_WIN32,
SERVICE_STATE_ALL,
@@ -245,10 +284,10 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
&resume_handle,
&result);
- if (NT_STATUS_IS_ERR(status)) {
+ if (!NT_STATUS_IS_OK(status)) {
d_fprintf(stderr,
_("Failed to enumerate services. [%s]\n"),
- win_errstr(result));
+ nt_errstr(status));
break;
}
@@ -258,6 +297,14 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
continue;
}
+ if (!W_ERROR_IS_OK(result)) {
+ status = werror_to_ntstatus(result);
+ d_fprintf(stderr,
+ _("Failed to enumerate services. [%s]\n"),
+ win_errstr(result));
+ break;
+ }
+
if ( num_services == 0 ) {
d_printf(_("No services returned\n"));
break;
@@ -299,7 +346,10 @@ static NTSTATUS rpc_service_list_internal(struct net_context *c,
} while (W_ERROR_EQUAL(result, WERR_MORE_DATA));
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return status;
}
@@ -323,6 +373,7 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
struct QUERY_SERVICE_CONFIG config;
uint32_t buf_size = sizeof(config);
uint32_t ret_size = 0;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service status <service>\n", _("Usage:"));
@@ -330,13 +381,19 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
}
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
@@ -345,14 +402,20 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
/* Open the Service */
- status = rpccli_svcctl_OpenServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenServiceW(b, mem_ctx,
&hSCM,
argv[0],
(SC_RIGHT_SVC_QUERY_STATUS|SC_RIGHT_SVC_QUERY_CONFIG),
&hService,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Failed to open service. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Failed to open service. [%s]\n"),
win_errstr(result));
goto done;
@@ -360,12 +423,18 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
/* get the status */
- status = rpccli_svcctl_QueryServiceStatus(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_QueryServiceStatus(b, mem_ctx,
&hService,
&service_status,
&result);
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Query status request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Query status request failed. [%s]\n"),
win_errstr(result));
goto done;
@@ -376,23 +445,36 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
/* get the config */
- status = rpccli_svcctl_QueryServiceConfigW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_QueryServiceConfigW(b, mem_ctx,
&hService,
&config,
buf_size,
&ret_size,
&result);
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Query config request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
+
if (W_ERROR_EQUAL(result, WERR_INSUFFICIENT_BUFFER)) {
buf_size = ret_size;
- status = rpccli_svcctl_QueryServiceConfigW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_QueryServiceConfigW(b, mem_ctx,
&hService,
&config,
buf_size,
&ret_size,
&result);
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Query config request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
}
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Query config request failed. [%s]\n"),
win_errstr(result));
goto done;
@@ -433,8 +515,14 @@ static NTSTATUS rpc_service_status_internal(struct net_context *c,
}
done:
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hService)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
+ }
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return werror_to_ntstatus(result);
}
@@ -455,6 +543,7 @@ static NTSTATUS rpc_service_stop_internal(struct net_context *c,
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
fstring servicename;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service status <service>\n", _("Usage:"));
@@ -464,13 +553,19 @@ static NTSTATUS rpc_service_stop_internal(struct net_context *c,
fstrcpy( servicename, argv[0] );
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
@@ -480,7 +575,10 @@ static NTSTATUS rpc_service_stop_internal(struct net_context *c,
result = control_service(pipe_hnd, mem_ctx, &hSCM, servicename,
SVCCTL_CONTROL_STOP, SVCCTL_STOPPED );
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return werror_to_ntstatus(result);
}
@@ -501,6 +599,7 @@ static NTSTATUS rpc_service_pause_internal(struct net_context *c,
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
fstring servicename;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service status <service>\n", _("Usage:"));
@@ -510,13 +609,19 @@ static NTSTATUS rpc_service_pause_internal(struct net_context *c,
fstrcpy( servicename, argv[0] );
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
@@ -526,7 +631,10 @@ static NTSTATUS rpc_service_pause_internal(struct net_context *c,
result = control_service(pipe_hnd, mem_ctx, &hSCM, servicename,
SVCCTL_CONTROL_PAUSE, SVCCTL_PAUSED );
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return werror_to_ntstatus(result);
}
@@ -547,6 +655,7 @@ static NTSTATUS rpc_service_resume_internal(struct net_context *c,
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
fstring servicename;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service status <service>\n", _("Usage:"));
@@ -556,13 +665,19 @@ static NTSTATUS rpc_service_resume_internal(struct net_context *c,
fstrcpy( servicename, argv[0] );
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
@@ -572,7 +687,10 @@ static NTSTATUS rpc_service_resume_internal(struct net_context *c,
result = control_service(pipe_hnd, mem_ctx, &hSCM, servicename,
SVCCTL_CONTROL_CONTINUE, SVCCTL_RUNNING );
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return werror_to_ntstatus(result);
}
@@ -593,6 +711,7 @@ static NTSTATUS rpc_service_start_internal(struct net_context *c,
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
uint32 state = 0;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service status <service>\n", _("Usage:"));
@@ -600,29 +719,42 @@ static NTSTATUS rpc_service_start_internal(struct net_context *c,
}
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr,
_("Failed to open Service Control Manager. [%s]\n"),
win_errstr(result));
return werror_to_ntstatus(result);
}
+
/* Open the Service */
- status = rpccli_svcctl_OpenServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenServiceW(b, mem_ctx,
&hSCM,
argv[0],
SC_RIGHT_SVC_START,
&hService,
&result);
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Failed to open service. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Failed to open service. [%s]\n"),
win_errstr(result));
goto done;
@@ -630,13 +762,19 @@ static NTSTATUS rpc_service_start_internal(struct net_context *c,
/* get the status */
- status = rpccli_svcctl_StartServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_StartServiceW(b, mem_ctx,
&hService,
0,
NULL,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Query status request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result) ) {
d_fprintf(stderr, _("Query status request failed. [%s]\n"),
win_errstr(result));
goto done;
@@ -652,8 +790,14 @@ static NTSTATUS rpc_service_start_internal(struct net_context *c,
argv[0], win_errstr(result) );
done:
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ if (is_valid_policy_hnd(&hService)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
+ }
+ if (is_valid_policy_hnd(&hSCM)) {
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
+ }
return werror_to_ntstatus(result);
}
@@ -673,48 +817,71 @@ static NTSTATUS rpc_service_delete_internal(struct net_context *c,
struct policy_handle hSCM, hService;
WERROR result = WERR_GENERAL_FAILURE;
NTSTATUS status;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 1 ) {
d_printf("%s net rpc service delete <service>\n", _("Usage:"));
return NT_STATUS_OK;
}
+ ZERO_STRUCT(hSCM);
+ ZERO_STRUCT(hService);
+
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_ENUMERATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
d_fprintf(stderr,
- _("Failed to open Service Control Manager. [%s]\n"),
- win_errstr(result));
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ win_errstr(result));
return werror_to_ntstatus(result);
}
/* Open the Service */
- status = rpccli_svcctl_OpenServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenServiceW(b, mem_ctx,
&hSCM,
argv[0],
SERVICE_ALL_ACCESS,
&hService,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
d_fprintf(stderr, _("Failed to open service. [%s]\n"),
- win_errstr(result));
+ nt_errstr(status));
+ goto done;
+ }
+
+ if (!W_ERROR_IS_OK(result) ) {
+ d_fprintf(stderr, _("Failed to open service. [%s]\n"),
+ win_errstr(result));
goto done;
}
/* Delete the Service */
- status = rpccli_svcctl_DeleteService(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_DeleteService(b, mem_ctx,
&hService,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
+ d_fprintf(stderr, _("Delete service request failed. [%s]\n"),
+ nt_errstr(status));
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result)) {
d_fprintf(stderr, _("Delete service request failed. [%s]\n"),
win_errstr(result));
goto done;
@@ -724,10 +891,12 @@ static NTSTATUS rpc_service_delete_internal(struct net_context *c,
done:
if (is_valid_policy_hnd(&hService)) {
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
}
if (is_valid_policy_hnd(&hSCM)) {
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
}
return werror_to_ntstatus(result);
@@ -751,6 +920,7 @@ static NTSTATUS rpc_service_create_internal(struct net_context *c,
const char *ServiceName;
const char *DisplayName;
const char *binary_path;
+ struct dcerpc_binding_handle *b = pipe_hnd->binding_handle;
if (argc != 3) {
d_printf("%s net rpc service create <service> "
@@ -758,17 +928,26 @@ static NTSTATUS rpc_service_create_internal(struct net_context *c,
return NT_STATUS_OK;
}
+ ZERO_STRUCT(hSCM);
+ ZERO_STRUCT(hService);
+
/* Open the Service Control Manager */
- status = rpccli_svcctl_OpenSCManagerW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_OpenSCManagerW(b, mem_ctx,
pipe_hnd->srv_name_slash,
NULL,
SC_RIGHT_MGR_CREATE_SERVICE,
&hSCM,
&result);
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result)) {
+ if (!NT_STATUS_IS_OK(status)) {
d_fprintf(stderr,
- _("Failed to open Service Control Manager. [%s]\n"),
- win_errstr(result));
+ _("Failed to open Service Control Manager. [%s]\n"),
+ nt_errstr(status));
+ return status;
+ }
+ if (!W_ERROR_IS_OK(result)) {
+ d_fprintf(stderr,
+ _("Failed to open Service Control Manager. [%s]\n"),
+ win_errstr(result));
return werror_to_ntstatus(result);
}
@@ -778,7 +957,7 @@ static NTSTATUS rpc_service_create_internal(struct net_context *c,
DisplayName = argv[1];
binary_path = argv[2];
- status = rpccli_svcctl_CreateServiceW(pipe_hnd, mem_ctx,
+ status = dcerpc_svcctl_CreateServiceW(b, mem_ctx,
&hSCM,
ServiceName,
DisplayName,
@@ -796,10 +975,15 @@ static NTSTATUS rpc_service_create_internal(struct net_context *c,
0, /* password_size */
&hService,
&result);
-
- if (!NT_STATUS_IS_OK(status) || !W_ERROR_IS_OK(result) ) {
+ if (!NT_STATUS_IS_OK(status)) {
+ result = ntstatus_to_werror(status);
d_fprintf(stderr, _("Create service request failed. [%s]\n"),
- win_errstr(result));
+ nt_errstr(status));
+ goto done;
+ }
+ if (!W_ERROR_IS_OK(result)) {
+ d_fprintf(stderr, _("Create service request failed. [%s]\n"),
+ win_errstr(result));
goto done;
}
@@ -807,10 +991,12 @@ static NTSTATUS rpc_service_create_internal(struct net_context *c,
done:
if (is_valid_policy_hnd(&hService)) {
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hService, NULL);
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hService, &_result);
}
if (is_valid_policy_hnd(&hSCM)) {
- rpccli_svcctl_CloseServiceHandle(pipe_hnd, mem_ctx, &hSCM, NULL);
+ WERROR _result;
+ dcerpc_svcctl_CloseServiceHandle(b, mem_ctx, &hSCM, &_result);
}
return werror_to_ntstatus(result);