1Crypt::Digest::CHAES(3)User Contributed Perl DocumentatioCnrypt::Digest::CHAES(3)
2
3
4
6 Crypt::Digest::CHAES - Hash function - CipherHash based on AES [size:
7 128 bits]
8
10 ### Functional interface:
11 use Crypt::Digest::CHAES qw( chaes chaes_hex chaes_b64 chaes_b64u
12 chaes_file chaes_file_hex chaes_file_b64 chaes_file_b64u );
13
14 # calculate digest from string/buffer
15 $chaes_raw = chaes('data string');
16 $chaes_hex = chaes_hex('data string');
17 $chaes_b64 = chaes_b64('data string');
18 $chaes_b64u = chaes_b64u('data string');
19 # calculate digest from file
20 $chaes_raw = chaes_file('filename.dat');
21 $chaes_hex = chaes_file_hex('filename.dat');
22 $chaes_b64 = chaes_file_b64('filename.dat');
23 $chaes_b64u = chaes_file_b64u('filename.dat');
24 # calculate digest from filehandle
25 $chaes_raw = chaes_file(*FILEHANDLE);
26 $chaes_hex = chaes_file_hex(*FILEHANDLE);
27 $chaes_b64 = chaes_file_b64(*FILEHANDLE);
28 $chaes_b64u = chaes_file_b64u(*FILEHANDLE);
29
30 ### OO interface:
31 use Crypt::Digest::CHAES;
32
33 $d = Crypt::Digest::CHAES->new;
34 $d->add('any data');
35 $d->addfile('filename.dat');
36 $d->addfile(*FILEHANDLE);
37 $result_raw = $d->digest; # raw bytes
38 $result_hex = $d->hexdigest; # hexadecimal form
39 $result_b64 = $d->b64digest; # Base64 form
40 $result_b64u = $d->b64udigest; # Base64 URL Safe form
41
43 Provides an interface to the CHAES digest algorithm.
44
46 Nothing is exported by default.
47
48 You can export selected functions:
49
50 use Crypt::Digest::CHAES qw(chaes chaes_hex chaes_b64 chaes_b64u
51 chaes_file chaes_file_hex chaes_file_b64 chaes_file_b64u);
52
53 Or all of them at once:
54
55 use Crypt::Digest::CHAES ':all';
56
58 chaes
59 Logically joins all arguments into a single string, and returns its
60 CHAES digest encoded as a binary string.
61
62 $chaes_raw = chaes('data string');
63 #or
64 $chaes_raw = chaes('any data', 'more data', 'even more data');
65
66 chaes_hex
67 Logically joins all arguments into a single string, and returns its
68 CHAES digest encoded as a hexadecimal string.
69
70 $chaes_hex = chaes_hex('data string');
71 #or
72 $chaes_hex = chaes_hex('any data', 'more data', 'even more data');
73
74 chaes_b64
75 Logically joins all arguments into a single string, and returns its
76 CHAES digest encoded as a Base64 string, with trailing '=' padding.
77
78 $chaes_b64 = chaes_b64('data string');
79 #or
80 $chaes_b64 = chaes_b64('any data', 'more data', 'even more data');
81
82 chaes_b64u
83 Logically joins all arguments into a single string, and returns its
84 CHAES digest encoded as a Base64 URL Safe string (see RFC 4648 section
85 5).
86
87 $chaes_b64url = chaes_b64u('data string');
88 #or
89 $chaes_b64url = chaes_b64u('any data', 'more data', 'even more data');
90
91 chaes_file
92 Reads file (defined by filename or filehandle) content, and returns its
93 CHAES digest encoded as a binary string.
94
95 $chaes_raw = chaes_file('filename.dat');
96 #or
97 $chaes_raw = chaes_file(*FILEHANDLE);
98
99 chaes_file_hex
100 Reads file (defined by filename or filehandle) content, and returns its
101 CHAES digest encoded as a hexadecimal string.
102
103 $chaes_hex = chaes_file_hex('filename.dat');
104 #or
105 $chaes_hex = chaes_file_hex(*FILEHANDLE);
106
107 BEWARE: You have to make sure that the filehandle is in binary mode
108 before you pass it as argument to the addfile() method.
109
110 chaes_file_b64
111 Reads file (defined by filename or filehandle) content, and returns its
112 CHAES digest encoded as a Base64 string, with trailing '=' padding.
113
114 $chaes_b64 = chaes_file_b64('filename.dat');
115 #or
116 $chaes_b64 = chaes_file_b64(*FILEHANDLE);
117
118 chaes_file_b64u
119 Reads file (defined by filename or filehandle) content, and returns its
120 CHAES digest encoded as a Base64 URL Safe string (see RFC 4648 section
121 5).
122
123 $chaes_b64url = chaes_file_b64u('filename.dat');
124 #or
125 $chaes_b64url = chaes_file_b64u(*FILEHANDLE);
126
128 The OO interface provides the same set of functions as Crypt::Digest.
129
130 new
131 $d = Crypt::Digest::CHAES->new();
132
133 clone
134 $d->clone();
135
136 reset
137 $d->reset();
138
139 add
140 $d->add('any data');
141 #or
142 $d->add('any data', 'more data', 'even more data');
143
144 addfile
145 $d->addfile('filename.dat');
146 #or
147 $d->addfile(*FILEHANDLE);
148
149 add_bits
150 $d->add_bits($bit_string); # e.g. $d->add_bits("111100001010");
151 #or
152 $d->add_bits($data, $nbits); # e.g. $d->add_bits("\xF0\xA0", 16);
153
154 hashsize
155 $d->hashsize;
156 #or
157 Crypt::Digest::CHAES->hashsize();
158 #or
159 Crypt::Digest::CHAES::hashsize();
160
161 digest
162 $result_raw = $d->digest();
163
164 hexdigest
165 $result_hex = $d->hexdigest();
166
167 b64digest
168 $result_b64 = $d->b64digest();
169
170 b64udigest
171 $result_b64url = $d->b64udigest();
172
174 • CryptX, Crypt::Digest
175
176 • <https://en.wikipedia.org/wiki/Cryptographic_hash_function#Hash_functions_based_on_block_ciphers>
177
178
179
180perl v5.36.1 2023-10-04 Crypt::Digest::CHAES(3)