|
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
using System.Security.Cryptography;
namespace Microsoft.NET.Build.Containers;
internal sealed class DigestUtils
{
/// <summary>
/// Gets digest for string <paramref name="str"/>.
/// </summary>
internal static string GetDigest(string str) => GetDigestFromSha(GetSha(str));
/// <summary>
/// Formats digest based on ready SHA <paramref name="sha"/>.
/// </summary>
internal static string GetDigestFromSha(string sha) => $"sha256:{sha}";
internal static string GetShaFromDigest(string digest)
{
if (!digest.StartsWith("sha256:", StringComparison.OrdinalIgnoreCase))
{
throw new ArgumentException($"Invalid digest '{digest}'. Digest must start with 'sha256:'.");
}
return digest.Substring("sha256:".Length);
}
/// <summary>
/// Gets the SHA of <paramref name="str"/>.
/// </summary>
internal static string GetSha(string str)
{
Span<byte> hash = stackalloc byte[SHA256.HashSizeInBytes];
SHA256.HashData(Encoding.UTF8.GetBytes(str), hash);
return Convert.ToHexStringLower(hash);
}
}
|