2017 © Pedro Peláez
 

symfony-bundle scrypt-password-encoder-bundle

Scrypt password encoder for Symfony2

image

usu/scrypt-password-encoder-bundle

Scrypt password encoder for Symfony2

  • Saturday, November 29, 2014
  • by andreausu
  • Repository
  • 3 Watchers
  • 19 Stars
  • 1,330 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 3 Forks
  • 0 Open issues
  • 4 Versions
  • 0 % Grown

The README.md

UsuScryptPasswordEncoderBundle

This Bundle provides a Symfony2 password encoder service that uses scrypt for password encoding., (*1)

Build Status Latest Stable Version Total Downloads License, (*2)

Why you should use scrypt

The scrypt key derivation function is designed to be far more secure against hardware brute-force attacks than alternative functions such as PBKDF2 or bcrypt., (*3)

KDF comparison, (*4)

The designers of scrypt estimate that on modern (2009) hardware, if 5 seconds are spent computing a derived key, the cost of a hardware brute-force attack against scrypt is roughly 4000 times greater than the cost of a similar attack against bcrypt (to find the same password), and 20000 times greater than a similar attack against PBKDF2., (*5)

But I'm already using Bcrypt!, (*6)

Installation

Add this to your composer.json:, (*7)

``` json { "require": { "usu/scrypt-password-encoder-bundle": "dev-master" } }, (*8)


Then run: ``` bash $ composer update usu/scrypt-password-encoder-bundle

Add the bundle in app/AppKernel.php:, (*9)

``` php $bundles = array( // ... new Usu\ScryptPasswordEncoderBundle\UsuScryptPasswordEncoderBundle(), );, (*10)


And, finally, set the encoder in `app/config/security.yml`: security: encoders: Symfony\Component\Security\Core\User\User: id: security.encoder.scrypt Or, if you are using the excellent `FOSUserBundle`: security: encoders: FOS\UserBundle\Model\UserInterface: id: security.encoder.scrypt Configuration ------------- You can change the default bundle values (shown below) by adding the following to your `config.yml` file: usu_scrypt_password_encoder: cpu_cost: 2048 memory_cost: 4 parallelization_cost: 1 key_length: 64 Changing any of the above parameters will result in a different key (auto updating of old passwords is not currently supported). The parameter `key_length` determines the size in bytes of the derived key; eg: a 64 bytes key will result in a 88 characters string after the automatic base64_encode. Please refer to the [original documentation](http://framework.zend.com/manual/2.2/en/modules/zend.crypt.key.derivation.html#scrypt-adapter) for additional informnation. Testing ------- This bundle is fully tested with PHPUnit. Go to the root folder, install the dev dependencies with composer, and then run the phpunit test suite ``` bash $ composer --dev install $ ./vendor/bin/phpunit

License

This bundle is released under the MIT license. See the complete license in the bundle:, (*11)

Resources/meta/LICENSE

Acknowledgements

I would like to thank elnur for creating the great ElnurBlowfishPasswordEncoderBundle that inspired me to release this and pbhogan from which I borrowed the "Why you should use scrypt" readme section., (*12)

The Versions

29/11 2014

dev-master

9999999-dev

Scrypt password encoder for Symfony2

  Sources   Download

MIT

The Requires

 

The Development Requires

by Andrea Usuelli

security symfony password password-encoder scrypt

29/11 2014

v1.0.0

1.0.0.0

Scrypt password encoder for Symfony2

  Sources   Download

MIT

The Requires

 

The Development Requires

by Andrea Usuelli

security symfony password password-encoder scrypt

12/10 2013

v0.1.1

0.1.1.0

Scrypt password encoder for Symfony2

  Sources   Download

MIT

The Requires

 

The Development Requires

by Andrea Usuelli

security symfony password password-encoder scrypt

28/08 2013

v0.1

0.1.0.0

Scrypt password encoder for Symfony2

  Sources   Download

MIT

The Requires

 

The Development Requires

by Andrea Usuelli

security symfony password password-encoder scrypt