All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.jna.platform.win32.Netapi32 Maven / Gradle / Ivy

There is a newer version: 5.15.0
Show newest version
/* Copyright (c) 2010 Daniel Doubrovkine, 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.Native;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
import com.sun.jna.platform.win32.DsGetDC.PDOMAIN_CONTROLLER_INFO;
import com.sun.jna.platform.win32.Guid.GUID;
import com.sun.jna.platform.win32.NTSecApi.PLSA_FOREST_TRUST_INFORMATION;
import com.sun.jna.ptr.IntByReference;
import com.sun.jna.ptr.PointerByReference;
import com.sun.jna.win32.StdCallLibrary;
import com.sun.jna.win32.W32APIOptions;

/**
 * Netapi32.dll Interface.
 * @author dblock[at]dblock.org
 */
public interface Netapi32 extends StdCallLibrary {
	
	Netapi32 INSTANCE = Native.load("Netapi32", Netapi32.class, W32APIOptions.DEFAULT_OPTIONS);

	/**
	 * Retrieves join status information for the specified computer.
	 * 
	 * @param lpServer
	 *  Specifies the DNS or NetBIOS name of the computer on which to
	 *  call the function.
	 * @param lpNameBuffer
	 *  Receives the NetBIOS name of the domain or workgroup to which
	 *  the computer is joined.
	 * @param BufferType
	 *  Join status of the specified computer.
	 * @return If the function succeeds, the return value is NERR_Success. If
	 *         the function fails, the return value is a system error code.
	 */
	public int NetGetJoinInformation(String lpServer,
			PointerByReference lpNameBuffer, IntByReference BufferType);

	/**
	 * Frees the memory that the NetApiBufferAllocate function allocates.
	 * 
	 * @param buffer buffer
	 * @return If the function succeeds, the return value is NERR_Success. If
	 *         the function fails, the return value is a system error code.
	 */
	public int NetApiBufferFree(Pointer buffer);

	/**
	 * Returns information about each local group account on the specified
	 * server.
	 * 
	 * @param serverName
	 *  Specifies the DNS or NetBIOS name of the remote server on
	 *  which the function is to execute. If this parameter is NULL,
	 *  the local computer is used.
	 * @param level
	 *  Specifies the information level of the data.
	 * @param bufptr
	 *  Pointer to the address of the buffer that receives the
	 *  information structure.
	 * @param prefmaxlen
	 *  Specifies the preferred maximum length of returned data, in
	 *  bytes.
	 * @param entriesread
	 *  Pointer to a value that receives the count of elements
	 *  actually enumerated.
	 * @param totalentries
	 *  Pointer to a value that receives the approximate total number
	 *  of entries that could have been enumerated from the current
	 *  resume position.
	 * @param resume_handle
	 *  Pointer to a value that contains a resume handle that is used
	 *  to continue an existing local group search.
	 * @return If the function succeeds, the return value is NERR_Success.
	 */
	public int NetLocalGroupEnum(String serverName, int level,
			PointerByReference bufptr, int prefmaxlen,
			IntByReference entriesread, IntByReference totalentries,
			IntByReference resume_handle);
	
	/**
	 * Returns the name of the primary domain controller (PDC).
	 * 
	 * @param serverName 
	 * 	Specifies the DNS or NetBIOS name of the remote server on which the function is 
	 * 	to execute. If this parameter is NULL, the local computer is used. 
	 * @param domainName
	 * 	Specifies the name of the domain. 
	 * @param bufptr
	 * 	Receives a string that specifies the server name of the PDC of the domain.
	 * @return 
	 * 	If the function succeeds, the return value is NERR_Success.
	 */
	public int NetGetDCName(String serverName, String domainName, 
			PointerByReference bufptr);

	/**
	 * The NetGroupEnum function retrieves information about each global group 
	 * in the security database, which is the security accounts manager (SAM) database or,
	 * in the case of domain controllers, the Active Directory.
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the 
	 *  remote server on which the function is to execute. If this parameter is NULL, 
	 *  the local computer is used. 
	 * @param level
	 *  Specifies the information level of the data. 
	 * @param bufptr
	 *  Pointer to the buffer to receive the global group information structure. 
	 *  The format of this data depends on the value of the level parameter. 
	 * @param prefmaxlen
	 *  Specifies the preferred maximum length of the returned data, in bytes. 
	 *  If you specify MAX_PREFERRED_LENGTH, the function allocates the amount of 
	 *  memory required to hold the data. If you specify another value in this 
	 *  parameter, it can restrict the number of bytes that the function returns. 
	 *  If the buffer size is insufficient to hold all entries, the function 
	 *  returns ERROR_MORE_DATA.
	 * @param entriesread
	 *  Pointer to a value that receives the count of elements actually enumerated. 
	 * @param totalentries
	 *  Pointer to a value that receives the total number of entries that could have 
	 *  been enumerated from the current resume position. The total number of entries 
	 *  is only a hint.
	 * @param resume_handle
	 *  Pointer to a variable that contains a resume handle that is used to continue 
	 *  the global group enumeration. The handle should be zero on the first call and 
	 *  left unchanged for subsequent calls. If resume_handle is NULL, no resume handle 
	 *  is stored. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetGroupEnum(String servername, int level, PointerByReference bufptr,
			int prefmaxlen, IntByReference entriesread, IntByReference totalentries,
			IntByReference resume_handle);

	/**
	 * The NetUserEnum function provides information about all user accounts on a server.	 
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the 
	 *  remote server on which the function is to execute. If this parameter is NULL, 
	 *  the local computer is used. 
	 * @param level
	 *  Specifies the information level of the data.
	 * @param filter
	 *  Specifies a value that filters the account types for enumeration.
	 * @param bufptr
	 *  Pointer to the buffer that receives the data. The format of this data depends 
	 *  on the value of the level parameter. This buffer is allocated by the system and
	 *  must be freed using the NetApiBufferFree function. Note that you must free the
	 *  buffer even if the function fails with ERROR_MORE_DATA. 
	 * @param prefmaxlen
	 *  Specifies the preferred maximum length, in 8-bit bytes of returned data. If you 
	 *  specify MAX_PREFERRED_LENGTH, the function allocates the amount of memory 
	 *  required for the data. If you specify another value in this parameter, it can
	 *  restrict the number of bytes that the function returns. If the buffer size is
	 *  insufficient to hold all entries, the function returns ERROR_MORE_DATA. 
	 * @param entriesread
	 *  Pointer to a value that receives the count of elements actually enumerated. 
	 * @param totalentries
	 *  Pointer to a value that receives the total number of entries that could have 
	 *  been enumerated from the current resume position. Note that applications should 
	 *  consider this value only as a hint.
	 * @param resume_handle
	 *  Pointer to a value that contains a resume handle which is used to continue an 
	 *  existing user search. The handle should be zero on the first call and left 
	 *  unchanged for subsequent calls. If resume_handle is NULL, then no resume 
	 *  handle is stored. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserEnum(String servername, int level, int filter, PointerByReference bufptr,
			int prefmaxlen, IntByReference entriesread, IntByReference totalentries,
			IntByReference resume_handle);

	/**
	 * The NetUserGetGroups function retrieves a list of global groups to which a 
	 * specified user belongs.
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the 
	 *  remote server on which the function is to execute. If this parameter is NULL, 
	 *  the local computer is used. 
	 * @param username
	 *  Pointer to a constant string that specifies the name of the user to search for 
	 *  in each group account. For more information, see the following Remarks section. 
	 * @param level
	 *  Specifies the information level of the data.
	 * @param bufptr
	 *  Pointer to the buffer that receives the data. This buffer is allocated by the 
	 *  system and must be freed using the NetApiBufferFree function. Note that you must 
	 *  free the buffer even if the function fails with ERROR_MORE_DATA. 
	 * @param prefmaxlen
	 *  Specifies the preferred maximum length of returned data, in bytes. If you specify 
	 *  MAX_PREFERRED_LENGTH, the function allocates the amount of memory required for the 
	 *  data. If you specify another value in this parameter, it can restrict the number 
	 *  of bytes that the function returns. If the buffer size is insufficient to hold 
	 *  all entries, the function returns ERROR_MORE_DATA.
	 * @param entriesread
	 *  Pointer to a value that receives the count of elements actually retrieved. 
	 * @param totalentries
	 *  Pointer to a value that receives the total number of entries that could have been retrieved. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserGetGroups(String servername, String username, int level,
			PointerByReference bufptr, int prefmaxlen,
			IntByReference entriesread, IntByReference totalentries);
 
	/**
	 * The NetUserGetLocalGroups function retrieves a list of local groups to which a
	 * specified user belongs.
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the remote 
	 *  server on which the function is to execute. If this parameter is NULL, the local 
	 *  computer is used. 
	 * @param username
	 *  Pointer to a constant string that specifies the name of the user for which to return
	 *  local group membership information. If the string is of the form DomainName\UserName 
	 *  the user name is expected to be found on that domain. If the string is of the form 
	 *  UserName, the user name is expected to be found on the server specified by the 
	 *  servername parameter.
	 * @param level
	 *  Specifies the information level of the data.
	 * @param flags
	 *  Specifies a bitmask of flags. Currently, only the value LG_INCLUDE_INDIRECT is 
	 *  defined. If this bit is set, the function also returns the names of the local 
	 *  groups in which the user is indirectly a member (that is, the user has membership 
	 *  in a global group that is itself a member of one or more local groups). 
	 * @param bufptr
	 *  Pointer to the buffer that receives the data. The format of this data depends on 
	 *  the value of the level parameter. This buffer is allocated by the system and must 
	 *  be freed using the NetApiBufferFree function. Note that you must free the buffer 
	 *  even if the function fails with ERROR_MORE_DATA. 
	 * @param prefmaxlen
	 *  Specifies the preferred maximum length of returned data, in bytes. If you specify 
	 *  MAX_PREFERRED_LENGTH, the function allocates the amount of memory required for the 
	 *  data. If you specify another value in this parameter, it can restrict the number of 
	 *  bytes that the function returns. If the buffer size is insufficient to hold all 
	 *  entries, the function returns ERROR_MORE_DATA. For more information, see Network 
	 *  Management Function Buffers and Network Management Function Buffer Lengths. 
	 * @param entriesread
	 *  Pointer to a value that receives the count of elements actually enumerated.
	 * @param totalentries
	 *  Pointer to a value that receives the total number of entries that could have been enumerated. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserGetLocalGroups(String servername, String username, int level,
			int flags, PointerByReference bufptr, int prefmaxlen,
			IntByReference entriesread, IntByReference totalentries);
	
	/**
	 * The NetUserAdd function adds a user account and assigns a password and privilege level.
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the remote server 
	 *  on which the function is to execute.
	 * @param level
	 *  Specifies the information level of the data.
	 * @param buf
	 *  Pointer to the buffer that specifies the data. The format of this data depends on the 
	 *  value of the level parameter.
	 * @param parm_err
	 *  Pointer to a value that receives the index of the first member of the user information 
	 *  structure that causes ERROR_INVALID_PARAMETER. If this parameter is NULL, the index is 
	 *  not returned on error. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserAdd(String servername, int level, 
			Structure buf, IntByReference parm_err);
	
	
	/**
	 * The NetUserDel function deletes a user account from a server.
	 * @param servername
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of the remote 
	 *  server on which the function is to execute. If this parameter is NULL, the local 
	 *  computer is used. 
	 * @param username
	 *  Pointer to a constant string that specifies the name of the user account to delete. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserDel(String servername, String username);		
	
	/**
	 * The NetUserChangePassword function changes a user's password for a specified
	 * network server or domain.
	 * @param domainname
	 *  Pointer to a constant string that specifies the DNS or NetBIOS name of a remote 
	 *  server or domain on which the function is to execute. If this parameter is NULL, 
	 *  the logon domain of the caller is used. 
	 * @param username
	 *  Pointer to a constant string that specifies a user name. The NetUserChangePassword 
	 *  function changes the password for the specified user. If this parameter is NULL, 
	 *  the logon name of the caller is used.
	 * @param oldpassword
	 *  Pointer to a constant string that specifies the user's old password. 
	 * @param newpassword
	 *  Pointer to a constant string that specifies the user's new password. 
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserChangePassword(String domainname, String username, 
			String oldpassword, String newpassword);
	
	/**
	 * The DsGetDcName function returns the name of a domain controller in a specified domain. 
	 * This function accepts additional domain controller selection criteria to indicate 
	 * preference for a domain controller with particular characteristics.
	 * @param ComputerName
	 *  Pointer to a null-terminated string that specifies the name of the server to process 
	 *  this function. Typically, this parameter is NULL, which indicates that the local 
	 *  computer is used. 
	 * @param DomainName
	 *  Pointer to a null-terminated string that specifies the name of the domain or application
	 *  partition to query. This name can either be a DNS style name, for example, fabrikam.com,
	 *  or a flat-style name, for example, Fabrikam. If a DNS style name is specified, the name 
	 *  may be specified with or without a trailing period.
	 * @param DomainGuid
	 *  Pointer to a GUID structure that specifies the GUID of the domain queried. If DomainGuid 
	 *  is not NULL and the domain specified by DomainName or ComputerName cannot be found, 
	 *  DsGetDcName attempts to locate a domain controller in the domain having the GUID specified 
	 *  by DomainGuid.
	 * @param SiteName
	 *  Pointer to a null-terminated string that specifies the name of the site where the returned 
	 *  domain controller should physically exist. If this parameter is NULL, DsGetDcName attempts 
	 *  to return a domain controller in the site closest to the site of the computer specified by 
	 *  ComputerName. This parameter should be NULL, by default.
	 * @param Flags
	 *  Contains a set of flags that provide additional data used to process the request.
	 * @param DomainControllerInfo
	 *  Pointer to a PDOMAIN_CONTROLLER_INFO value that receives a pointer to a 
	 *  DOMAIN_CONTROLLER_INFO structure that contains data about the domain controller selected. 
	 *  This structure is allocated by DsGetDcName. The caller must free the structure using 
	 *  the NetApiBufferFree function when it is no longer required.
	 * @return
	 *  If the function returns domain controller data, the return value is ERROR_SUCCESS.
	 *  If the function fails, the return code is one of ERROR_* values.
	 */
	public int DsGetDcName(String ComputerName, String DomainName, GUID DomainGuid,
            String SiteName, int Flags, PDOMAIN_CONTROLLER_INFO DomainControllerInfo);
	
	/**
	 * The DsGetForestTrustInformationW function obtains forest trust data for a specified domain.
	 * @param serverName
	 *  Contains the name of the domain controller that DsGetForestTrustInformationW 
	 *  is connected to remotely. The caller must be an authenticated user on this server. 
	 *  If this parameter is NULL, the local server is used.
	 * @param trustedDomainName
	 *  Contains the NETBIOS or DNS name of the trusted domain that the forest trust data 
	 *  is to be retrieved for. This domain must have the TRUST_ATTRIBUTE_FOREST_TRANSITIVE 
	 *  trust attribute. If this parameter is NULL, the forest trust data for the domain 
	 *  hosted by ServerName is retrieved.
	 * @param Flags
	 *  Contains a set of flags that modify the behavior of this function.
	 *  DS_GFTI_UPDATE_TDO: If this flag is set, DsGetForestTrustInformationW will update the 
	 *  forest trust data of the trusted domain identified by the TrustedDomainName parameter. 
	 * @param ForestTrustInfo
	 *  Pointer to an LSA_FOREST_TRUST_INFORMATION structure pointer that receives the forest 
	 *  trust data that describes the namespaces claimed by the domain specified by 
	 *  TrustedDomainName. The Time member of all returned records will be zero. 
	 * @return
	 *  Returns NO_ERROR if successful or a Win32 error code otherwise. 
	 */
	public int DsGetForestTrustInformation(String serverName, String trustedDomainName, int Flags, 
			PLSA_FOREST_TRUST_INFORMATION ForestTrustInfo);
	
	/**
	 * The DsEnumerateDomainTrusts function obtains domain trust data for a specified domain.
	 * @param serverName
	 *  Pointer to a null-terminated string that specifies the name of a computer in the domain to 
	 *  obtain the trust information for. This computer must be running the Windows 2000 or later 
	 *  operating system. If this parameter is NULL, the name of the local computer is used. 
	 *  The caller must be an authenticated user in this domain.
	 * @param Flags
	 *  Contains a set of flags that determines which domain trusts to enumerate.
	 * @param Domains
	 *  Receives a pointer which points to an array of DS_DOMAIN_TRUSTS structures. 
	 *  Each structure in this array contains trust data about a domain. The caller must free this 
	 *  memory when it is no longer required by calling NetApiBufferFree.
	 * @param DomainCount
	 *  Pointer to a ULONG value that receives the number of elements returned in the Domains array.
	 * @return
	 *  Returns ERROR_SUCCESS if successful or a Win32 error code otherwise.
	 */
	public int DsEnumerateDomainTrusts(String serverName, int Flags, 
			PointerByReference Domains, IntByReference DomainCount);
	
	/**
	 * The NetUserGetInfo function retrieves information about a particular user account on a server.
	 * @param servername
	 * A pointer to a constant string that specifies the DNS or NetBIOS name of the remote server on 
	 * which the function is to execute. If this parameter is NULL, the local computer is used.
	 * @param username
	 * A pointer to a constant string that specifies the name of the user account for which to return information. 
	 * For more information, see the following Remarks section.
	 * @param level
	 * The information level of the data. This parameter can be one of the following values.
	 * Value Meaning
	 * 0     Return the user account name. The bufptr parameter points to a USER_INFO_0 structure.
	 * 1     Return detailed information about the user account. The bufptr parameter points to a USER_INFO_1 structure.
	 * 2     Return detailed information and additional attributes about the user account. The bufptr parameter points to a USER_INFO_2 structure.
	 * 3     Return detailed information and additional attributes about the user account. This level is valid only on servers. The bufptr parameter points to a USER_INFO_3 structure. Note that it is recommended that you use USER_INFO_4 instead.
	 * 4     Return detailed information and additional attributes about the user account. This level is valid only on servers. The bufptr parameter points to a USER_INFO_4 structure. Windows 2000:  This level is not supported.
	 * 10    Return user and account names and comments. The bufptr parameter points to a USER_INFO_10 structure.
	 * 11    Return detailed information about the user account. The bufptr parameter points to a USER_INFO_11 structure.
	 * 20    Return the user's name and identifier and various account attributes. The bufptr parameter points to a USER_INFO_20 structure. Note that on Windows XP and later, it is recommended that you use USER_INFO_23 instead.
	 * 23    Return the user's name and identifier and various account attributes. The bufptr parameter points to a USER_INFO_23 structure.  Windows 2000:  This level is not supported.
	 * @param bufptr
	 * A pointer to the buffer that receives the data. 
	 * The format of this data depends on the value of the level parameter. 
	 * This buffer is allocated by the system and must be freed using the NetApiBufferFree function. 
	 * For more information, see Network Management Function Buffers and Network Management Function Buffer Lengths.
	 * @return
	 *  If the function succeeds, the return value is NERR_Success.
	 */
	public int NetUserGetInfo(String servername, String username, int level, PointerByReference bufptr);

    /**
     * Shares a server resource.
     * 
     * @param servername [in]
     *  Pointer to a string that specifies the DNS or NetBIOS name of the remote server on which the function is to execute.
     *  If this parameter is NULL, the local computer is used.
     * @param level [in]
     *  Specifies the information level of the data. This parameter can be one of the following values:
     *  2 - Specifies information about the shared resource, including the name of the resource, type and permissions, and number of connections.
     *  The buf parameter points to a SHARE_INFO_2 structure.
     *  502 - Specifies information about the shared resource, including the name of the resource, type and permissions, number of connections, and other pertinent information.
     *  The buf parameter points to a SHARE_INFO_502 structure.
     *  503 - Specifies information about the shared resource, including the name of the resource, type and permissions, number of connections, and other pertinent information.
     *  The buf parameter points to a SHARE_INFO_503 structure.
     * @param buf [in]
     *  Pointer to the buffer that specifies the data. The format of this data depends on the value of the level parameter.
     *  For more information, see Network Management Function Buffers (https://msdn.microsoft.com/en-us/library/windows/desktop/aa370676(v=vs.85).aspx)
     * @param parm_err [out]
     *  Pointer to a value that receives the index of the first member of the share information structure that causes the ERROR_INVALID_PARAMETER error. If this parameter is NULL, the
     *  index is not returned on error. For more information, see the NetShareSetInfo function.
     * @return If the function succeeds, the return value is NERR_Success. If the function fails, the return value can be an error code as seen on MSDN.
     */
    public int NetShareAdd(String servername, int level, Pointer buf, IntByReference parm_err);

    /**
     * Deletes a share name from a server's list of shared resources, disconnecting all connections to the shared resource.
     * 
     * @param servername [in]
     *  Pointer to a string that specifies the DNS or NetBIOS name of the remote server on which the function is to execute.
     *  If this parameter is NULL, the local computer is used.
     * @param netname [in]
     *  Pointer to a string that specifies the name of the share to delete.
     * @param reserved
     *  Reserved, must be zero.
     * @return If the function succeeds, the return value is LMErr.NERR_Success.
     *  If the function fails, the return value can be an error code as seen on MSDN.
     */
    public int NetShareDel(String servername, String netname, int reserved);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy