Show / Hide Table of Contents

Sha256Creator Property

Sha256Creator

This property is a delegate (function pointer). The method loaded will return an instance of SHA256.

C#
public static Func<SHA256> Sha256Creator { get; set; }

Property Value

Type Description
Func<SHA256>

Remarks

When an SDK operation needs to digest data using SHA-256, it will do so using an implementation of the System.Security.Cryptography.SHA256 abstract class. However, when it needs the SHA256 class, it will ask this delegate to build an object, rather than ask for an object itself. This has to do with the fact that the SHA256 class implements IDisposable. In order to avoid the complex problem of ownership of an object that will be disposed once it goes out of scope, the SDK will create a new object each time one is needed. This new object will be in scope only for the duration of its use in the SDK, and will be disposed immediately when the SDK is done with it.

The method loaded will return an object. This class is initialized with a method that will build and return an instance of the C# default implementation. For example, it could be used as follows.

SHA256 sha256Object = CryptographyProviders.Sha256Creator();

If you want to replace the implementation, you will likely do something like this in your application.

CryptographyProviders.Sha256Creator = () =>
{
    Handle sha256Handle = Sha256Impl.GetSha256Handle();
    return Sha256Impl.GetSha256Object(sha256Handle);
};
In This Article
  • Remarks
Back to top Generated by DocFX