com.sun.jna.platform.win32.W32ServiceManager Maven / Gradle / Ivy
/* Copyright (c) 2010 EugineLev, All Rights Reserved
 *
 * The contents of this file is dual-licensed under 2
 * alternative Open Source/Free licenses: LGPL 2.1 or later and
 * Apache License 2.0. (starting with JNA version 4.0.0).
 *
 * You can freely decide which license you want to apply to
 * the project.
 *
 * You may obtain a copy of the LGPL License at:
 *
 * http://www.gnu.org/licenses/licenses.html
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "LGPL2.1".
 *
 * You may obtain a copy of the Apache License at:
 *
 * http://www.apache.org/licenses/
 *
 * A copy is also included in the downloadable source code package
 * containing JNA, in file "AL2.0".
 */
package com.sun.jna.platform.win32;
import com.sun.jna.Memory;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
import com.sun.jna.platform.win32.Winsvc.ENUM_SERVICE_STATUS_PROCESS;
import com.sun.jna.platform.win32.Winsvc.SC_HANDLE;
import com.sun.jna.ptr.IntByReference;
import java.io.Closeable;
/**
 * Win32 Service Manager wrapper
 * @author EugineLev
 */
public class W32ServiceManager implements Closeable {
    SC_HANDLE _handle = null;
    String _machineName = null;
    String _databaseName = null;
    /**
     * Instantiate a W32ServiceManager for the local computer and the
     * SERVICES_ACTIVE_DATABASE ("ServicesActive") database.
     * 
     * 
     * The connection is not established until {@link #open(int)} is called.
     */
    public W32ServiceManager() {
    }
    /**
     * Instantiate a W32ServiceManager for the local computer and the
     * SERVICES_ACTIVE_DATABASE ("ServicesActive") database.
     * 
     * 
     * A connection is opened directly with the requested permissions.
     *
     * @param permissions requested permissions for access
     */
    public W32ServiceManager(int permissions) {
        open(permissions);
    }
    /**
     * Instantiate a W32ServiceManager.
     *
     * @param machineName  The name of the target computer. If the pointer is
     *                     NULL or points to an empty string, the function
     *                     connects to the service control manager on the local
     *                     computer.
     * @param databaseName The name of the service control manager database.
     *                     This parameter should be set to "ServicesActive". If
     *                     it is NULL, the "ServicesActive"
     *                     (SERVICES_ACTIVE_DATABASE) database is opened by
     *                     default.
     * 
     * The connection is not established until {@link #open(int)} is called.
     */
    public W32ServiceManager(String machineName, String databaseName) {
        _machineName = machineName;
        _databaseName = databaseName;
    }
    /**
     * Instantiate a W32ServiceManager.
     * 
     * 
     * A connection is opened directly with the requested permissions.
     *
     * @param machineName  The name of the target computer. If the pointer is
     *                     NULL or points to an empty string, the function
     *                     connects to the service control manager on the local
     *                     computer.
     * @param databaseName The name of the service control manager database.
     *                     This parameter should be set to "ServicesActive". If
     *                     it is NULL, the "ServicesActive"
     *                     (SERVICES_ACTIVE_DATABASE) database is opened by
     *                     default.
     * @param permissions  requested permissions for access
     */
    public W32ServiceManager(String machineName, String databaseName, int permissions) {
        _machineName = machineName;
        _databaseName = databaseName;
        open(permissions);
    }
    /**
     * (Re-)Opens the Service Manager with the supplied permissions.
     *
     * @param permissions Permissions.
     */
    public void open(int permissions) {
        close();
        _handle = Advapi32.INSTANCE.OpenSCManager(
                _machineName, _databaseName, permissions);
        if (_handle == null) {
            throw new Win32Exception(Kernel32.INSTANCE.GetLastError());
        }
    }
    /**
     * Closes the previously opened Service Manager.
     */
    @Override
    public void close() {
        if (_handle != null) {
            if (!Advapi32.INSTANCE.CloseServiceHandle(_handle)) {
                throw new Win32Exception(Kernel32.INSTANCE.GetLastError());
            }
            _handle = null;
        }
    }
    /**
     * Opens a Service.
     *
     * @param serviceName Service name.
     * @param permissions Permissions.
     *
     * @return Returns an opened service.
     */
    public W32Service openService(String serviceName, int permissions) {
        SC_HANDLE serviceHandle = Advapi32.INSTANCE.OpenService(
                _handle, serviceName, permissions);
        if (serviceHandle == null) {
            throw new Win32Exception(Kernel32.INSTANCE.GetLastError());
        }
        return new W32Service(serviceHandle);
    }
    /**
     * Gets the service manager handle.
     *
     * @return Returns the service manager handle.
     */
    public SC_HANDLE getHandle() {
        return _handle;
    }
    /**
     * Enumerates services in the specified service control manager database.
     * The name and status of each service are provided, along with additional
     * data based on the specified information level.
     *
     * @param dwServiceType  The type of services to be enumerated. This
     *                       parameter can be one or more of the following
     *                       values.
     *
     * 
     * Value Meaning  
     * {@link WinNT#SERVICE_DRIVER} Services of type
     * {@link WinNT#SERVICE_KERNEL_DRIVER} and
     * {@link WinNT#SERVICE_FILE_SYSTEM_DRIVER}.  
     * {@link WinNT#SERVICE_FILE_SYSTEM_DRIVER} File system
     * driver services.  
     * {@link WinNT#SERVICE_KERNEL_DRIVER} Driver
     * services.  
     * {@link WinNT#SERVICE_WIN32} Services of type
     * {@link WinNT#SERVICE_WIN32_OWN_PROCESS} and
     * {@link WinNT#SERVICE_WIN32_SHARE_PROCESS}.  
     * {@link WinNT#SERVICE_WIN32_OWN_PROCESS} Services that run
     * in their own processes.  
     * {@link WinNT#SERVICE_WIN32_SHARE_PROCESS} Services that
     * share a process with one or more other services. For more information,
     * see Service Programs.  
     * 
     *
     * @param dwServiceState The state of the services to be enumerated. This
     *                       parameter can be one of the following values.
     * 
     * Value Meaning  
     * {@link Winsvc#SERVICE_ACTIVE} Enumerates services that
     * are in the following states:
     * {@link Winsvc#SERVICE_START_PENDING}, {@link Winsvc#SERVICE_STOP_PENDING}, {@link Winsvc#SERVICE_RUNNING}, {@link Winsvc#SERVICE_CONTINUE_PENDING}, {@link Winsvc#SERVICE_PAUSE_PENDING},
     * and {@link Winsvc#SERVICE_PAUSED}.  
     * {@link Winsvc#SERVICE_INACTIVE} Enumerates services that
     * are in the {@link Winsvc#SERVICE_STOPPED} state.  
     * {@link Winsvc#SERVICE_STATE_ALL} Combines the following
     * states: {@link Winsvc#SERVICE_ACTIVE} and
     * {@link Winsvc#SERVICE_INACTIVE}.  
     * 
     * @param groupName      The load-order group name. If this parameter is a
     *                       string, the only services enumerated are those that
     *                       belong to the group that has the name specified by
     *                       the string. If this parameter is an empty string,
     *                       only services that do not belong to any group are
     *                       enumerated. If this parameter is NULL, group
     *                       membership is ignored and all services are
     *                       enumerated.
     *
     * @return array of ENUM_SERVICE_STATUS_PROCESS structures.
     */
    public ENUM_SERVICE_STATUS_PROCESS[] enumServicesStatusExProcess(int dwServiceType, int dwServiceState, String groupName) {
        IntByReference pcbBytesNeeded = new IntByReference(0);
        IntByReference lpServicesReturned = new IntByReference(0);
        IntByReference lpResumeHandle = new IntByReference(0);
        Advapi32.INSTANCE.EnumServicesStatusEx(_handle, Winsvc.SC_ENUM_PROCESS_INFO, dwServiceType, dwServiceState, Pointer.NULL, 0, pcbBytesNeeded, lpServicesReturned, lpResumeHandle, groupName);
        int lastError = Kernel32.INSTANCE.GetLastError();
        if (lastError != WinError.ERROR_MORE_DATA) {
            throw new Win32Exception(lastError);
        }
        Memory buffer = new Memory(pcbBytesNeeded.getValue());
        boolean result = Advapi32.INSTANCE.EnumServicesStatusEx(_handle, Winsvc.SC_ENUM_PROCESS_INFO, dwServiceType, dwServiceState, buffer, (int) buffer.size(), pcbBytesNeeded, lpServicesReturned, lpResumeHandle, groupName);
        if (!result) {
            throw new Win32Exception(Kernel32.INSTANCE.GetLastError());
        }
        if (lpServicesReturned.getValue() == 0) {
            return new Winsvc.ENUM_SERVICE_STATUS_PROCESS[0];
        }
        ENUM_SERVICE_STATUS_PROCESS status = Structure.newInstance(ENUM_SERVICE_STATUS_PROCESS.class, buffer);
        status.read();
        return (ENUM_SERVICE_STATUS_PROCESS[]) status.toArray(lpServicesReturned.getValue());
    }
}
    © 2015 - 2025 Weber Informatics LLC | Privacy Policy