package digestif

  1. Overview
  2. Docs
Hashes implementations (SHA*, RIPEMD160, BLAKE2* and MD5)

Install

dune-project
 Dependency

Authors

Maintainers

Sources

digestif-1.3.0.tbz
sha256=9a6cdcb332539c87f4723fc3bd73626b2675a7b1161fdf0fed309186ce18f427
sha512=986d98eeb79f75ff69842a7ed4b93b4ff3795df7c09d455ca0c41408d67415a6743253a96c7e0de653dc62db95cb1fd29b1c654472fa11259cddde65dd5dd352

Description

Digestif is a toolbox to provide hashes implementations in C and OCaml.

It uses the linking trick and user can decide at the end to use the C implementation or the OCaml implementation.

We provides implementation of:

  • MD5
  • SHA1
  • SHA224
  • SHA256
  • SHA384
  • SHA512
  • SHA3
  • Keccak-256
  • WHIRLPOOL
  • BLAKE2B
  • BLAKE2S
  • RIPEMD160

Published: 17 Apr 2025

README

Digestif - Hash algorithms in C and OCaml

Digestif is a toolbox which implements hashes:

  • MD5
  • SHA1
  • SHA2
  • SHA3
  • WHIRLPOOL
  • BLAKE2B
  • BLAKE2S
  • RIPEMD160

Digestif uses a trick about linking and let the end-user to choose which implementation he wants to use. We provide 2 implementations:

  • C implementation with digestif.c
  • OCaml implementation with digestif.ocaml

Both are well-tested. However, OCaml implementation is slower than the C implementation.

Note: The linking trick requires digestif.c or digestif.ocaml to be the first of your dependencies.

Documentation: https://mirage.github.io/digestif/

Contact: Romain Calascibetta <romain.calascibet ta@gmail.com>

Install & Usage

The library is available on OPAM. You can install it via:

$ opam install digestif

This is a simple program which implements sha1sum:

$ cat >sha1sum.ml <<EOF
let sum ic =
  let tmp = Bytes.create 0x1000 in
  let rec go ctx = match input ic tmp 0 0x1000 with
    | 0 -> Digestif.SHA1.get ctx
    | len ->
      let ctx = Digestif.SHA1.feed_bytes ctx ~off:0 ~len tmp in
      go ctx
    | exception End_of_file -> Digestif.SHA1.get ctx in
  go Digestif.SHA1.empty

let () = match Sys.argv with
  | [| _; filename; |] when Sys.file_exists filename ->
    let ic = open_in filename in
    let hash = sum ic in
    close_in ic ; print_endline (Digestif.SHA1.to_hex hash)
  | [| _ |] ->
    let hash = sum stdin in
    print_endline (Digestif.SHA1.to_hex hash)
  | _ -> Format.eprintf "%s [<filename>]\n%!" Sys.argv.(0)
EOF
$ cat >dune <<EOF
(executable
 (name sha1sum)
 (libraries digestif))
EOF
$ dune exec ./sha1sum.exe -- sha1sum.ml
fe6e6639a817c23857b507e2d833ec776f23f327

API

For each hash, we implement the same API which is referentially transparent. Then, on the top of these, we reflect functions (like digesti or hmaci) with GADT - however, conversion from GADT to hash type is not possible (but you can destruct GADT with to_raw_string).

Equal/Compare function

We deciced to protect users to timing-attack. In this case, Digestif.equal (by eqaf package) compares hashes in constant-time.

However, we provide unsafe_compare function too which is not a constant time function. In some contexts, like ocaml-git, we don't care about timing attack and we use unsafe_compare - then, we need to make a wrap where we rename unsafe_compare to compare to be able to use it in some functors like Map.Make or Set.Make.

It's little annoying to do that but it forces the user to get the right question about security issues. So, please, don't ask to rename this function.

MirageOS

Of course, this package is available to be used on MirageOS (both implementations). User is able to compile digestif.ocaml with js_of_ocaml and this package is platform agnostic.

Build Requirements

  • OCaml >= 4.03.0 (may be less but need test)
  • base-bytes meta-package
  • base-bigarray meta-package
  • dune to build the project

If you want to compile the test program, you need:

  • alcotest

Credits

This work is from the nocrypto library and the Vincent hanquez's work in ocaml-sha.

All credits appear in the begin of files and this library is motivated by two reasons:

  • delete the dependancy with nocrypto if you don't use the encryption (and common) part
  • aggregate all hashes functions in one library

Dependencies (3)

  1. eqaf
  2. dune >= "2.6.0"
  3. ocaml >= "4.08.0"

Dev Dependencies (8)

  1. crowbar with-test
  2. ocamlfind with-test
  3. rresult with-test
  4. fpath with-test
  5. astring with-test
  6. bos with-test
  7. alcotest with-test
  8. fmt with-test & >= "0.8.7"

Used by (81)

  1. albatross >= "2.3.0"
  2. archetype < "1.2.2"
  3. aws >= "1.2"
  4. aws-s3
  5. builder-web >= "0.2.0"
  6. ca-certs >= "1.0.1"
  7. ca-certs-nss >= "3.104"
  8. caldav >= "0.2.3"
  9. carton < "1.0.0"
  10. carton-git-lwt
  11. carton-lwt
  12. carton-miou-unix
  13. chamelon
  14. cohttp-async >= "6.0.0"
  15. conex-mirage-crypto >= "1.0.0"
  16. dkim
  17. dkim-mirage
  18. dns-tsig >= "9.1.0"
  19. docfd >= "2.1.0"
  20. docteur
  21. docteur-solo5
  22. docteur-unix
  23. dream < "1.0.0~alpha3" | >= "1.0.0~alpha5"
  24. dream-httpaf < "1.0.0~alpha4"
  25. esperanto-cosmopolitan >= "0.0.5"
  26. fluxt
  27. git >= "3.2.0"
  28. git-kv >= "0.2.0"
  29. git-unix >= "3.2.0"
  30. graphql-cohttp >= "0.9.0"
  31. httpcats
  32. httpun-ws-async
  33. httpun-ws-eio
  34. httpun-ws-lwt
  35. index-bench >= "1.5.0"
  36. irmin
  37. irmin-cli
  38. irmin-git
  39. irmin-http
  40. irmin-server
  41. irmin-tezos
  42. irmin-unix
  43. jose >= "0.10.0"
  44. jupyter-kernel
  45. jwto >= "0.4.0"
  46. kdf
  47. learn-ocaml
  48. learn-ocaml-client
  49. letsencrypt >= "1.0.0"
  50. MlFront_Cli < "2.3.1"
  51. MlFront_Core
  52. MlFront_Thunk
  53. miou
  54. mirage-crypto-ec >= "1.1.0"
  55. mirage-crypto-pk >= "1.1.0"
  56. mirage-crypto-rng >= "1.1.0"
  57. mirage-crypto-rng-miou-unix
  58. multihash-digestif
  59. naboris >= "0.1.3"
  60. nocoiner
  61. noise >= "0.2.0"
  62. nomad
  63. ocluster
  64. ocluster-worker
  65. octez-internal-libs
  66. ometrics >= "0.1.2"
  67. openstellina
  68. otr >= "1.0.0"
  69. owi >= "0.2"
  70. smaws-lib
  71. soupault >= "4.4.0"
  72. spoke
  73. swhid
  74. swhid_compute
  75. tezos-base58
  76. tezos-context < "16.0"
  77. tezos-context-hash
  78. tls >= "1.0.4"
  79. webauthn >= "0.2.0"
  80. yocaml_runtime
  81. zeit

Conflicts (2)

  1. ocaml-freestanding
  2. mirage-xen < "6.0.0"