Nefarius.Drivers.HidHide 2.0.0-pre1

Prefix Reserved
This is a prerelease version of Nefarius.Drivers.HidHide.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Nefarius.Drivers.HidHide --version 2.0.0-pre1                
NuGet\Install-Package Nefarius.Drivers.HidHide -Version 2.0.0-pre1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Nefarius.Drivers.HidHide" Version="2.0.0-pre1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Nefarius.Drivers.HidHide --version 2.0.0-pre1                
#r "nuget: Nefarius.Drivers.HidHide, 2.0.0-pre1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Nefarius.Drivers.HidHide as a Cake Addin
#addin nuget:?package=Nefarius.Drivers.HidHide&version=2.0.0-pre1&prerelease

// Install Nefarius.Drivers.HidHide as a Cake Tool
#tool nuget:?package=Nefarius.Drivers.HidHide&version=2.0.0-pre1&prerelease                

<img src="assets/NSS-128x128.png" align="left" />Nefarius.Drivers.HidHide

.NET Requirements Requirements Nuget Nuget

Managed API for configuring HidHide.

Usage

Create an instance of HidHideControlService whenever you need it.

You can use it as a singleton with dependency injection as well.

This class will not block other configuration apps so you can keep it in memory as long as you need. A handle to the driver is only opened when necessary (when the properties are read from or the methods get invoked).

The following methods and properties are available:

/// <summary>
///     Provides a managed wrapper for communicating with HidHide driver.
/// </summary>
public interface IHidHideControlService
{
    /// <summary>
    ///     Gets or sets whether global device hiding is currently active or not.
    /// </summary>
    bool IsActive { get; set; }
    
    /// <summary>
    ///     Gets whether the driver is present and operable.
    /// </summary>
    bool IsInstalled { get; }

    /// <summary>
    ///     Gets or sets whether the application list is inverted (from block all/allow specific to allow all/block specific).
    /// </summary>
    /// <remarks>
    ///     The default behaviour of the application list is to block all processes by default and only treat listed paths
    ///     as exempted.
    /// </remarks>
    bool IsAppListInverted { get; set; }

    /// <summary>
    ///     Returns list of currently blocked instance IDs.
    /// </summary>
    IReadOnlyList<string> BlockedInstanceIds { get; }

    /// <summary>
    ///     Returns list of currently allowed (or blocked, see <see cref="IsAppListInverted" />) application paths.
    /// </summary>
    IReadOnlyList<string> ApplicationPaths { get; }

    /// <summary>
    ///     Submit a new instance to block.
    /// </summary>
    /// <remarks>
    ///     To get the instance ID from e.g. a symbolic link (device path) you can use this companion library:
    ///     https://github.com/nefarius/Nefarius.Utilities.DeviceManagement
    /// </remarks>
    /// <param name="instanceId">The Instance ID to block.</param>
    void AddBlockedInstanceId(string instanceId);

    /// <summary>
    ///     Remove an instance from being blocked.
    /// </summary>
    /// <remarks>
    ///     To get the instance ID from e.g. a symbolic link (device path) you can use this companion library:
    ///     https://github.com/nefarius/Nefarius.Utilities.DeviceManagement
    /// </remarks>
    /// <param name="instanceId">The Instance ID to unblock.</param>
    void RemoveBlockedInstanceId(string instanceId);

    /// <summary>
    ///     Empties the device instances list. Useful if <see cref="AddBlockedInstanceId" /> or
    ///     <see cref="BlockedInstanceIds" /> throw exceptions due to nonexistent entries.
    /// </summary>
    /// <remarks>
    ///     Be very conservative in using this call, you might accidentally undo settings different apps have put in
    ///     place.
    /// </remarks>
    void ClearBlockedInstancesList();

    /// <summary>
    ///     Submit a new application to allow (or deny if inverse flag is set).
    /// </summary>
    /// <remarks>Use the common local path notation (e.g. "C:\Windows\System32\rundll32.exe").</remarks>
    /// <param name="path">The absolute application path to allow.</param>
    void AddApplicationPath(string path);

    /// <summary>
    ///     Revokes an applications exemption.
    /// </summary>
    /// <remarks>Use the common local path notation (e.g. "C:\Windows\System32\rundll32.exe").</remarks>
    /// <param name="path">The absolute application path to revoke.</param>
    void RemoveApplicationPath(string path);

    /// <summary>
    ///     Empties the application list. Useful if <see cref="AddApplicationPath" /> or <see cref="ApplicationPaths" /> throw
    ///     exceptions due to nonexistent entries.
    /// </summary>
    /// <remarks>
    ///     Be very conservative in using this call, you might accidentally undo settings different apps have put in
    ///     place.
    /// </remarks>
    void ClearApplicationsList();
}

3rd party sources

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net6.0-windows7.0 is compatible.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net7.0-windows7.0 is compatible.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net8.0-windows7.0 is compatible. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (6)

Showing the top 5 popular GitHub repositories that depend on Nefarius.Drivers.HidHide:

Repository Stars
Valkirie/HandheldCompanion
ControllerService
CircumSpector/DS4Windows
A reimagination of DS4Windows.
project-sbc/Handheld-Control-Panel
nefarius/Legacinator
The one and only Legacinator
JamesCJ60/Universal-x86-Tuning-Utility-Handheld
Unlock the full potential of your Intel/AMD based handheld.
Version Downloads Last updated
2.4.1 952 10/1/2024
2.4.0 114 9/30/2024
2.3.0 294 9/17/2024
2.3.0-pre002 99 9/16/2024
2.3.0-pre001 87 9/16/2024
2.2.0 525 7/6/2024
2.1.0 157 6/23/2024
2.0.0 111 6/22/2024
2.0.0-pre9 94 6/21/2024
2.0.0-pre8 90 6/21/2024
2.0.0-pre7 96 6/21/2024
2.0.0-pre6 96 6/21/2024
2.0.0-pre5 85 6/21/2024
2.0.0-pre4 88 6/21/2024
2.0.0-pre3 94 6/21/2024
2.0.0-pre2 96 6/21/2024
2.0.0-pre10 63 6/21/2024
2.0.0-pre1 114 6/18/2024
2.0.0-pre001 74 6/21/2024
1.12.2 2,099 11/17/2023
1.12.1 117 11/17/2023
1.12.0 119 11/17/2023
1.11.0 245 10/18/2023
1.10.1 166 10/12/2023
1.10.0 137 10/12/2023
1.9.2 207 9/26/2023
1.9.1 136 9/21/2023
1.9.0-tags-v1-9-0-pre.1 71 9/21/2023 1.9.0-tags-v1-9-0-pre.1 is deprecated.
1.8.60 2,466 3/7/2023
1.8.59 220 3/7/2023
1.8.56 207 3/7/2023
1.8.54 832 11/14/2022
1.6.51 367 11/2/2022
1.6.49 344 11/2/2022
1.6.46 329 11/2/2022
1.6.44 341 11/2/2022
1.6.38 403 10/26/2022
1.5.35 364 10/26/2022
1.4.31 381 10/25/2022
1.3.26 407 10/23/2022
1.2.23 390 10/23/2022
1.2.21 393 10/23/2022
1.1.16 412 10/22/2022
1.1.12 391 10/22/2022
1.1.11 385 10/22/2022
1.0.9 412 10/22/2022
1.0.7 398 10/22/2022
1.0.5 403 10/22/2022
1.0.3 390 10/22/2022