/var/www/hkosl.com/aga/wp-includes/sodium_compat/src/Core32/Poly1305.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
58
59
60
61
62
63
<?php

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

/**
 * Class ParagonIE_Sodium_Core32_Poly1305
 */
abstract class ParagonIE_Sodium_Core32_Poly1305 extends ParagonIE_Sodium_Core32_Util
{
    const 
BLOCK_SIZE 16;

    
/**
     * @internal You should not use this directly from another application
     *
     * @param string $m
     * @param string $key
     * @return string
     * @throws SodiumException
     * @throws TypeError
     */
    
public static function onetimeauth($m$key)
    {
        if (
self::strlen($key) < 32) {
            throw new 
InvalidArgumentException(
                
'Key must be 32 bytes long.'
            
);
        }
        
$state = new ParagonIE_Sodium_Core32_Poly1305_State(
            
self::substr($key032)
        );
        return 
$state
            
->update($m)
            ->
finish();
    }

    
/**
     * @internal You should not use this directly from another application
     *
     * @param string $mac
     * @param string $m
     * @param string $key
     * @return bool
     * @throws SodiumException
     * @throws TypeError
     */
    
public static function onetimeauth_verify($mac$m$key)
    {
        if (
self::strlen($key) < 32) {
            throw new 
InvalidArgumentException(
                
'Key must be 32 bytes long.'
            
);
        }
        
$state = new ParagonIE_Sodium_Core32_Poly1305_State(
            
self::substr($key032)
        );
        
$calc $state
            
->update($m)
            ->
finish();
        return 
self::verify_16($calc$mac);
    }
}