diff options
author | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-08-12 17:23:11 +0000 |
---|---|---|
committer | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2011-08-12 17:23:11 +0000 |
commit | c233d6592d6ce0cca9149f09cc87c5799d33382a (patch) | |
tree | 3d4453a2546d95bbebc6cc0cf17277a21b47a06b /ext | |
parent | 26b384e6a584cbd142327d1b1fb67f861cfc862d (diff) | |
download | ruby-c233d6592d6ce0cca9149f09cc87c5799d33382a.tar.gz |
* ext/digest/digest.c: Add documentation for the Digest module. Patch by
Sylvain Daubert. [Ruby 1.9 - Bug #5167]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@32950 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
-rw-r--r-- | ext/digest/digest.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/ext/digest/digest.c b/ext/digest/digest.c index d535b35980..956f47ff78 100644 --- a/ext/digest/digest.c +++ b/ext/digest/digest.c @@ -29,6 +29,53 @@ RUBY_EXTERN void Init_digest_base(void); * Document-module: Digest * * This module provides a framework for message digest libraries. + * + * You may want to look at OpenSSL::Digest as it supports support more + * algorithms. + * + * A cryptographic hash function is a procedure that takes data and return a + * fixed bit string : the hash value, also known as _digest_. Hash functions + * are also called one-way functions, it is easy to compute a digest from + * a message, but it is infeasible to generate a message from a digest. + * + * == Example + * + * require 'digest' + * + * # Compute a complete digest + * sha256 = Digest::SHA256.new + * digest = sha256.digest message + * + * # Compute digest by chunks + * sha256 = Digest::SHA256.new + * sha256.update message1 + * sha256 << message2 # << is an alias for update + * + * digest = sha256.digest + * + * == Digest algorithms + * + * Different digest algorithms (or hash functions) are available : + * + * HMAC:: + * See FIPS PUB 198 The Keyed-Hash Message Authentication Code (HMAC) + * RIPEMD-160:: + * (as Digest::RMD160) see + * http://homes.esat.kuleuven.be/~bosselae/ripemd160.html + * SHA1:: + * See FIPS 180 Secure Hash Standard + * SHA2 family:: + * See FIPS 180 Secure Hash Standard which defines the following algorithms: + * * SHA512 + * * SHA384 + * * SHA256 + * + * The latest versions of the FIPS publications can be found here: + * http://csrc.nist.gov/publications/PubsFIPS.html + * + * Additionally Digest::BubbleBabble encodes a digest as a sequence of + * consonants and vowels which is more recognizable and comparable than a + * hexadecimal digest. See http://en.wikipedia.org/wiki/Bubblebabble */ static VALUE |