summary refs log tree commit diff
path: root/crypto/src/tls/CombinedHash.cs
blob: 360b9d426f5739dc28226010961541e9c914ff25 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
using System;

using Org.BouncyCastle.Tls.Crypto;
using Org.BouncyCastle.Utilities;

namespace Org.BouncyCastle.Tls
{
    /// <summary>A combined hash, which implements md5(m) || sha1(m).</summary>
    public class CombinedHash
        : TlsHash
    {
        protected readonly TlsContext m_context;
        protected readonly TlsCrypto m_crypto;
        protected readonly TlsHash m_md5;
        protected readonly TlsHash m_sha1;

        internal CombinedHash(TlsContext context, TlsHash md5, TlsHash sha1)
        {
            this.m_context = context;
            this.m_crypto = context.Crypto;
            this.m_md5 = md5;
            this.m_sha1 = sha1;
        }

        public CombinedHash(TlsCrypto crypto)
        {
            this.m_crypto = crypto;
            this.m_md5 = crypto.CreateHash(CryptoHashAlgorithm.md5);
            this.m_sha1 = crypto.CreateHash(CryptoHashAlgorithm.sha1);
        }

        public CombinedHash(CombinedHash t)
        {
            this.m_context = t.m_context;
            this.m_crypto = t.m_crypto;
            this.m_md5 = t.m_md5.CloneHash();
            this.m_sha1 = t.m_sha1.CloneHash();
        }

        public virtual void Update(byte[] input, int inOff, int len)
        {
            m_md5.Update(input, inOff, len);
            m_sha1.Update(input, inOff, len);
        }

#if NETCOREAPP2_1_OR_GREATER || NETSTANDARD2_1_OR_GREATER
        public void Update(ReadOnlySpan<byte> input)
        {
            m_md5.Update(input);
            m_sha1.Update(input);
        }
#endif

        public virtual byte[] CalculateHash()
        {
            if (null != m_context && TlsUtilities.IsSsl(m_context))
            {
                Ssl3Utilities.CompleteCombinedHash(m_context, m_md5, m_sha1);
            }

            return Arrays.Concatenate(m_md5.CalculateHash(), m_sha1.CalculateHash());
        }

        public virtual TlsHash CloneHash()
        {
            return new CombinedHash(this);
        }

        public virtual void Reset()
        {
            m_md5.Reset();
            m_sha1.Reset();
        }
    }
}