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

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

There is a newer version: 5.15.0
Show newest version
/* Copyright (c) 2011 Timothy Wall, 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.platform.win32.WinDef.BOOLByReference;
import com.sun.jna.platform.win32.WinNT.HANDLE;
import com.sun.jna.platform.win32.WinNT.HANDLEByReference;
import com.sun.jna.platform.win32.WinRas.RASCONN;
import com.sun.jna.platform.win32.WinRas.RASCONNSTATUS;
import com.sun.jna.platform.win32.WinRas.RASCREDENTIALS;
import com.sun.jna.platform.win32.WinRas.RASDIALEXTENSIONS;
import com.sun.jna.platform.win32.WinRas.RASDIALPARAMS;
import com.sun.jna.platform.win32.WinRas.RASENTRY;
import com.sun.jna.platform.win32.WinRas.RAS_STATS;
import com.sun.jna.platform.win32.WinRas.RasDialFunc2;
import com.sun.jna.ptr.IntByReference;
import com.sun.jna.win32.StdCallLibrary;
import com.sun.jna.win32.W32APIOptions;

/**
 * Rasapi32.dll Interface.
 */
public interface Rasapi32 extends StdCallLibrary {
    Rasapi32 INSTANCE = Native.load("Rasapi32", Rasapi32.class, W32APIOptions.DEFAULT_OPTIONS);

    /**
     * The RasDial function establishes a RAS connection between a RAS client and a RAS server.
     * The connection data includes callback and user-authentication information.
     *
     * @param lpRasDialExtensions
     *            Pointer to a RASDIALEXTENSIONS structure that specifies a set of RasDial extended features to enable.
     *            Set this parameter to NULL if there is not a need to enable these features.
     * @param lpszPhonebook
     *            Pointer to a null-terminated string that specifies the full path and file name of a phone-book (PBK) file.
     *            If this parameter is NULL, the function uses the current default phone-book file.
     *            The default phone-book file is the one selected by the user in the User Preferences property sheet of the
     *            Dial-Up Networking dialog box.
     * @param lpRasDialParams
     *            Pointer to a RASDIALPARAMS structure that specifies calling parameters for the RAS connection.
     *            Use the RasGetEntryDialParams function to retrieve a copy of this structure for a particular phone-book entry.
     * @param dwNotifierType
     *            Specifies the nature of the lpvNotifier parameter. If lpvNotifier is NULL, dwNotifierType is ignored.
     *            If lpvNotifier is not NULL, set dwNotifierType to one of the following values.
     * @param lpvNotifier
     *            Specifies a window handle or a RasDialFunc, RasDialFunc1, or RasDialFunc2 callback function to receive
     *            RasDial event notifications.
     *            The dwNotifierType parameter specifies the nature of lpvNotifier. Please refer to its description preceding for further detail.
     * @param lphRasConn
     *            Pointer to a variable of type HRASCONN. Set the HRASCONN variable to NULL before calling RasDial.
     *            If RasDial succeeds, it stores a handle to the RAS connection into *lphRasConn.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasDial(RASDIALEXTENSIONS.ByReference lpRasDialExtensions, String lpszPhonebook, RASDIALPARAMS.ByReference lpRasDialParams, int dwNotifierType, RasDialFunc2 lpvNotifier, HANDLEByReference lphRasConn);

    /**
     * The RasEnumConnections function lists all active RAS connections. It returns each connection's handle and phone-book entry name.
     *
     * @param lprasconn
     *            Pointer to a buffer that receives, on output, an array of RASCONN structures, one for each RAS connection.
     *            On input, an application must set the dwSize member of the first RASCONN structure in the buffer to sizeof(RASCONN)
     *            in order to identify the version of the structure being passed.
     * @param lpcb
     *            Pointer to a variable that, on input, contains the size, in bytes, of the buffer specified by lprasconn.
     *            On output, the function sets this variable to the number of bytes required to enumerate the RAS connections.
     * @param lpcConnections
     *            Pointer to a variable that receives the number of RASCONN structures written to the buffer specified by lprasconn.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasEnumConnections(RASCONN[] lprasconn, IntByReference lpcb, IntByReference lpcConnections);

    /**
     * The RasGetConnectionStatistics function retrieves accumulated connection statistics for the specified connection.
     *
     * @param hrasconn
     *            Handle to the connection. Use RasDial or RasEnumConnections to obtain this handle.
     * @param lpStatistics
     *            Pointer to the RASCONNSTATUS structure that, on output, receives the status information.
     *            On input, set the dwSize member of the structure to sizeof(RASCONNSTATUS) in order to identify the version of the structure being passed.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetConnectionStatistics(HANDLE hrasconn, RAS_STATS.ByReference lpStatistics);

    /**
     * The RasGetConnectionStatistics function retrieves accumulated connection statistics for the specified connection.
     *
     * @param hrasconn
     *            Specifies the remote access connection for which to retrieve the status. This handle must have been obtained from RasDial
     *            or RasEnumConnections.
     * @param lprasconnstatus
     *            Pointer to the RASCONNSTATUS structure that, on output, receives the status information.
     *            On input, set the dwSize member of the structure to sizeof(RASCONNSTATUS) in order to identify the version of the structure being passed.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetConnectStatus(HANDLE hrasconn, RASCONNSTATUS.ByReference lprasconnstatus);

    /**
     * The RasGetCredentials function retrieves the user credentials associated with a specified RAS phone-book entry.
     *
     * @param lpszPhonebook
     *            Pointer to a null-terminated string that specifies the full path and file name of a phone-book (PBK) file.
     *            If this parameter is NULL, the function uses the current default phone-book file. The default phone-book file is the
     *            one selected by the user in the User Preferences property sheet of the Dial-Up Networking dialog box.
     * @param lpszEntry
     *            Pointer to a null-terminated string that specifies the name of a phone-book entry.
     * @param lpCredentials
     *            Pointer to the RASCREDENTIALS structure that, on output, receives the user credentials associated with the specified
     *            phone-book entry.
     *            On input, set the dwSize member of the structure to sizeof(RASCREDENTIALS), and set the dwMask member to indicate the
     *            credential information to retrieve. When the function returns, dwMask indicates the members that were successfully retrieved.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetCredentials(String lpszPhonebook, String lpszEntry, RASCREDENTIALS.ByReference lpCredentials);

    /**
     * The RasGetEntryProperties function retrieves the properties of a phone-book entry.
     *
     * @param lpszPhonebook
     *            Pointer to a null-terminated string that specifies the full path and file name of a phone-book (PBK) file.
     *            If this parameter is NULL, the function uses the current default phone-book file.
     *            The default phone-book file is the one selected by the user in the User Preferences property sheet of the
     *            Dial-Up Networking dialog box.
     * @param lpszEntry
     *            Pointer to a null-terminated string that specifies an existing entry name.
     *            If an empty string is specified, the function returns default values in the buffers pointed to by the
     *            lpRasEntry and lpbDeviceInfo parameters.
     * @param lpRasEntry
     *            Pointer to a RASENTRY structure followed by additional bytes for the alternate phone number list, if there is one.
     * @param lpdwEntryInfoSize
     *            Pointer to a variable that, on input, specifies the size, in bytes, of the lpRasEntry buffer.
     * @param lpbDeviceInfo
     *            This parameter is no longer used. The calling function should set this parameter to NULL.
     * @param lpdwDeviceInfoSize
     *            This parameter is unused. The calling function should set this parameter to NULL.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetEntryProperties(String lpszPhonebook, String lpszEntry, RASENTRY.ByReference lpRasEntry, IntByReference lpdwEntryInfoSize, Pointer lpbDeviceInfo, Pointer lpdwDeviceInfoSize);

    /**
     * The RasGetProjectionInfo function obtains information about a remote access projection operation for a specified remote access
     * component protocol.
     *
     * @param hrasconn
     *            Handle to the remote access connection of interest. An application obtains a RAS connection handle from the RasDial
     *            or RasEnumConnections function.
     * @param rasprojection
     *            Specifies the RASPROJECTION enumerated type value that identifies the protocol of interest.
     * @param lpprojection
     *            Pointer to a buffer that receives the information specified by the rasprojection parameter. The information is in a
     *            structure appropriate to the rasprojection value.
     * @param lpcb
     *            Pointer to a variable that, on input, specifies the size, in bytes, of the buffer pointed to by lpprojection.
     *            On output, this variable receives the size, in bytes, of the lpprojection buffer.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetProjectionInfo(HANDLE hrasconn, int rasprojection, Pointer lpprojection, IntByReference lpcb);

    /**
     * The RasHangUp function terminates a remote access connection. The connection is specified with a RAS connection handle.
     * The function releases all RASAPI32.DLL resources associated with the handle.
     *
     * @param hrasconn
     *            Specifies the remote access connection to terminate. This is a handle returned from a previous call to RasDial or RasEnumConnections.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasHangUp(HANDLE hrasconn);

    /**
     * The RasSetEntryProperties function changes the connection information for an entry in the phone book or creates a new phone-book entry.
     *
     * @param lpszPhonebook
     *            Pointer to a null-terminated string that specifies the full path and file name of a phone-book (PBK) file.
     *            If this parameter is NULL, the function uses the current default phone-book file.
     *            The default phone-book file is the one selected by the user in the User Preferences property sheet of the Dial-Up
     *            Networking dialog box.
     * @param lpszEntry
     *            Pointer to a null-terminated string that specifies an entry name.
     * @param lpRasEntry
     *            Pointer to the RASENTRY structure that specifies the new connection data to be associated with the
     *            phone-book entry indicated by the lpszEntry parameter.
     * @param dwEntryInfoSize
     *            Specifies the size, in bytes, of the buffer identified by the lpRasEntry parameter.
     * @param lpbDeviceInfo
     *            Pointer to a buffer that specifies device-specific configuration information.
     *            This is opaque TAPI device configuration information. For more information about TAPI device configuration,
     *            see the lineGetDevConfig function in Telephony Application Programming Interfaces (TAPI) in the Platform SDK.
     * @param dwDeviceInfoSize
     *            Specifies the size, in bytes, of the lpbDeviceInfo buffer.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasSetEntryProperties(String lpszPhonebook, String lpszEntry, RASENTRY.ByReference lpRasEntry, int dwEntryInfoSize, byte[] lpbDeviceInfo, int dwDeviceInfoSize);

    /**
     * The RasGetEntryDialParams function retrieves the connection information saved by the last successful call to the RasDial or
     * RasSetEntryDialParams function for a specified phone-book entry.
     *
     * @param lpszPhonebook
     *           Pointer to a null-terminated string that specifies the full path and file name of a phone-book (PBK) file.
     *           If this parameter is NULL, the function uses the current default phone-book file.
     *           The default phone-book file is the one selected by the user in the User Preferences property sheet of the
     *           Dial-Up Networking dialog box.
     * @param lprasdialparams
     *            Pointer to a RASDIALPARAMS structure.
     * @param lpfPassword
     *            Pointer to a flag that indicates whether the function retrieved the password associated with the user
     *            name for the phone-book entry. The lpfPassword parameter is TRUE if the system has saved a password for
     *            the specified entry. If the system has no password saved for this entry, lpfPassword is FALSE.
     * @return If the function succeeds, the return value is ERROR_SUCCESS.
     */
    int RasGetEntryDialParams(String lpszPhonebook, RASDIALPARAMS.ByReference lprasdialparams, BOOLByReference lpfPassword);

    /**
     * The RasGetErrorString function obtains an error message string for a specified RAS error value.
     *
     * @param uErrorValue
     *           Specifies the error value of interest. These are values returned by one of the RAS functions:
     *           those listed in the RasError.h header file.
     * @param lpszErrorString
     *            Pointer to a buffer that receives the error string. This parameter must not be NULL.
     * @param cBufSize
     *            Specifies the size, in characters, of the buffer pointed to by lpszErrorString.
         * @return status
     */
    int RasGetErrorString(int uErrorValue, char[] lpszErrorString, int cBufSize);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy