diff options
Diffstat (limited to 'source3/services/svc_rcinit.c')
-rw-r--r-- | source3/services/svc_rcinit.c | 150 |
1 files changed, 150 insertions, 0 deletions
diff --git a/source3/services/svc_rcinit.c b/source3/services/svc_rcinit.c new file mode 100644 index 0000000..7a8ad65 --- /dev/null +++ b/source3/services/svc_rcinit.c @@ -0,0 +1,150 @@ +/* + * Unix SMB/CIFS implementation. + * Service Control API Implementation + * Copyright (C) Gerald Carter 2005. + * + * 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 3 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, see <http://www.gnu.org/licenses/>. + */ + +#include "includes.h" +#include "services/services.h" + +/********************************************************************* +*********************************************************************/ + +static WERROR rcinit_stop( const char *service, struct SERVICE_STATUS *status ) +{ + int ret = -1; + + /* + * Disabled due to security concerns and unknown use in the + * field -- vl@samba.org + */ +#if 0 + char *command = NULL; + int fd; + + if (asprintf(&command, "%s/%s/%s stop", + get_dyn_MODULESDIR(), SVCCTL_SCRIPT_DIR, service) < 0) { + return WERR_NOT_ENOUGH_MEMORY; + } + + /* we've already performed the access check when the service was opened */ + + become_root(); + ret = smbrun(command, &fd, NULL); + unbecome_root(); + + DEBUGADD(5, ("rcinit_start: [%s] returned [%d]\n", command, ret)); + close(fd); + + SAFE_FREE(command); + + ZERO_STRUCTP( status ); + + status->type = SERVICE_TYPE_WIN32_SHARE_PROCESS; + status->state = (ret == 0 ) ? SVCCTL_STOPPED : SVCCTL_RUNNING; + status->controls_accepted = SVCCTL_ACCEPT_STOP | + SVCCTL_ACCEPT_SHUTDOWN; +#endif + return ( ret == 0 ) ? WERR_OK : WERR_ACCESS_DENIED; +} + +/********************************************************************* +*********************************************************************/ + +static WERROR rcinit_start( const char *service ) +{ + int ret = -1; + /* + * Disabled due to security concerns and unknown use in the + * field -- vl@samba.org + */ +#if 0 + char *command = NULL; + int fd; + + if (asprintf(&command, "%s/%s/%s start", + get_dyn_MODULESDIR(), SVCCTL_SCRIPT_DIR, service) < 0) { + return WERR_NOT_ENOUGH_MEMORY; + } + + /* we've already performed the access check when the service was opened */ + + become_root(); + ret = smbrun(command, &fd, NULL); + unbecome_root(); + + DEBUGADD(5, ("rcinit_start: [%s] returned [%d]\n", command, ret)); + close(fd); + + SAFE_FREE(command); +#endif + return ( ret == 0 ) ? WERR_OK : WERR_ACCESS_DENIED; +} + +/********************************************************************* +*********************************************************************/ + +static WERROR rcinit_status( const char *service, struct SERVICE_STATUS *status ) +{ + /* + * Disabled due to security concerns and unknown use in the + * field -- vl@samba.org + */ +#if 0 + char *command = NULL; + int ret, fd; + + if (asprintf(&command, "%s/%s/%s status", + get_dyn_MODULESDIR(), SVCCTL_SCRIPT_DIR, service) < 0) { + return WERR_NOT_ENOUGH_MEMORY; + } + + /* we've already performed the access check when the service was opened */ + /* assume as return code of 0 means that the service is ok. Anything else + is STOPPED */ + + become_root(); + ret = smbrun(command, &fd, NULL); + unbecome_root(); + + DEBUGADD(5, ("rcinit_start: [%s] returned [%d]\n", command, ret)); + close(fd); + + SAFE_FREE(command); + + ZERO_STRUCTP( status ); + + status->type = SERVICE_TYPE_WIN32_SHARE_PROCESS; + status->state = (ret == 0 ) ? SVCCTL_RUNNING : SVCCTL_STOPPED; + status->controls_accepted = SVCCTL_ACCEPT_STOP | + SVCCTL_ACCEPT_SHUTDOWN; + + return WERR_OK; +#else + return WERR_ACCESS_DENIED; +#endif +} + +/********************************************************************* +*********************************************************************/ + +/* struct for svcctl control to manipulate rcinit service */ + +SERVICE_CONTROL_OPS rcinit_svc_ops = { + rcinit_stop, + rcinit_start, + rcinit_status +}; |