mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-04-24 14:08:44 -04:00
Remove Hex class as the BCL has one now
This commit is contained in:
parent
9534f55eb0
commit
8c8a71692e
12 changed files with 13 additions and 233 deletions
|
@ -647,7 +647,7 @@ namespace Emby.Server.Implementations.LiveTv.Listings
|
||||||
{
|
{
|
||||||
using var options = new HttpRequestMessage(HttpMethod.Post, ApiUrl + "/token");
|
using var options = new HttpRequestMessage(HttpMethod.Post, ApiUrl + "/token");
|
||||||
var hashedPasswordBytes = _cryptoProvider.ComputeHash("SHA1", Encoding.ASCII.GetBytes(password), Array.Empty<byte>());
|
var hashedPasswordBytes = _cryptoProvider.ComputeHash("SHA1", Encoding.ASCII.GetBytes(password), Array.Empty<byte>());
|
||||||
string hashedPassword = Hex.Encode(hashedPasswordBytes);
|
string hashedPassword = Convert.ToHexString(hashedPasswordBytes);
|
||||||
options.Content = new StringContent("{\"username\":\"" + username + "\",\"password\":\"" + hashedPassword + "\"}", Encoding.UTF8, MediaTypeNames.Application.Json);
|
options.Content = new StringContent("{\"username\":\"" + username + "\",\"password\":\"" + hashedPassword + "\"}", Encoding.UTF8, MediaTypeNames.Application.Json);
|
||||||
|
|
||||||
using var response = await Send(options, false, null, cancellationToken).ConfigureAwait(false);
|
using var response = await Send(options, false, null, cancellationToken).ConfigureAwait(false);
|
||||||
|
|
|
@ -243,7 +243,7 @@ namespace Emby.Server.Implementations.QuickConnect
|
||||||
Span<byte> bytes = stackalloc byte[length];
|
Span<byte> bytes = stackalloc byte[length];
|
||||||
_rng.GetBytes(bytes);
|
_rng.GetBytes(bytes);
|
||||||
|
|
||||||
return Hex.Encode(bytes);
|
return Convert.ToHexString(bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
|
|
|
@ -414,7 +414,7 @@ namespace Emby.Server.Implementations.Updates
|
||||||
using var md5 = MD5.Create();
|
using var md5 = MD5.Create();
|
||||||
cancellationToken.ThrowIfCancellationRequested();
|
cancellationToken.ThrowIfCancellationRequested();
|
||||||
|
|
||||||
var hash = Hex.Encode(md5.ComputeHash(stream));
|
var hash = Convert.ToHexString(md5.ComputeHash(stream));
|
||||||
if (!string.Equals(package.Checksum, hash, StringComparison.OrdinalIgnoreCase))
|
if (!string.Equals(package.Checksum, hash, StringComparison.OrdinalIgnoreCase))
|
||||||
{
|
{
|
||||||
_logger.LogError(
|
_logger.LogError(
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.ComponentModel.DataAnnotations;
|
using System.ComponentModel.DataAnnotations;
|
||||||
using System.Diagnostics.CodeAnalysis;
|
using System.Diagnostics.CodeAnalysis;
|
||||||
|
@ -17,7 +17,6 @@ using Jellyfin.Api.Helpers;
|
||||||
using Jellyfin.Api.ModelBinders;
|
using Jellyfin.Api.ModelBinders;
|
||||||
using Jellyfin.Api.Models.LiveTvDtos;
|
using Jellyfin.Api.Models.LiveTvDtos;
|
||||||
using Jellyfin.Data.Enums;
|
using Jellyfin.Data.Enums;
|
||||||
using MediaBrowser.Common;
|
|
||||||
using MediaBrowser.Common.Configuration;
|
using MediaBrowser.Common.Configuration;
|
||||||
using MediaBrowser.Common.Net;
|
using MediaBrowser.Common.Net;
|
||||||
using MediaBrowser.Controller.Dto;
|
using MediaBrowser.Controller.Dto;
|
||||||
|
@ -1015,7 +1014,7 @@ namespace Jellyfin.Api.Controllers
|
||||||
if (!string.IsNullOrEmpty(pw))
|
if (!string.IsNullOrEmpty(pw))
|
||||||
{
|
{
|
||||||
using var sha = SHA1.Create();
|
using var sha = SHA1.Create();
|
||||||
listingsProviderInfo.Password = Hex.Encode(sha.ComputeHash(Encoding.UTF8.GetBytes(pw)));
|
listingsProviderInfo.Password = Convert.ToHexString(sha.ComputeHash(Encoding.UTF8.GetBytes(pw)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return await _liveTvManager.SaveListingProvider(listingsProviderInfo, validateLogin, validateListings).ConfigureAwait(false);
|
return await _liveTvManager.SaveListingProvider(listingsProviderInfo, validateLogin, validateListings).ConfigureAwait(false);
|
||||||
|
|
|
@ -101,13 +101,13 @@ namespace MediaBrowser.Common.Cryptography
|
||||||
// Check if the string also contains a salt
|
// Check if the string also contains a salt
|
||||||
if (splitted.Length - index == 2)
|
if (splitted.Length - index == 2)
|
||||||
{
|
{
|
||||||
salt = Hex.Decode(splitted[index++]);
|
salt = Convert.FromHexString(splitted[index++]);
|
||||||
hash = Hex.Decode(splitted[index++]);
|
hash = Convert.FromHexString(splitted[index++]);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
salt = Array.Empty<byte>();
|
salt = Array.Empty<byte>();
|
||||||
hash = Hex.Decode(splitted[index++]);
|
hash = Convert.FromHexString(splitted[index++]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new PasswordHash(id, hash, salt, parameters);
|
return new PasswordHash(id, hash, salt, parameters);
|
||||||
|
@ -144,11 +144,11 @@ namespace MediaBrowser.Common.Cryptography
|
||||||
if (_salt.Length != 0)
|
if (_salt.Length != 0)
|
||||||
{
|
{
|
||||||
str.Append('$')
|
str.Append('$')
|
||||||
.Append(Hex.Encode(_salt, false));
|
.Append(Convert.ToHexString(_salt));
|
||||||
}
|
}
|
||||||
|
|
||||||
return str.Append('$')
|
return str.Append('$')
|
||||||
.Append(Hex.Encode(_hash, false)).ToString();
|
.Append(Convert.ToHexString(_hash)).ToString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,94 +0,0 @@
|
||||||
using System;
|
|
||||||
using System.Diagnostics.CodeAnalysis;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Common
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Encoding and decoding hex strings.
|
|
||||||
/// </summary>
|
|
||||||
public static class Hex
|
|
||||||
{
|
|
||||||
internal const string HexCharsLower = "0123456789abcdef";
|
|
||||||
internal const string HexCharsUpper = "0123456789ABCDEF";
|
|
||||||
|
|
||||||
internal const int LastHexSymbol = 0x66; // 102: f
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Gets a map from an ASCII char to its hex value shifted,
|
|
||||||
/// e.g. <c>b</c> -> 11. 0xFF means it's not a hex symbol.
|
|
||||||
/// </summary>
|
|
||||||
internal static ReadOnlySpan<byte> HexLookup => new byte[]
|
|
||||||
{
|
|
||||||
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0xFF, 0x0A, 0x0B, 0x0C, 0x0D, 0x0E, 0x0F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
|
|
||||||
0xFF, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f
|
|
||||||
};
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Encodes each element of the specified bytes as its hexadecimal string representation.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="bytes">An array of bytes.</param>
|
|
||||||
/// <param name="lowercase"><c>true</c> to use lowercase hexadecimal characters; otherwise <c>false</c>.</param>
|
|
||||||
/// <returns><c>bytes</c> as a hex string.</returns>
|
|
||||||
public static string Encode(ReadOnlySpan<byte> bytes, bool lowercase = true)
|
|
||||||
{
|
|
||||||
var hexChars = lowercase ? HexCharsLower : HexCharsUpper;
|
|
||||||
|
|
||||||
// TODO: use string.Create when it's supports spans
|
|
||||||
// Ref: https://github.com/dotnet/corefx/issues/29120
|
|
||||||
char[] s = new char[bytes.Length * 2];
|
|
||||||
int j = 0;
|
|
||||||
for (int i = 0; i < bytes.Length; i++)
|
|
||||||
{
|
|
||||||
s[j++] = hexChars[bytes[i] >> 4];
|
|
||||||
s[j++] = hexChars[bytes[i] & 0x0f];
|
|
||||||
}
|
|
||||||
|
|
||||||
return new string(s);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Decodes a hex string into bytes.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="str">The <see cref="string" />.</param>
|
|
||||||
/// <returns>The decoded bytes.</returns>
|
|
||||||
public static byte[] Decode(ReadOnlySpan<char> str)
|
|
||||||
{
|
|
||||||
if (str.Length == 0)
|
|
||||||
{
|
|
||||||
return Array.Empty<byte>();
|
|
||||||
}
|
|
||||||
|
|
||||||
var unHex = HexLookup;
|
|
||||||
|
|
||||||
int byteLen = str.Length / 2;
|
|
||||||
byte[] bytes = new byte[byteLen];
|
|
||||||
int i = 0;
|
|
||||||
for (int j = 0; j < byteLen; j++)
|
|
||||||
{
|
|
||||||
byte a;
|
|
||||||
byte b;
|
|
||||||
if (str[i] > LastHexSymbol
|
|
||||||
|| (a = unHex[str[i++]]) == 0xFF
|
|
||||||
|| str[i] > LastHexSymbol
|
|
||||||
|| (b = unHex[str[i++]]) == 0xFF)
|
|
||||||
{
|
|
||||||
ThrowArgumentException(nameof(str));
|
|
||||||
break; // Unreachable
|
|
||||||
}
|
|
||||||
|
|
||||||
bytes[j] = (byte)((a * 16) | b);
|
|
||||||
}
|
|
||||||
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
[DoesNotReturn]
|
|
||||||
private static void ThrowArgumentException(string paramName)
|
|
||||||
=> throw new ArgumentException("Character is not a hex symbol.", paramName);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
using System;
|
|
||||||
using System.Globalization;
|
|
||||||
using BenchmarkDotNet.Attributes;
|
|
||||||
using BenchmarkDotNet.Running;
|
|
||||||
using MediaBrowser.Common;
|
|
||||||
|
|
||||||
namespace Jellyfin.Common.Benches
|
|
||||||
{
|
|
||||||
[MemoryDiagnoser]
|
|
||||||
public class HexDecodeBenches
|
|
||||||
{
|
|
||||||
private string _data;
|
|
||||||
|
|
||||||
[Params(0, 10, 100, 1000, 10000, 1000000)]
|
|
||||||
public int N { get; set; }
|
|
||||||
|
|
||||||
[GlobalSetup]
|
|
||||||
public void GlobalSetup()
|
|
||||||
{
|
|
||||||
var bytes = new byte[N];
|
|
||||||
new Random(42).NextBytes(bytes);
|
|
||||||
_data = Hex.Encode(bytes);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Benchmark]
|
|
||||||
public byte[] Decode() => Hex.Decode(_data);
|
|
||||||
|
|
||||||
[Benchmark]
|
|
||||||
public byte[] DecodeSubString() => DecodeSubString(_data);
|
|
||||||
|
|
||||||
private static byte[] DecodeSubString(string str)
|
|
||||||
{
|
|
||||||
byte[] bytes = new byte[str.Length / 2];
|
|
||||||
for (int i = 0; i < str.Length; i += 2)
|
|
||||||
{
|
|
||||||
bytes[i / 2] = byte.Parse(
|
|
||||||
str.Substring(i, 2),
|
|
||||||
NumberStyles.HexNumber,
|
|
||||||
CultureInfo.InvariantCulture);
|
|
||||||
}
|
|
||||||
|
|
||||||
return bytes;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,32 +0,0 @@
|
||||||
using System;
|
|
||||||
using BenchmarkDotNet.Attributes;
|
|
||||||
using BenchmarkDotNet.Running;
|
|
||||||
using MediaBrowser.Common;
|
|
||||||
|
|
||||||
namespace Jellyfin.Common.Benches
|
|
||||||
{
|
|
||||||
[MemoryDiagnoser]
|
|
||||||
public class HexEncodeBenches
|
|
||||||
{
|
|
||||||
private byte[] _data;
|
|
||||||
|
|
||||||
[Params(0, 10, 100, 1000, 10000, 1000000)]
|
|
||||||
public int N { get; set; }
|
|
||||||
|
|
||||||
[GlobalSetup]
|
|
||||||
public void GlobalSetup()
|
|
||||||
{
|
|
||||||
_data = new byte[N];
|
|
||||||
new Random(42).NextBytes(_data);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Benchmark]
|
|
||||||
public string HexEncode() => Hex.Encode(_data);
|
|
||||||
|
|
||||||
[Benchmark]
|
|
||||||
public string BitConverterToString() => BitConverter.ToString(_data);
|
|
||||||
|
|
||||||
[Benchmark]
|
|
||||||
public string BitConverterToStringWithReplace() => BitConverter.ToString(_data).Replace("-", "");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,16 +0,0 @@
|
||||||
<Project Sdk="Microsoft.NET.Sdk">
|
|
||||||
|
|
||||||
<PropertyGroup>
|
|
||||||
<OutputType>Exe</OutputType>
|
|
||||||
<TargetFramework>net5.0</TargetFramework>
|
|
||||||
</PropertyGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<PackageReference Include="BenchmarkDotNet" Version="0.12.0" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
<ItemGroup>
|
|
||||||
<ProjectReference Include="../../MediaBrowser.Common/MediaBrowser.Common.csproj" />
|
|
||||||
</ItemGroup>
|
|
||||||
|
|
||||||
</Project>
|
|
|
@ -1,14 +0,0 @@
|
||||||
using System;
|
|
||||||
using BenchmarkDotNet.Running;
|
|
||||||
|
|
||||||
namespace Jellyfin.Common.Benches
|
|
||||||
{
|
|
||||||
public static class Program
|
|
||||||
{
|
|
||||||
public static void Main(string[] args)
|
|
||||||
{
|
|
||||||
_ = BenchmarkRunner.Run<HexEncodeBenches>();
|
|
||||||
_ = BenchmarkRunner.Run<HexDecodeBenches>();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,19 +0,0 @@
|
||||||
using MediaBrowser.Common;
|
|
||||||
using Xunit;
|
|
||||||
|
|
||||||
namespace Jellyfin.Common.Tests
|
|
||||||
{
|
|
||||||
public class HexTests
|
|
||||||
{
|
|
||||||
[Theory]
|
|
||||||
[InlineData("")]
|
|
||||||
[InlineData("00")]
|
|
||||||
[InlineData("01")]
|
|
||||||
[InlineData("000102030405060708090a0b0c0d0e0f")]
|
|
||||||
[InlineData("0123456789abcdef")]
|
|
||||||
public void RoundTripTest(string data)
|
|
||||||
{
|
|
||||||
Assert.Equal(data, Hex.Encode(Hex.Decode(data)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
using System;
|
||||||
using MediaBrowser.Common;
|
using MediaBrowser.Common;
|
||||||
using MediaBrowser.Common.Cryptography;
|
using MediaBrowser.Common.Cryptography;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
@ -16,8 +17,8 @@ namespace Jellyfin.Common.Tests
|
||||||
{
|
{
|
||||||
var pass = PasswordHash.Parse(passwordHash);
|
var pass = PasswordHash.Parse(passwordHash);
|
||||||
Assert.Equal(id, pass.Id);
|
Assert.Equal(id, pass.Id);
|
||||||
Assert.Equal(salt, Hex.Encode(pass.Salt, false));
|
Assert.Equal(salt, Convert.ToHexString(pass.Salt));
|
||||||
Assert.Equal(hash, Hex.Encode(pass.Hash, false));
|
Assert.Equal(hash, Convert.ToHexString(pass.Hash));
|
||||||
}
|
}
|
||||||
|
|
||||||
[Theory]
|
[Theory]
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue