/users/patterns/www2_Hacked_x/blog/wp-includes/sodium_compat/src/Core32/XSalsa20.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
<?php

if (class_exists('ParagonIE_Sodium_Core32_XSalsa20'false)) {
    return;
}

/**
 * Class ParagonIE_Sodium_Core32_XSalsa20
 */
abstract class ParagonIE_Sodium_Core32_XSalsa20 extends ParagonIE_Sodium_Core32_HSalsa20
{
    
/**
     * Expand a key and nonce into an xsalsa20 keystream.
     *
     * @internal You should not use this directly from another application
     *
     * @param int $len
     * @param string $nonce
     * @param string $key
     * @return string
     * @throws SodiumException
     * @throws TypeError
     */
    
public static function xsalsa20($len$nonce$key)
    {
        
$ret self::salsa20(
            
$len,
            
self::substr($nonce168),
            
self::hsalsa20($nonce$key)
        );
        return 
$ret;
    }

    
/**
     * Encrypt a string with XSalsa20. Doesn't provide integrity.
     *
     * @internal You should not use this directly from another application
     *
     * @param string $message
     * @param string $nonce
     * @param string $key
     * @return string
     * @throws SodiumException
     * @throws TypeError
     */
    
public static function xsalsa20_xor($message$nonce$key)
    {
        return 
self::xorStrings(
            
$message,
            
self::xsalsa20(
                
self::strlen($message),
                
$nonce,
                
$key
            
)
        );
    }
}