123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- // This code is derived from jcifs smb client library <jcifs at samba dot org>
- // Ported by J. Arturo <webmaster at komodosoft dot net>
- //
- // This library is free software; you can redistribute it and/or
- // modify it under the terms of the GNU Lesser General Public
- // License as published by the Free Software Foundation; either
- // version 2.1 of the License, or (at your option) any later version.
- //
- // This library is distributed in the hope that it will be useful,
- // but WITHOUT ANY WARRANTY; without even the implied warranty of
- // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- // Lesser General Public License for more details.
- //
- // You should have received a copy of the GNU Lesser General Public
- // License along with this library; if not, write to the Free Software
- // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- using System;
- using SharpCifs.Util.Sharpen;
- namespace SharpCifs.Util
- {
- /// <summary>This is an implementation of the HMACT64 keyed hashing algorithm.</summary>
- /// <remarks>
- /// This is an implementation of the HMACT64 keyed hashing algorithm.
- /// HMACT64 is defined by Luke Leighton as a modified HMAC-MD5 (RFC 2104)
- /// in which the key is truncated at 64 bytes (rather than being hashed
- /// via MD5).
- /// </remarks>
- public class Hmact64 : MessageDigest
- {
- private const int BlockLength = 64;
- private const byte Ipad = unchecked(unchecked(0x36));
- private const byte Opad = unchecked(unchecked(0x5c));
- private MessageDigest _md5;
- private byte[] _ipad = new byte[BlockLength];
- private byte[] _opad = new byte[BlockLength];
- /// <summary>Creates an HMACT64 instance which uses the given secret key material.</summary>
- /// <remarks>Creates an HMACT64 instance which uses the given secret key material.</remarks>
- /// <param name="key">The key material to use in hashing.</param>
- public Hmact64(byte[] key)
- {
- int length = Math.Min(key.Length, BlockLength);
- for (int i = 0; i < length; i++)
- {
- _ipad[i] = unchecked((byte)(key[i] ^ Ipad));
- _opad[i] = unchecked((byte)(key[i] ^ Opad));
- }
- for (int i1 = length; i1 < BlockLength; i1++)
- {
- _ipad[i1] = Ipad;
- _opad[i1] = Opad;
- }
- try
- {
- _md5 = GetInstance("MD5");
- }
- catch (Exception ex)
- {
- throw new InvalidOperationException(ex.Message);
- }
- EngineReset();
- }
- protected byte[] EngineDigest()
- {
- byte[] digest = _md5.Digest();
- _md5.Update(_opad);
- return _md5.Digest(digest);
- }
- protected int EngineDigest(byte[] buf, int offset, int len)
- {
- byte[] digest = _md5.Digest();
- _md5.Update(_opad);
- _md5.Update(digest);
- try
- {
- _md5.Digest(buf, offset, len);
- return len;
- }
- catch (Exception)
- {
- throw new InvalidOperationException();
- }
- }
- protected int EngineGetDigestLength()
- {
- return _md5.GetDigestLength();
- }
- protected void EngineReset()
- {
- _md5.Reset();
- _md5.Update(_ipad);
- }
- protected void EngineUpdate(byte b)
- {
- _md5.Update(b);
- }
- protected void EngineUpdate(byte[] input, int offset, int len)
- {
- _md5.Update(input, offset, len);
- }
- public override byte[] Digest()
- {
- return EngineDigest();
- }
- public override int GetDigestLength()
- {
- return EngineGetDigestLength();
- }
- public override void Reset()
- {
- EngineReset();
- }
- public override void Update(byte[] b)
- {
- EngineUpdate(b, 0, b.Length);
- }
- public override void Update(byte b)
- {
- EngineUpdate(b);
- }
- public override void Update(byte[] b, int offset, int len)
- {
- EngineUpdate(b, offset, len);
- }
- }
- }
|