diff options
| author | Phallacy <Dragoonmac@gmail.com> | 2019-02-12 02:16:03 -0800 |
|---|---|---|
| committer | Phallacy <Dragoonmac@gmail.com> | 2019-02-12 02:16:03 -0800 |
| commit | 05bbf71b6d97614888efe103f763753e4487cc2c (patch) | |
| tree | a43ea503958842d1852c19e871d995cf9a747dc1 /MediaBrowser.Model/Cryptography/PasswordHash.cs | |
| parent | 8bf88f4cb2ddb140baffd8e4542d8f528b482a67 (diff) | |
sha256 with salt auth and sha1 interop
Diffstat (limited to 'MediaBrowser.Model/Cryptography/PasswordHash.cs')
| -rw-r--r-- | MediaBrowser.Model/Cryptography/PasswordHash.cs | 37 |
1 files changed, 27 insertions, 10 deletions
diff --git a/MediaBrowser.Model/Cryptography/PasswordHash.cs b/MediaBrowser.Model/Cryptography/PasswordHash.cs index d37220ab2..524484b10 100644 --- a/MediaBrowser.Model/Cryptography/PasswordHash.cs +++ b/MediaBrowser.Model/Cryptography/PasswordHash.cs @@ -33,15 +33,15 @@ namespace MediaBrowser.Model.Cryptography if (a.Length == 4)
{
Salt = a[2];
- SaltBytes = Convert.FromBase64CharArray(Salt.ToCharArray(), 0, Salt.Length);
+ SaltBytes = FromByteString(Salt);
Hash = a[3];
- HashBytes = Convert.FromBase64CharArray(Hash.ToCharArray(), 0, Hash.Length);
+ HashBytes = FromByteString(Hash);
}
else
{
Salt = string.Empty;
Hash = a[3];
- HashBytes = Convert.FromBase64CharArray(Hash.ToCharArray(), 0, Hash.Length);
+ HashBytes = FromByteString(Hash);
}
}
else
@@ -49,15 +49,15 @@ namespace MediaBrowser.Model.Cryptography if (a.Length == 4)
{
Salt = a[2];
- SaltBytes = Convert.FromBase64CharArray(Salt.ToCharArray(), 0, Salt.Length);
+ SaltBytes = FromByteString(Salt);
Hash = a[3];
- HashBytes = Convert.FromBase64CharArray(Hash.ToCharArray(), 0, Hash.Length);
+ HashBytes = FromByteString(Hash);
}
else
{
Salt = string.Empty;
Hash = a[2];
- HashBytes = Convert.FromBase64CharArray(Hash.ToCharArray(), 0, Hash.Length);
+ HashBytes = FromByteString(Hash);
}
}
@@ -68,7 +68,17 @@ namespace MediaBrowser.Model.Cryptography {
Id = "SHA256";
SaltBytes = cryptoProvider2.GenerateSalt();
- Salt = Convert.ToBase64String(SaltBytes);
+ Salt = BitConverter.ToString(SaltBytes).Replace("-", "");
+ } + + private byte[] FromByteString(string ByteString) + { + List<byte> Bytes = new List<byte>(); + for (int i = 0; i < ByteString.Length; i += 2) + { + Bytes.Add(Convert.ToByte(ByteString.Substring(i, 2),16)); + } + return Bytes.ToArray(); }
private string SerializeParameters()
{
@@ -77,7 +87,7 @@ namespace MediaBrowser.Model.Cryptography {
ReturnString += String.Format(",{0}={1}", KVP.Key, KVP.Value);
}
- if (ReturnString[0] == ',')
+ if ((!string.IsNullOrEmpty(ReturnString)) && ReturnString[0] == ',')
{
ReturnString = ReturnString.Remove(0, 1);
}
@@ -85,8 +95,15 @@ namespace MediaBrowser.Model.Cryptography }
public override string ToString()
- {
- return String.Format("${0}${1}${2}${3}", Id, SerializeParameters(), Salt, Hash);
+ { + string OutString = "$"; + OutString += Id; + if (!string.IsNullOrEmpty(SerializeParameters())) + OutString += $"${SerializeParameters()}"; + if (!string.IsNullOrEmpty(Salt)) + OutString += $"${Salt}"; + OutString += $"${Hash}";
+ return OutString;
}
}
|
