joomla / crypt
Joomla Crypt Package
Fund package maintenance!
joomla
community.joomla.org/sponsorship-campaigns.html
Installs: 191 134
Dependents: 3
Suggesters: 2
Security: 0
Stars: 6
Watchers: 13
Forks: 9
Open Issues: 0
Type:joomla-package
Requires
- php: ^8.1.0
Requires (Dev)
- defuse/php-encryption: ^2.0
- paragonie/sodium_compat: ^1|^2
- phan/phan: ^5.4.2
- phpstan/phpstan: ^1.10.7
- phpunit/phpunit: ^9.5.28
- squizlabs/php_codesniffer: ~3.7.2
- symfony/phpunit-bridge: ^5.0
- symfony/polyfill-util: ^1.0
Suggests
- ext-openssl: To use the OpenSSL cipher
- ext-sodium: To use the Sodium cipher
- defuse/php-encryption: To use Crypto cipher
- paragonie/sodium_compat: To use Sodium cipher if neither ext/sodium or ext/libsodium are available
This package is auto-updated.
Last update: 2025-01-10 07:10:22 UTC
README
The Crypt password provides a set of classes that can be used for encrypting and hashing data.
Interfaces
PasswordInterface
PasswordInterface
is an interface that requires a class to be implemented with a create and a verify method.
The create method should take a plain text password and a type and return a hashed password.
The verify method should accept a plain text password and a hashed password and return a boolean indicating whether or not the password matched the password in the hash.
The PasswordInterface
interface defines the following constants for use with implementations:
PasswordInterface::BLOWFISH
PasswordInterface::JOOMLA
PasswordInterface::MD5
PasswordInterface::PBKDF
Classes
Password\Simple
Usage
In addition to the interface PasswordInterface
there is also a basic implementation provided which provides for use with the most common password schemes. This if found in the Password\Simple
class.
Aside from the two methods create and verify methods, this implementation also adds an additional method called setCost. This method is used to set a cost parameter for methods that support workload factors. It takes an integer cost factor as a parameter.
Password\Simple
provides support for bcrypt, MD5 and the traditional Joomla! CMS hashing scheme. The hash format can be specified during hash creation by using the constants PasswordInterface::BLOWFISH
, PasswordInterface::MD5
, PasswordInterface::JOOMLA
, and PasswordInterface::PBKDF
. An appropriate salt will be automatically generated when required.
Installation via Composer
Add "joomla/crypt": "~3.0" to the require block in your composer.json and then run
composer install`.
{ "require": { "joomla/crypt": "~3.0" } }
Alternatively, you can simply run the following from the command line:
composer require joomla/crypt "~3.0"
If you want to include the test sources, use
composer require --prefer-source joomla/crypt "~3.0"