whirlpooldigest.bmx 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. '
  2. ' Copyright (C) 2019-2022 Bruce A Henderson
  3. '
  4. ' This software is provided 'as-is', without any express or implied
  5. ' warranty. In no event will the authors be held liable for any damages
  6. ' arising from the use of this software.
  7. '
  8. ' Permission is granted to anyone to use this software for any purpose,
  9. ' including commercial applications, and to alter it and redistribute it
  10. ' freely, subject to the following restrictions:
  11. '
  12. ' 1. The origin of this software must not be misrepresented; you must not
  13. ' claim that you wrote the original software. If you use this software
  14. ' in a product, an acknowledgment in the product documentation would be
  15. ' appreciated but is not required.
  16. ' 2. Altered source versions must be plainly marked as such, and must not be
  17. ' misrepresented as being the original software.
  18. ' 3. This notice may not be removed or altered from any source distribution.
  19. '
  20. SuperStrict
  21. Rem
  22. bbdoc: WHILRPOOL Digest
  23. about:
  24. See <https://en.wikipedia.org/wiki/Whirlpool_(hash_function)>
  25. End Rem
  26. Module Crypto.WhirlpoolDigest
  27. ModuleInfo "CC_OPTS: -DLTC_NO_TEST -DLTC_NO_FILE"
  28. ModuleInfo "CC_OPTS: -DLTC_WHIRLPOOL"
  29. Import "common.bmx"
  30. New TWhirlpoolDigestRegister
  31. Rem
  32. bbdoc: A WHIRPOOL message digest.
  33. End Rem
  34. Type TWhirlpool Extends TMessageDigest
  35. Method New()
  36. digestPtr = bmx_digest_whirlpool_init()
  37. End Method
  38. Method OutBytes:Int() Override
  39. Return 64
  40. End Method
  41. Rem
  42. bbdoc: Updates the hash with @dataLen bytes of data.
  43. End Rem
  44. Method Update:Int(data:Byte Ptr, dataLen:Int) Override
  45. Return bmx_digest_whirlpool_process(digestPtr, data, dataLen)
  46. End Method
  47. Rem
  48. bbdoc: Finishes hashing and produces the digest, filling @digest with the hashed bytes.
  49. about: The hashing state is reset, ready to create a new digest.
  50. End Rem
  51. Method Finish:Int(digest:Byte[]) Override
  52. Assert digest.length >= 64, "Byte array must be at least 16 bytes."
  53. Return bmx_digest_whirlpool_done(digestPtr, digest)
  54. End Method
  55. End Type
  56. Type TWhirlpoolDigestRegister Extends TDigestRegister
  57. Method GetDigest:TMessageDigest( name:String ) Override
  58. If name.ToUpper() = "WHIRLPOOL" Then
  59. Return New TWhirlpool
  60. End If
  61. End Method
  62. Method ToString:String() Override
  63. Return "WHIRLPOOL"
  64. End Method
  65. End Type