Skip to content

GOST R 34.11-2012 (Stribog) Hash Function implementation for PHP.

License

MIT, BSD-2-Clause licenses found

Licenses found

MIT
LICENSE
BSD-2-Clause
LICENSE.gost
Notifications You must be signed in to change notification settings

sjinks/php-stribog

Repository files navigation

php-stribog

Build and Test

GOST R 34.11-2012 (Stribog) Hash Function Implementation for PHP.

Tested with PHP 5.2, 5.3, 5.4, 5.5, 5.6, 7.0, 7.1, 7.2, 7.3, 7.4, 8.0, 8.1, 8.2, 8.3, 8.4, and nightly (8.5 as of writing)

Introduction

This extension provides the implementation of GOST R 34.11-2012 256- and 512-bit hash functions to use with PHP hash extension.

The extension does not introduce any new functions; instead, it registers three hashes:

  • stribog-256 (GOST R 34.11-2012 256-bit hash function);
  • stribog-512 (GOST R 34.11-2012 512-bit hash function);
  • stribog (alias of stribog-512).

These hashes can be used with any function from PHP hash extension.

The implementation of the hash function (gost3411-2012-*.c) is based on the implementation by Alexey Degtyarev, see LICENSE.gost. The changes made to Alexey's code:

  • the MMX implementation was almost completely rewritten in order not to use SSE instructions;
  • optimization of 64-bit version of extract() — gained extra 0.7 MB/s;
  • the generic implementation was optimized by removing unnecessary memcpy calls;
  • inline functions instead of macros;
  • the implementation (generic/MMX/SSE) is chosen at runtime depending on CPU capabilities (GCC 4.6 or newer is required for that);
  • fixed add512() implementation.

Installing/Configuring

phpize
./configure
make
sudo make install

You will also need to add

extension=stribog.so

to your php.ini.

There are no configuration directives defined in php.ini.

Usage Example

Hash calculation:

$data = '012345678901234567890123456789012345678901234567890123456789012';
echo hash('stribog256', $data), PHP_EOL;
echo hash('stribog512', $data), PHP_EOL;
echo hash('stribog', $data), PHP_EOL;

HMAC calculation:

$data = 'Very secret data';
$key  = 'password';
echo hash_hmac('stribog', $data, $key);