duplicati/Duplicati/Library/Utility/HashFactory.cs
Kenneth Skovhede 9464caf622
Feature/update license 2025 (#5851)
* Fixed some minor whitespace issues

* Updated all copyright to 2025
2025-01-07 09:40:39 +01:00

83 lines
3 KiB
C#

// Copyright (C) 2025, The Duplicati Team
// https://duplicati.com, hello@duplicati.com
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
using System;
using System.Collections.Generic;
using Crypto = System.Security.Cryptography;
using System.Text;
namespace Duplicati.Library.Utility
{
public static class HashFactory
{
public const string MD5 = "MD5";
public const string SHA1 = "SHA1";
public const string SHA256 = "SHA256";
public const string SHA384 = "SHA384";
public const string SHA512 = "SHA512";
public static string[] GetSupportedHashes()
{
var r = new List<string>();
foreach (var h in new string[] { "SHA1", "MD5", "SHA256", "SHA384", "SHA512" })
{
try
{
using (var p = CreateHasher(h)) {
if (p != null)
r.Add(h);
}
}
catch
{
}
}
return r.ToArray();
}
public static Crypto.HashAlgorithm CreateHasher(string algorithm)
{
switch (algorithm.ToUpperInvariant())
{
case "MD5":
return Crypto.MD5.Create();
case "SHA1":
return Crypto.SHA1.Create();
case "SHA256":
return Crypto.SHA256.Create();
case "SHA384":
return Crypto.SHA384.Create();
case "SHA512":
return Crypto.SHA512.Create();
default:
throw new ArgumentException("Unknown algorithm: " + algorithm, nameof(algorithm));
}
}
public static int HashSizeBytes(string algorithm)
{
using (var hasher = CreateHasher(algorithm))
{
return hasher.HashSize / 8;
}
}
}
}