PHP Classes

File: autoload.php

Recommend this page to a friend!
  Classes of Scott Arciszewski   PHP Sodium Compat   autoload.php   Download  
File: autoload.php
Role: Auxiliary script
Content type: text/plain
Description: Auxiliary script
Class: PHP Sodium Compat
Cryptographic functions of libsodium in pure PHP
Author: By
Last change: Avoid recursion with class_exists()
Less reliance on include guards that return early

This may help with errors induced by opcache preloading
Add sodium_crypto_stream_xchacha20_xor_ic()

See https://github.com/php/php-src/pull/8276 for upstream
Possible fix for #122 by coercing the autoloader to always load the `ParagonIE_Sodium_Compat` class before the remaining polyfills (constants, etc.).
Implement Ristretto255

This is compatible with the new ext/sodium functions landing in PHP 8.1.0 and PECL libsodium 2.0.25.

See: https://github.com/php/php-src/pull/6922
See: https://github.com/jedisct1/libsodium-php/pull/212
We need a more surgical polyfill
Date: 2 years ago
Size: 2,855 bytes
 

Contents

Class file image Download
<?php

if (PHP_VERSION_ID < 70000) {
    if (!
is_callable('sodiumCompatAutoloader')) {
       
/**
         * Sodium_Compat autoloader.
         *
         * @param string $class Class name to be autoloaded.
         *
         * @return bool Stop autoloading?
         */
       
function sodiumCompatAutoloader($class)
        {
           
$namespace = 'ParagonIE_Sodium_';
           
// Does the class use the namespace prefix?
           
$len = strlen($namespace);
            if (
strncmp($namespace, $class, $len) !== 0) {
               
// no, move to the next registered autoloader
               
return false;
            }

           
// Get the relative class name
           
$relative_class = substr($class, $len);

           
// Replace the namespace prefix with the base directory, replace namespace
            // separators with directory separators in the relative class name, append
            // with .php
           
$file = dirname(__FILE__) . '/src/' . str_replace('_', '/', $relative_class) . '.php';
           
// if the file exists, require it
           
if (file_exists($file)) {
                require_once
$file;
                return
true;
            }
            return
false;
        }

       
// Now that we have an autoloader, let's register it!
       
spl_autoload_register('sodiumCompatAutoloader');
    }
} else {
    require_once
dirname(__FILE__) . '/autoload-php7.php';
}

/* Explicitly, always load the Compat class: */
if (!class_exists('ParagonIE_Sodium_Compat', false)) {
    require_once
dirname(__FILE__) . '/src/Compat.php';
}

if (!
class_exists('SodiumException', false)) {
    require_once
dirname(__FILE__) . '/src/SodiumException.php';
}
if (
PHP_VERSION_ID >= 50300) {
   
// Namespaces didn't exist before 5.3.0, so don't even try to use this
    // unless PHP >= 5.3.0
   
require_once dirname(__FILE__) . '/lib/namespaced.php';
    require_once
dirname(__FILE__) . '/lib/sodium_compat.php';
} else {
    require_once
dirname(__FILE__) . '/src/PHP52/SplFixedArray.php';
}
if (
PHP_VERSION_ID < 70200 || !extension_loaded('sodium')) {
    if (
PHP_VERSION_ID >= 50300 && !defined('SODIUM_CRYPTO_SCALARMULT_BYTES')) {
        require_once
dirname(__FILE__) . '/lib/php72compat_const.php';
    }
    if (
PHP_VERSION_ID >= 70000) {
       
assert(class_exists('ParagonIE_Sodium_Compat'), 'Possible filesystem/autoloader bug?');
    } else {
       
assert(class_exists('ParagonIE_Sodium_Compat'));
    }
    require_once(
dirname(__FILE__) . '/lib/php72compat.php');
} elseif (!
function_exists('sodium_crypto_stream_xchacha20_xor')) {
   
// Older versions of {PHP, ext/sodium} will not define these
   
require_once(dirname(__FILE__) . '/lib/php72compat.php');
}
require_once(
dirname(__FILE__) . '/lib/stream-xchacha20.php');
require_once(
dirname(__FILE__) . '/lib/ristretto255.php');