Project

keccak

0.04
Low commit activity in last 3 years
The Keccak (SHA3) hash used by Ethereum. This does not implement the final FIPS202 standard, today known as SHA3 but rather an early version, commonly referred to as Keccak.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 2.4
~> 3.6
 Project Readme

The Keccak (SHA3 candidate) digest for Ruby

GitHub Workflow Status GitHub top language GitHub release Gem Gem Visitors License

This Ruby extension exposes the Keccak (SHA3 candidate) digest C bindings in the non-final version used by Ethereum. It is based on the reference C implementation, version 3.2. The exposed interface is almost identical to that of the digest standard library. See #16.

Installation

The gem is called keccak.

bundle add keccak
gem install keccak
gem 'keccak', '~> 1.3'

Usage

This gem extends the digest/* module by a digest/keccak class.

require 'digest/keccak'

# Generate 512-bit digest.
Digest::Keccak.digest("foo")       # => "\025\227\204*..."
Digest::Keccak.hexdigest("foo")    # => "1597842a..."

# Generate 224-bit digest.
Digest::Keccak.digest("foo", 224)       # => "\332\251M\247..."
Digest::Keccak.hexdigest("foo", 224)    # => "daa94da7..."

# Use this interface to feed data in chunks. 512-bit by default.
digest = Digest::Keccak.new
digest.update("f")
digest.update("o")
digest.update("o")
digest.digest       # => "\025\227\204*..."
digest.hexdigest    # => "1597842a..."

# You can pass a hash length to the constructor.
digest = Digest::Keccak.new(224)

Keccak supports five hash lengths: 224-bit, 256-bit, 384-bit, 512-bit and variable length. Variable length is not supported by this Ruby extension. Unless the user specifies otherwise, this Ruby extension assumes 512-bit.

Running the test suite

Run the test suite as follows:

bundle install
make test

A part of the test suite is automatically generated from Keccak's reference test suite.

Warning: Keccak vs. SHA3

⚠️ This gem does not implement the final FIPS202 standard, today known as SHA3 but rather an early version, commonly referred to as Keccak. The reason why this is kept around, is that Ethereum uses this earler version of Keccak. See also: Ethereum: Difference between keccak256 and sha3.

If you are looking for the final SHA3 gem, please use the following: https://rubygems.org/gems/sha3

History

This gem was initially developed and published as digest-sha3: https://github.com/phusion/digest-sha3-ruby

This gem was later patched multiple times: