Halite is a high-level cryptography interface that relies on libsodium
for all of its underlying cryptography operations.
Halite was created by Paragon Initiative Enterprises as a result of our continued efforts to improve the ecosystem and make cryptography in PHP safer and easier to implement.
It's released under the GPLv3 license. Commercial licenses are available from Paragon Initiative Enterprises if you wish to implement Halite in an application without making your source code available under a GPL-compatible license.
For PHP 5.x compatibility, see stable for version 1.x.
Halite alternatives and similar libraries
Based on the "Security" category.
Alternatively, view Halite alternatives based on common mentions on social networks and blogs.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest. Visit our partner's website for more details.
Do you think we are missing an alternative of Halite or a related project?
Halite is a high-level cryptography interface that relies on libsodium for all of its underlying cryptography operations.
You can read the Halite Documentation online.
Halite is released under Mozilla Public License 2.0. Commercial licenses are available from Paragon Initiative Enterprises if you wish to extend Halite without making your derivative works available under the terms of the MPL.
If you are satisfied with the terms of MPL software for backend web applications but would like to purchase a support contract for your application that uses Halite, those are also offered by Paragon Initiative Enterprises.
Important: Earlier versions of Halite were available under the GNU Public License version 3 (GPLv3). Only Halite 4.0.1 and newer are available under the Mozilla Public License terms.
Before you can use Halite, you must choose a version that fits the requirements of your project. The differences between the requirements for the available versions of Halite are briefly highlighted below.
|Halite 4.1 and newer||7.2.0||1.0.15||N/A (standard)||:heavy_check_mark: Active|
|Halite 4.0||7.2.0||1.0.13||N/A (standard)||:heavy_check_mark: Active|
|Halite 3||7.0.0||1.0.9||1.0.6 / 2.0.4||:x: Not Supported|
|Halite 2||7.0.0||1.0.9||1.0.6||:x: Not Supported|
|Halite 1||5.6.0||1.0.6||1.0.2||:x: Not Supported|
If you need a version of Halite before 4.0, see the documentation relevant to that particular branch.
To install Halite, you first need to install libsodium. You may or may not need the PHP extension. For most people, this means running...
sudo apt-get install php7.2-sodium
...or an equivalent command for your operating system and PHP version.
If you're stuck, [this step-by-step guide contributed by @aolko](doc/Install-Guides/Ubuntu.md) may be helpful.
Once you have the prerequisites installed, install Halite through Composer:
composer require paragonie/halite:^4
Commercial Support for Older Halite Versions
Free (gratis) support for Halite only extends to the most recent major version (currently 4).
If your company requires support for an older version of Halite, contact Paragon Initiative Enterprises to inquire about commercial support options.
If you need an easy way to migrate from older versions of Halite, check out halite-legacy.
Using Halite in Your Project
Check out the [documentation](doc). The basic Halite API is designed for simplicity:
Example: Encrypting and Decrypting a message
First, generate and persist a key exactly once:
<?php use ParagonIE\Halite\KeyFactory; $encKey = KeyFactory::generateEncryptionKey(); KeyFactory::save($encKey, '/path/outside/webroot/encryption.key');
And then you can encrypt/decrypt messages like so:
<?php use ParagonIE\Halite\KeyFactory; use ParagonIE\Halite\Symmetric\Crypto as Symmetric; use ParagonIE\HiddenString\HiddenString; $encryptionKey = KeyFactory::loadEncryptionKey('/path/outside/webroot/encryption.key'); $message = new HiddenString('This is a confidential message for your eyes only.'); $ciphertext = Symmetric::encrypt($message, $encryptionKey); $decrypted = Symmetric::decrypt($ciphertext, $encryptionKey); var_dump($decrypted->getString() === $message->getString()); // bool(true)
This should produce something similar to:
Cryptographic Keys in Halite
Important: Halite works with
Keyobjects, not strings.
If you attempt to
echo a key object, you will get an empty string
rather than its contents. If you attempt to
var_dump() a key object,
you will just get some facts about the type of key it is.
You must invoke
$obj->getRawKeyMaterial() explicitly if you want
to inspect a key's raw binary contents. This is not recommended for
most use cases.
Example: Generating a key from a password
<?php use ParagonIE\Halite\KeyFactory; use ParagonIE\HiddenString\HiddenString; $passwd = new HiddenString('correct horse battery staple'); // Use random_bytes(16); to generate the salt: $salt = "\xdd\x7b\x1e\x38\x75\x9f\x72\x86\x0a\xe9\xc8\x58\xf6\x16\x0d\x3b"; $encryptionKey = KeyFactory::deriveEncryptionKey($passwd, $salt);
A key derived from a password can be used in place of one randomly generated.
Example: Encrypting a large file on a system with low memory
Halite includes a file cryptography class that utilizes a streaming API to allow large files (e.g. gigabytes) be encrypted on a system with very little available memory (i.e. less than 8 MB).
<?php use ParagonIE\Halite\File; use ParagonIE\Halite\KeyFactory; $encryptionKey = KeyFactory::loadEncryptionKey('/path/outside/webroot/encryption.key'); File::encrypt('input.txt', 'output.txt', $encryptionKey);
Common Support Issues
Uncaught SodiumException: Cannot Wipe Memory
PHP Fatal error: Uncaught SodiumException: This is not implemented, as it is not possible to securely wipe memory from PHP
The solution to this is to make sure libsodium is installed/enabled. See above in this README for more information.
If your company uses this library in their products or services, you may be interested in purchasing a support contract from Paragon Initiative Enterprises.
*Note that all licence references and agreements mentioned in the Halite README section above are relevant to that project's source code only.