sodium_crypto_aead_xchacha20poly1305_ietf_encrypt

FunctionMisc changes in PHP 8.2

(Preferred) Encrypt then authenticate with XChaCha20-Poly1305.

PHP 5
PHP 7.0-7.1
PHP 7.2
Added
PHP 7.3-7.4
PHP 8.0
Improved
PHP 8.1-8.2
PHP 8.3
PHP 8.4
PHP 8.5

sodium_crypto_aead_xchacha20poly1305_ietf_encrypt Function synopsis

sodium_crypto_aead_xchacha20poly1305_ietf_encrypt(
    string $message,
    string $additional_data,
    string $nonce,
    string $key
  ): string

Parameters

$message

Typestring

The plaintext message to encrypt.

$additional_data

Typestring

Additional, authenticated data. This is used in the verification of the authentication tag appended to the ciphertext, but it is not encrypted or stored in the ciphertext.

$nonce

Typestring

A number that must be only used once, per message. 24 bytes long. This is a large enough bound to generate randomly (i.e. random_bytes).

$key

Typestring

Encryption key (256-bit).

Return value

Typestring

Returns the ciphertext and tag on success, or false on failure.

Changes to the sodium_crypto_aead_xchacha20poly1305_ietf_encrypt Function

PHP 8.2

PHP 8.0

  • Return type added: string
  • Parameter name of parameter #1 changed: $string to $message
  • Parameter type added for parameter #1 ($message): string
  • Parameter name of parameter #2 changed: $ad to $additional_data
  • Parameter type added for parameter #2 ($additional_data): string
  • Parameter type added for parameter #3 ($nonce): string
  • Parameter type added for parameter #4 ($key): string
  sodium_crypto_aead_xchacha20poly1305_ietf_encrypt(
-     $string,
+     string $message,
-     $ad,
+     string $additional_data,
-     $nonce,
+     string $nonce,
-     $key
+     string $key
-   )
+   ): string

PHP 7.2

  • Function added

sodium_crypto_aead_xchacha20poly1305_ietf_encrypt Function Availability

PHP VersionAvailability
PHP 8.5Upcoming Release Yes
PHP 8.4Supported (Latest) Yes
PHP 8.3Supported Yes
PHP 8.2Security-Fixes Only Yes
PHP 8.1Security-Fixes Only Yes
PHP 8.0Unsupported Yes
PHP 7.4Unsupported Yes
PHP 7.3Unsupported Yes
PHP 7.2Unsupported Yes
PHP 7.1Unsupported No
PHP 7.0Unsupported No
PHP 5.6Unsupported No
PHP 5.5Unsupported No
PHP 5.4Unsupported No
PHP 5.3Unsupported No