SYSLIB0030: HMACSHA1 always uses the algorithm implementation provided by the platform

The HMACSHA1(Byte[], Boolean) constructor is marked as obsolete, starting in .NET 6. Using this API in code generates warning SYSLIB0030 at compile time.

Workarounds

Use a constructor without the useManagedSha1 parameter.

Suppress a warning

If you must use the obsolete APIs, you can suppress the warning in code or in your project file.

To suppress only a single violation, add preprocessor directives to your source file to disable and then re-enable the warning.

// Disable the warning.
#pragma warning disable SYSLIB0030

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0030

To suppress all the SYSLIB0030 warnings in your project, add a <NoWarn> property to your project file.

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0030</NoWarn>
  </PropertyGroup>
</Project>

For more information, see Suppress warnings.