sha512digest.bmx 2.1 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: SHA-512 Digest
  23. about:
  24. See <https://en.wikipedia.org/wiki/SHA-2>
  25. End Rem
  26. Module Crypto.SHA512Digest
  27. ModuleInfo "CC_OPTS: -DLTC_NO_TEST -DLTC_NO_FILE"
  28. Import "common.bmx"
  29. New TSHA512DigestRegister
  30. Rem
  31. bbdoc: An SHA-512 message digest.
  32. End Rem
  33. Type TSHA512 Extends TMessageDigest
  34. Method New()
  35. digestPtr = bmx_digest_SHA512_init()
  36. End Method
  37. Method OutBytes:Int() Override
  38. Return 64
  39. End Method
  40. Rem
  41. bbdoc: Updates the hash with @dataLen bytes of data.
  42. End Rem
  43. Method Update:Int(data:Byte Ptr, dataLen:Int) Override
  44. Return bmx_digest_SHA512_process(digestPtr, data, dataLen)
  45. End Method
  46. Rem
  47. bbdoc: Finishes hashing and produces the digest, filling @digest with the hashed bytes.
  48. about: The hashing state is reset, ready to create a new digest.
  49. End Rem
  50. Method Finish:Int(digest:Byte[]) Override
  51. Assert digest.length >= 64, "Byte array must be at least 64 bytes."
  52. Return bmx_digest_SHA512_done(digestPtr, digest)
  53. End Method
  54. End Type
  55. Type TSHA512DigestRegister Extends TDigestRegister
  56. Method GetDigest:TMessageDigest( name:String ) Override
  57. name = name.ToUpper()
  58. If name = "SHA512" Or name = "SHA-512" Then
  59. Return New TSHA512
  60. End If
  61. End Method
  62. Method ToString:String() Override
  63. Return "SHA-512"
  64. End Method
  65. End Type