9d2c55f147ed499888b812a7177dd8fb60c2f8c7
[NovacoinLibrary.git] / Novacoin / RIPEMD160.cs
1 \feff/**
2  *  Novacoin classes library
3  *  Copyright (C) 2015 Alex D. (balthazar.ad@gmail.com)
4
5  *  This program is free software: you can redistribute it and/or modify
6  *  it under the terms of the GNU Affero General Public License as
7  *  published by the Free Software Foundation, either version 3 of the
8  *  License, or (at your option) any later version.
9
10  *  This program is distributed in the hope that it will be useful,
11  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  *  GNU Affero General Public License for more details.
14
15  *  You should have received a copy of the GNU Affero General Public License
16  *  along with this program.  If not, see <http://www.gnu.org/licenses/>.
17  */
18
19 using Org.BouncyCastle.Crypto.Digests;
20
21 namespace Novacoin
22 {
23     /// <summary>
24     /// Representation of RIPEMD-160 hash.
25     /// </summary>
26     public class RIPEMD160 : Hash
27     {
28         /// <summary>
29         /// Computes RIPEMD160 hash using managed library
30         /// </summary>
31         // private static readonly RIPEMD160Managed _hasher160 = new RIPEMD160Managed();
32         private static RipeMD160Digest _hasher160 = new RipeMD160Digest();
33         
34         // 20 bytes
35         public override int hashSize
36         {
37             get { return _hasher160.GetDigestSize(); }
38         }
39
40         public RIPEMD160() : base() { }
41         public RIPEMD160(byte[] bytes, int offset = 0) : base(bytes, offset) { }
42         public RIPEMD160(RIPEMD160 h) : base(h) { }
43
44         public static RIPEMD160 Compute160(byte[] inputBytes)
45         {
46             var digest1 = new byte[_hasher160.GetDigestSize()];
47             _hasher160.BlockUpdate(inputBytes, 0, inputBytes.Length);
48             _hasher160.DoFinal(digest1, 0);
49
50             return new RIPEMD160(digest1);
51         }
52     }
53 }
54