]> Dogcows Code - chaz/p5-File-KDBX/blob - lib/File/KDBX/Constants.pm
Add function for creating class attributes
[chaz/p5-File-KDBX] / lib / File / KDBX / Constants.pm
1 package File::KDBX::Constants;
2 # ABSTRACT: All the KDBX-related constants you could ever want
3
4 # HOW TO add new constants:
5 # 1. Add it to the %CONSTANTS structure below.
6 # 2. List it in the pod at the bottom of this file in the section corresponding to its tag.
7 # 3. There is no step three.
8
9 use warnings;
10 use strict;
11
12 use Exporter qw(import);
13 use Scalar::Util qw(dualvar);
14 use namespace::clean -except => 'import';
15
16 our $VERSION = '999.999'; # VERSION
17
18 BEGIN {
19 my %CONSTANTS = (
20 magic => {
21 __prefix => 'KDBX',
22 SIG1 => 0x9aa2d903,
23 SIG1_FIRST_BYTE => 0x03,
24 SIG2_1 => 0xb54bfb65,
25 SIG2_2 => 0xb54bfb67,
26 },
27 version => {
28 __prefix => 'KDBX_VERSION',
29 _2_0 => 0x00020000,
30 _3_0 => 0x00030000,
31 _3_1 => 0x00030001,
32 _4_0 => 0x00040000,
33 _4_1 => 0x00040001,
34 OLDEST => 0x00020000,
35 LATEST => 0x00040001,
36 MAJOR_MASK => 0xffff0000,
37 MINOR_MASK => 0x0000ffff,
38 },
39 header => {
40 __prefix => 'HEADER',
41 END => dualvar( 0, 'end'),
42 COMMENT => dualvar( 1, 'comment'),
43 CIPHER_ID => dualvar( 2, 'cipher_id'),
44 COMPRESSION_FLAGS => dualvar( 3, 'compression_flags'),
45 MASTER_SEED => dualvar( 4, 'master_seed'),
46 TRANSFORM_SEED => dualvar( 5, 'transform_seed'),
47 TRANSFORM_ROUNDS => dualvar( 6, 'transform_rounds'),
48 ENCRYPTION_IV => dualvar( 7, 'encryption_iv'),
49 INNER_RANDOM_STREAM_KEY => dualvar( 8, 'inner_random_stream_key'),
50 STREAM_START_BYTES => dualvar( 9, 'stream_start_bytes'),
51 INNER_RANDOM_STREAM_ID => dualvar( 10, 'inner_random_stream_id'),
52 KDF_PARAMETERS => dualvar( 11, 'kdf_parameters'),
53 PUBLIC_CUSTOM_DATA => dualvar( 12, 'public_custom_data'),
54 },
55 compression => {
56 __prefix => 'COMPRESSION',
57 NONE => dualvar( 0, 'none'),
58 GZIP => dualvar( 1, 'gzip'),
59 },
60 cipher => {
61 __prefix => 'CIPHER',
62 UUID_AES128 => "\x61\xab\x05\xa1\x94\x64\x41\xc3\x8d\x74\x3a\x56\x3d\xf8\xdd\x35",
63 UUID_AES256 => "\x31\xc1\xf2\xe6\xbf\x71\x43\x50\xbe\x58\x05\x21\x6a\xfc\x5a\xff",
64 UUID_CHACHA20 => "\xd6\x03\x8a\x2b\x8b\x6f\x4c\xb5\xa5\x24\x33\x9a\x31\xdb\xb5\x9a",
65 UUID_SALSA20 => "\x71\x6e\x1c\x8a\xee\x17\x4b\xdc\x93\xae\xa9\x77\xb8\x82\x83\x3a",
66 UUID_SERPENT => "\x09\x85\x63\xff\xdd\xf7\x4f\x98\x86\x19\x80\x79\xf6\xdb\x89\x7a",
67 UUID_TWOFISH => "\xad\x68\xf2\x9f\x57\x6f\x4b\xb9\xa3\x6a\xd4\x7a\xf9\x65\x34\x6c",
68 },
69 kdf => {
70 __prefix => 'KDF',
71 UUID_AES => "\xc9\xd9\xf3\x9a\x62\x8a\x44\x60\xbf\x74\x0d\x08\xc1\x8a\x4f\xea",
72 UUID_AES_CHALLENGE_RESPONSE => "\x7c\x02\xbb\x82\x79\xa7\x4a\xc0\x92\x7d\x11\x4a\x00\x64\x82\x38",
73 UUID_ARGON2D => "\xef\x63\x6d\xdf\x8c\x29\x44\x4b\x91\xf7\xa9\xa4\x03\xe3\x0a\x0c",
74 UUID_ARGON2ID => "\x9e\x29\x8b\x19\x56\xdb\x47\x73\xb2\x3d\xfc\x3e\xc6\xf0\xa1\xe6",
75 PARAM_UUID => '$UUID',
76 PARAM_AES_ROUNDS => 'R',
77 PARAM_AES_SEED => 'S',
78 PARAM_ARGON2_SALT => 'S',
79 PARAM_ARGON2_PARALLELISM => 'P',
80 PARAM_ARGON2_MEMORY => 'M',
81 PARAM_ARGON2_ITERATIONS => 'I',
82 PARAM_ARGON2_VERSION => 'V',
83 PARAM_ARGON2_SECRET => 'K',
84 PARAM_ARGON2_ASSOCDATA => 'A',
85 DEFAULT_AES_ROUNDS => 100_000,
86 DEFAULT_ARGON2_ITERATIONS => 10,
87 DEFAULT_ARGON2_MEMORY => 1 << 16,
88 DEFAULT_ARGON2_PARALLELISM => 2,
89 DEFAULT_ARGON2_VERSION => 0x13,
90 },
91 random_stream => {
92 __prefix => 'STREAM',
93 ID_RC4_VARIANT => 1,
94 ID_SALSA20 => 2,
95 ID_CHACHA20 => 3,
96 SALSA20_IV => "\xe8\x30\x09\x4b\x97\x20\x5d\x2a",
97
98 },
99 variant_map => {
100 __prefix => 'VMAP',
101 VERSION => 0x0100,
102 VERSION_MAJOR_MASK => 0xff00,
103 TYPE_END => 0x00,
104 TYPE_UINT32 => 0x04,
105 TYPE_UINT64 => 0x05,
106 TYPE_BOOL => 0x08,
107 TYPE_INT32 => 0x0C,
108 TYPE_INT64 => 0x0D,
109 TYPE_STRING => 0x18,
110 TYPE_BYTEARRAY => 0x42,
111 },
112 inner_header => {
113 __prefix => 'INNER_HEADER',
114 END => dualvar( 0, 'end'),
115 INNER_RANDOM_STREAM_ID => dualvar( 1, 'inner_random_stream_id'),
116 INNER_RANDOM_STREAM_KEY => dualvar( 2, 'inner_random_stream_key'),
117 BINARY => dualvar( 3, 'binary'),
118 BINARY_FLAG_PROTECT => 1,
119 },
120 key_file => {
121 __prefix => 'KEY_FILE',
122 TYPE_BINARY => dualvar( 1, 'binary'),
123 TYPE_HASHED => dualvar( 3, 'hashed'),
124 TYPE_HEX => dualvar( 2, 'hex'),
125 TYPE_XML => dualvar( 4, 'xml'),
126 },
127 history => {
128 __prefix => 'HISTORY',
129 DEFAULT_MAX_ITEMS => 10,
130 DEFAULT_MAX_SIZE => 6_291_456, # 6 M
131 },
132 icon => {
133 __prefix => 'ICON',
134 PASSWORD => dualvar( 0, 'Password'),
135 PACKAGE_NETWORK => dualvar( 1, 'Package_Network'),
136 MESSAGEBOX_WARNING => dualvar( 2, 'MessageBox_Warning'),
137 SERVER => dualvar( 3, 'Server'),
138 KLIPPER => dualvar( 4, 'Klipper'),
139 EDU_LANGUAGES => dualvar( 5, 'Edu_Languages'),
140 KCMDF => dualvar( 6, 'KCMDF'),
141 KATE => dualvar( 7, 'Kate'),
142 SOCKET => dualvar( 8, 'Socket'),
143 IDENTITY => dualvar( 9, 'Identity'),
144 KONTACT => dualvar( 10, 'Kontact'),
145 CAMERA => dualvar( 11, 'Camera'),
146 IRKICKFLASH => dualvar( 12, 'IRKickFlash'),
147 KGPG_KEY3 => dualvar( 13, 'KGPG_Key3'),
148 LAPTOP_POWER => dualvar( 14, 'Laptop_Power'),
149 SCANNER => dualvar( 15, 'Scanner'),
150 MOZILLA_FIREBIRD => dualvar( 16, 'Mozilla_Firebird'),
151 CDROM_UNMOUNT => dualvar( 17, 'CDROM_Unmount'),
152 DISPLAY => dualvar( 18, 'Display'),
153 MAIL_GENERIC => dualvar( 19, 'Mail_Generic'),
154 MISC => dualvar( 20, 'Misc'),
155 KORGANIZER => dualvar( 21, 'KOrganizer'),
156 ASCII => dualvar( 22, 'ASCII'),
157 ICONS => dualvar( 23, 'Icons'),
158 CONNECT_ESTABLISHED => dualvar( 24, 'Connect_Established'),
159 FOLDER_MAIL => dualvar( 25, 'Folder_Mail'),
160 FILESAVE => dualvar( 26, 'FileSave'),
161 NFS_UNMOUNT => dualvar( 27, 'NFS_Unmount'),
162 MESSAGE => dualvar( 28, 'Message'),
163 KGPG_TERM => dualvar( 29, 'KGPG_Term'),
164 KONSOLE => dualvar( 30, 'Konsole'),
165 FILEPRINT => dualvar( 31, 'FilePrint'),
166 FSVIEW => dualvar( 32, 'FSView'),
167 RUN => dualvar( 33, 'Run'),
168 CONFIGURE => dualvar( 34, 'Configure'),
169 KRFB => dualvar( 35, 'KRFB'),
170 ARK => dualvar( 36, 'Ark'),
171 KPERCENTAGE => dualvar( 37, 'KPercentage'),
172 SAMBA_UNMOUNT => dualvar( 38, 'Samba_Unmount'),
173 HISTORY => dualvar( 39, 'History'),
174 MAIL_FIND => dualvar( 40, 'Mail_Find'),
175 VECTORGFX => dualvar( 41, 'VectorGfx'),
176 KCMMEMORY => dualvar( 42, 'KCMMemory'),
177 TRASHCAN_FULL => dualvar( 43, 'Trashcan_Full'),
178 KNOTES => dualvar( 44, 'KNotes'),
179 CANCEL => dualvar( 45, 'Cancel'),
180 HELP => dualvar( 46, 'Help'),
181 KPACKAGE => dualvar( 47, 'KPackage'),
182 FOLDER => dualvar( 48, 'Folder'),
183 FOLDER_BLUE_OPEN => dualvar( 49, 'Folder_Blue_Open'),
184 FOLDER_TAR => dualvar( 50, 'Folder_Tar'),
185 DECRYPTED => dualvar( 51, 'Decrypted'),
186 ENCRYPTED => dualvar( 52, 'Encrypted'),
187 APPLY => dualvar( 53, 'Apply'),
188 SIGNATURE => dualvar( 54, 'Signature'),
189 THUMBNAIL => dualvar( 55, 'Thumbnail'),
190 KADDRESSBOOK => dualvar( 56, 'KAddressBook'),
191 VIEW_TEXT => dualvar( 57, 'View_Text'),
192 KGPG => dualvar( 58, 'KGPG'),
193 PACKAGE_DEVELOPMENT => dualvar( 59, 'Package_Development'),
194 KFM_HOME => dualvar( 60, 'KFM_Home'),
195 SERVICES => dualvar( 61, 'Services'),
196 TUX => dualvar( 62, 'Tux'),
197 FEATHER => dualvar( 63, 'Feather'),
198 APPLE => dualvar( 64, 'Apple'),
199 W => dualvar( 65, 'W'),
200 MONEY => dualvar( 66, 'Money'),
201 CERTIFICATE => dualvar( 67, 'Certificate'),
202 SMARTPHONE => dualvar( 68, 'Smartphone'),
203 },
204 bool => {
205 FALSE => !1,
206 TRUE => 1,
207 },
208 time => {
209 __prefix => 'TIME',
210 SECONDS_AD1_TO_UNIX_EPOCH => 62_135_596_800,
211 },
212 yubikey => {
213 YUBICO_VID => dualvar( 0x1050, 'Yubico'),
214 YUBIKEY_PID => dualvar( 0x0010, 'YubiKey 1/2'),
215 NEO_OTP_PID => dualvar( 0x0110, 'YubiKey NEO OTP'),
216 NEO_OTP_CCID_PID => dualvar( 0x0111, 'YubiKey NEO OTP+CCID'),
217 NEO_CCID_PID => dualvar( 0x0112, 'YubiKey NEO CCID'),
218 NEO_U2F_PID => dualvar( 0x0113, 'YubiKey NEO FIDO'),
219 NEO_OTP_U2F_PID => dualvar( 0x0114, 'YubiKey NEO OTP+FIDO'),
220 NEO_U2F_CCID_PID => dualvar( 0x0115, 'YubiKey NEO FIDO+CCID'),
221 NEO_OTP_U2F_CCID_PID => dualvar( 0x0116, 'YubiKey NEO OTP+FIDO+CCID'),
222 YK4_OTP_PID => dualvar( 0x0401, 'YubiKey 4/5 OTP'),
223 YK4_U2F_PID => dualvar( 0x0402, 'YubiKey 4/5 FIDO'),
224 YK4_OTP_U2F_PID => dualvar( 0x0403, 'YubiKey 4/5 OTP+FIDO'),
225 YK4_CCID_PID => dualvar( 0x0404, 'YubiKey 4/5 CCID'),
226 YK4_OTP_CCID_PID => dualvar( 0x0405, 'YubiKey 4/5 OTP+CCID'),
227 YK4_U2F_CCID_PID => dualvar( 0x0406, 'YubiKey 4/5 FIDO+CCID'),
228 YK4_OTP_U2F_CCID_PID => dualvar( 0x0407, 'YubiKey 4/5 OTP+FIDO+CCID'),
229 PLUS_U2F_OTP_PID => dualvar( 0x0410, 'YubiKey Plus OTP+FIDO'),
230
231 ONLYKEY_VID => dualvar( 0x1d50, 'OnlyKey'),
232 ONLYKEY_PID => dualvar( 0x60fc, 'OnlyKey'),
233
234 YK_EUSBERR => dualvar( 0x01, 'USB error'),
235 YK_EWRONGSIZ => dualvar( 0x02, 'wrong size'),
236 YK_EWRITEERR => dualvar( 0x03, 'write error'),
237 YK_ETIMEOUT => dualvar( 0x04, 'timeout'),
238 YK_ENOKEY => dualvar( 0x05, 'no yubikey present'),
239 YK_EFIRMWARE => dualvar( 0x06, 'unsupported firmware version'),
240 YK_ENOMEM => dualvar( 0x07, 'out of memory'),
241 YK_ENOSTATUS => dualvar( 0x08, 'no status structure given'),
242 YK_ENOTYETIMPL => dualvar( 0x09, 'not yet implemented'),
243 YK_ECHECKSUM => dualvar( 0x0a, 'checksum mismatch'),
244 YK_EWOULDBLOCK => dualvar( 0x0b, 'operation would block'),
245 YK_EINVALIDCMD => dualvar( 0x0c, 'invalid command for operation'),
246 YK_EMORETHANONE => dualvar( 0x0d, 'expected only one YubiKey but serveral present'),
247 YK_ENODATA => dualvar( 0x0e, 'no data returned from device'),
248
249 CONFIG1_VALID => 0x01,
250 CONFIG2_VALID => 0x02,
251 CONFIG1_TOUCH => 0x04,
252 CONFIG2_TOUCH => 0x08,
253 CONFIG_LED_INV => 0x10,
254 CONFIG_STATUS_MASK => 0x1f,
255 },
256 );
257
258 our %EXPORT_TAGS;
259 my %seen;
260 no strict 'refs'; ## no critic (ProhibitNoStrict)
261 while (my ($tag, $constants) = each %CONSTANTS) {
262 my $prefix = delete $constants->{__prefix};
263 while (my ($name, $value) = each %$constants) {
264 my $val = $value;
265 $val = $val+0 if $tag eq 'icon'; # TODO
266 $name =~ s/^_+//;
267 my $full_name = $prefix ? "${prefix}_${name}" : $name;
268 die "Duplicate constant: $full_name\n" if $seen{$full_name};
269 *{$full_name} = sub() { $value };
270 push @{$EXPORT_TAGS{$tag} //= []}, $full_name;
271 $seen{$full_name}++;
272 }
273 }
274 }
275
276 our %EXPORT_TAGS;
277 push @{$EXPORT_TAGS{header}}, 'kdbx_header';
278 push @{$EXPORT_TAGS{compression}}, 'compression';
279 push @{$EXPORT_TAGS{inner_header}}, 'kdbx_inner_header';
280 push @{$EXPORT_TAGS{icon}}, 'icon';
281
282 $EXPORT_TAGS{all} = [map { @$_ } values %EXPORT_TAGS];
283 our @EXPORT_OK = sort @{$EXPORT_TAGS{all}};
284
285 my %HEADER;
286 for my $header (
287 HEADER_END, HEADER_COMMENT, HEADER_CIPHER_ID, HEADER_COMPRESSION_FLAGS,
288 HEADER_MASTER_SEED, HEADER_TRANSFORM_SEED, HEADER_TRANSFORM_ROUNDS,
289 HEADER_ENCRYPTION_IV, HEADER_INNER_RANDOM_STREAM_KEY, HEADER_STREAM_START_BYTES,
290 HEADER_INNER_RANDOM_STREAM_ID, HEADER_KDF_PARAMETERS, HEADER_PUBLIC_CUSTOM_DATA,
291 ) {
292 $HEADER{$header} = $HEADER{0+$header} = $header;
293 }
294 sub kdbx_header { $HEADER{$_[0]} }
295
296 my %COMPRESSION;
297 for my $compression (COMPRESSION_NONE, COMPRESSION_GZIP) {
298 $COMPRESSION{$compression} = $COMPRESSION{0+$compression} = $compression;
299 }
300 sub compression { $COMPRESSION{$_[0]} }
301
302 my %INNER_HEADER;
303 for my $inner_header (
304 INNER_HEADER_END, INNER_HEADER_INNER_RANDOM_STREAM_ID,
305 INNER_HEADER_INNER_RANDOM_STREAM_KEY, INNER_HEADER_BINARY,
306 ) {
307 $INNER_HEADER{$inner_header} = $INNER_HEADER{0+$inner_header} = $inner_header;
308 }
309 sub kdbx_inner_header { $INNER_HEADER{$_[0]} }
310
311 my %ICON;
312 for my $icon (
313 ICON_PASSWORD, ICON_PACKAGE_NETWORK, ICON_MESSAGEBOX_WARNING, ICON_SERVER, ICON_KLIPPER,
314 ICON_EDU_LANGUAGES, ICON_KCMDF, ICON_KATE, ICON_SOCKET, ICON_IDENTITY, ICON_KONTACT, ICON_CAMERA,
315 ICON_IRKICKFLASH, ICON_KGPG_KEY3, ICON_LAPTOP_POWER, ICON_SCANNER, ICON_MOZILLA_FIREBIRD,
316 ICON_CDROM_UNMOUNT, ICON_DISPLAY, ICON_MAIL_GENERIC, ICON_MISC, ICON_KORGANIZER, ICON_ASCII, ICON_ICONS,
317 ICON_CONNECT_ESTABLISHED, ICON_FOLDER_MAIL, ICON_FILESAVE, ICON_NFS_UNMOUNT, ICON_MESSAGE, ICON_KGPG_TERM,
318 ICON_KONSOLE, ICON_FILEPRINT, ICON_FSVIEW, ICON_RUN, ICON_CONFIGURE, ICON_KRFB, ICON_ARK,
319 ICON_KPERCENTAGE, ICON_SAMBA_UNMOUNT, ICON_HISTORY, ICON_MAIL_FIND, ICON_VECTORGFX, ICON_KCMMEMORY,
320 ICON_TRASHCAN_FULL, ICON_KNOTES, ICON_CANCEL, ICON_HELP, ICON_KPACKAGE, ICON_FOLDER,
321 ICON_FOLDER_BLUE_OPEN, ICON_FOLDER_TAR, ICON_DECRYPTED, ICON_ENCRYPTED, ICON_APPLY, ICON_SIGNATURE,
322 ICON_THUMBNAIL, ICON_KADDRESSBOOK, ICON_VIEW_TEXT, ICON_KGPG, ICON_PACKAGE_DEVELOPMENT, ICON_KFM_HOME,
323 ICON_SERVICES, ICON_TUX, ICON_FEATHER, ICON_APPLE, ICON_W, ICON_MONEY, ICON_CERTIFICATE, ICON_SMARTPHONE,
324 ) {
325 $ICON{$icon} = $ICON{0+$icon} = $icon;
326 }
327 sub icon { $ICON{$_[0] // ''} // ICON_PASSWORD }
328
329 1;
330 __END__
331
332 =head1 SYNOPSIS
333
334 use File::KDBX::Constants qw(:all);
335
336 say KDBX_VERSION_4_1;
337
338 =head1 DESCRIPTION
339
340 This module provides importable constants related to KDBX. Constants can be imported individually or in groups
341 (by tag). The available tags are:
342
343 =for :list
344 * L</:magic>
345 * L</:version>
346 * L</:header>
347 * L</:compression>
348 * L</:cipher>
349 * L</:random_stream>
350 * L</:kdf>
351 * L</:variant_map>
352 * L</:inner_header>
353 * L</:key_file>
354 * L</:history>
355 * L</:icon>
356 * L</:bool>
357 * L</:time>
358 * L</:yubikey>
359 * C<:all> - All of the above
360
361 View the source of this module to see the constant values (but really you shouldn't care).
362
363 =head1 CONSTANTS
364
365 =head2 :magic
366
367 Constants related to identifying the file types:
368
369 =for :list
370 = C<KDBX_SIG1>
371 = C<KDBX_SIG1_FIRST_BYTE>
372 = C<KDBX_SIG2_1>
373 = C<KDBX_SIG2_2>
374
375 =head2 :version
376
377 Constants related to identifying the format version of a file:
378
379 =for :list
380 = C<KDBX_VERSION_2_0>
381 = C<KDBX_VERSION_3_0>
382 = C<KDBX_VERSION_3_1>
383 = C<KDBX_VERSION_4_0>
384 = C<KDBX_VERSION_4_1>
385 = C<KDBX_VERSION_OLDEST>
386 = C<KDBX_VERSION_LATEST>
387 = C<KDBX_VERSION_MAJOR_MASK>
388 = C<KDBX_VERSION_MINOR_MASK>
389
390 =head2 :header
391
392 Constants related to parsing and generating KDBX file headers:
393
394 =for :list
395 = C<HEADER_END>
396 = C<HEADER_COMMENT>
397 = C<HEADER_CIPHER_ID>
398 = C<HEADER_COMPRESSION_FLAGS>
399 = C<HEADER_MASTER_SEED>
400 = C<HEADER_TRANSFORM_SEED>
401 = C<HEADER_TRANSFORM_ROUNDS>
402 = C<HEADER_ENCRYPTION_IV>
403 = C<HEADER_INNER_RANDOM_STREAM_KEY>
404 = C<HEADER_STREAM_START_BYTES>
405 = C<HEADER_INNER_RANDOM_STREAM_ID>
406 = C<HEADER_KDF_PARAMETERS>
407 = C<HEADER_PUBLIC_CUSTOM_DATA>
408
409 =func kdbx_header
410
411 $constant = kdbx_header($number);
412 $constant = kdbx_header($string);
413
414 Get a header constant from an integer or string value.
415
416 =head2 :compression
417
418 Constants related to identifying the compression state of a file:
419
420 =for :list
421 = C<COMPRESSION_NONE>
422 = C<COMPRESSION_GZIP>
423
424 =func compression
425
426 $constant = compression($number);
427 $constant = compression($string);
428
429 Get a compression constant from an integer or string value.
430
431 =head2 :cipher
432
433 Constants related ciphers:
434
435 =for :list
436 = C<CIPHER_UUID_AES128>
437 = C<CIPHER_UUID_AES256>
438 = C<CIPHER_UUID_CHACHA20>
439 = C<CIPHER_UUID_SALSA20>
440 = C<CIPHER_UUID_SERPENT>
441 = C<CIPHER_UUID_TWOFISH>
442
443 =head2 :random_stream
444
445 Constants related to memory protection stream ciphers:
446
447 =for :list
448 = C<STREAM_ID_RC4_VARIANT>
449 This is insecure and not implemented.
450 = C<STREAM_ID_SALSA20>
451 = C<STREAM_ID_CHACHA20>
452 = C<STREAM_SALSA20_IV>
453
454 =head2 :kdf
455
456 Constants related to key derivation functions and configuration:
457
458 =for :list
459 = C<KDF_UUID_AES>
460 = C<KDF_UUID_AES_CHALLENGE_RESPONSE>
461 This is what KeePassXC calls C<KDF_AES_KDBX4>.
462 = C<KDF_UUID_ARGON2D>
463 = C<KDF_UUID_ARGON2ID>
464 = C<KDF_PARAM_UUID>
465 = C<KDF_PARAM_AES_ROUNDS>
466 = C<KDF_PARAM_AES_SEED>
467 = C<KDF_PARAM_ARGON2_SALT>
468 = C<KDF_PARAM_ARGON2_PARALLELISM>
469 = C<KDF_PARAM_ARGON2_MEMORY>
470 = C<KDF_PARAM_ARGON2_ITERATIONS>
471 = C<KDF_PARAM_ARGON2_VERSION>
472 = C<KDF_PARAM_ARGON2_SECRET>
473 = C<KDF_PARAM_ARGON2_ASSOCDATA>
474 = C<KDF_DEFAULT_AES_ROUNDS>
475 = C<KDF_DEFAULT_ARGON2_ITERATIONS>
476 = C<KDF_DEFAULT_ARGON2_MEMORY>
477 = C<KDF_DEFAULT_ARGON2_PARALLELISM>
478 = C<KDF_DEFAULT_ARGON2_VERSION>
479
480 =head2 :variant_map
481
482 Constants related to parsing and generating KDBX4 variant maps:
483
484 =for :list
485 = C<VMAP_VERSION>
486 = C<VMAP_VERSION_MAJOR_MASK>
487 = C<VMAP_TYPE_END>
488 = C<VMAP_TYPE_UINT32>
489 = C<VMAP_TYPE_UINT64>
490 = C<VMAP_TYPE_BOOL>
491 = C<VMAP_TYPE_INT32>
492 = C<VMAP_TYPE_INT64>
493 = C<VMAP_TYPE_STRING>
494 = C<VMAP_TYPE_BYTEARRAY>
495
496 =head2 :inner_header
497
498 Constants related to parsing and generating KDBX4 inner headers:
499
500 =for :list
501 = C<INNER_HEADER_END>
502 = C<INNER_HEADER_INNER_RANDOM_STREAM_ID>
503 = C<INNER_HEADER_INNER_RANDOM_STREAM_KEY>
504 = C<INNER_HEADER_BINARY>
505 = C<INNER_HEADER_BINARY_FLAG_PROTECT>
506
507 =func kdbx_inner_header
508
509 $constant = kdbx_inner_header($number);
510 $constant = kdbx_inner_header($string);
511
512 Get an inner header constant from an integer or string value.
513
514 =head2 :key_file
515
516 Constants related to identifying key file types:
517
518 =for :list
519 = C<KEY_FILE_TYPE_BINARY>
520 = C<KEY_FILE_TYPE_HASHED>
521 = C<KEY_FILE_TYPE_HEX>
522 = C<KEY_FILE_TYPE_XML>
523
524 =head2 :history
525
526 Constants for history-related default values:
527
528 =for :list
529 = C<HISTORY_DEFAULT_MAX_ITEMS>
530 = C<HISTORY_DEFAULT_MAX_SIZE>
531
532 =head2 :icon
533
534 Constants for default icons used by KeePass password safe implementations:
535
536 =for :list
537 = C<ICON_PASSWORD>
538 = C<ICON_PACKAGE_NETWORK>
539 = C<ICON_MESSAGEBOX_WARNING>
540 = C<ICON_SERVER>
541 = C<ICON_KLIPPER>
542 = C<ICON_EDU_LANGUAGES>
543 = C<ICON_KCMDF>
544 = C<ICON_KATE>
545 = C<ICON_SOCKET>
546 = C<ICON_IDENTITY>
547 = C<ICON_KONTACT>
548 = C<ICON_CAMERA>
549 = C<ICON_IRKICKFLASH>
550 = C<ICON_KGPG_KEY3>
551 = C<ICON_LAPTOP_POWER>
552 = C<ICON_SCANNER>
553 = C<ICON_MOZILLA_FIREBIRD>
554 = C<ICON_CDROM_UNMOUNT>
555 = C<ICON_DISPLAY>
556 = C<ICON_MAIL_GENERIC>
557 = C<ICON_MISC>
558 = C<ICON_KORGANIZER>
559 = C<ICON_ASCII>
560 = C<ICON_ICONS>
561 = C<ICON_CONNECT_ESTABLISHED>
562 = C<ICON_FOLDER_MAIL>
563 = C<ICON_FILESAVE>
564 = C<ICON_NFS_UNMOUNT>
565 = C<ICON_MESSAGE>
566 = C<ICON_KGPG_TERM>
567 = C<ICON_KONSOLE>
568 = C<ICON_FILEPRINT>
569 = C<ICON_FSVIEW>
570 = C<ICON_RUN>
571 = C<ICON_CONFIGURE>
572 = C<ICON_KRFB>
573 = C<ICON_ARK>
574 = C<ICON_KPERCENTAGE>
575 = C<ICON_SAMBA_UNMOUNT>
576 = C<ICON_HISTORY>
577 = C<ICON_MAIL_FIND>
578 = C<ICON_VECTORGFX>
579 = C<ICON_KCMMEMORY>
580 = C<ICON_TRASHCAN_FULL>
581 = C<ICON_KNOTES>
582 = C<ICON_CANCEL>
583 = C<ICON_HELP>
584 = C<ICON_KPACKAGE>
585 = C<ICON_FOLDER>
586 = C<ICON_FOLDER_BLUE_OPEN>
587 = C<ICON_FOLDER_TAR>
588 = C<ICON_DECRYPTED>
589 = C<ICON_ENCRYPTED>
590 = C<ICON_APPLY>
591 = C<ICON_SIGNATURE>
592 = C<ICON_THUMBNAIL>
593 = C<ICON_KADDRESSBOOK>
594 = C<ICON_VIEW_TEXT>
595 = C<ICON_KGPG>
596 = C<ICON_PACKAGE_DEVELOPMENT>
597 = C<ICON_KFM_HOME>
598 = C<ICON_SERVICES>
599 = C<ICON_TUX>
600 = C<ICON_FEATHER>
601 = C<ICON_APPLE>
602 = C<ICON_W>
603 = C<ICON_MONEY>
604 = C<ICON_CERTIFICATE>
605 = C<ICON_SMARTPHONE>
606
607 =func icon
608
609 $constant = icon($number);
610 $constant = icon($string);
611
612 Get an icon constant from an integer or string value.
613
614 =head2 :bool
615
616 Boolean values:
617
618 =for :list
619 = C<FALSE>
620 = C<TRUE>
621
622 =head2 :time
623
624 Constants related to time:
625
626 =for :list
627 = C<TIME_SECONDS_AD1_TO_UNIX_EPOCH>
628
629 =head2 :yubikey
630
631 Constants related to working with YubiKeys:
632
633 =for :list
634 = C<YUBICO_VID>
635 = C<YUBIKEY_PID>
636 = C<NEO_OTP_PID>
637 = C<NEO_OTP_CCID_PID>
638 = C<NEO_CCID_PID>
639 = C<NEO_U2F_PID>
640 = C<NEO_OTP_U2F_PID>
641 = C<NEO_U2F_CCID_PID>
642 = C<NEO_OTP_U2F_CCID_PID>
643 = C<YK4_OTP_PID>
644 = C<YK4_U2F_PID>
645 = C<YK4_OTP_U2F_PID>
646 = C<YK4_CCID_PID>
647 = C<YK4_OTP_CCID_PID>
648 = C<YK4_U2F_CCID_PID>
649 = C<YK4_OTP_U2F_CCID_PID>
650 = C<PLUS_U2F_OTP_PID>
651 = C<ONLYKEY_VID>
652 = C<ONLYKEY_PID>
653 = C<YK_EUSBERR>
654 = C<YK_EWRONGSIZ>
655 = C<YK_EWRITEERR>
656 = C<YK_ETIMEOUT>
657 = C<YK_ENOKEY>
658 = C<YK_EFIRMWARE>
659 = C<YK_ENOMEM>
660 = C<YK_ENOSTATUS>
661 = C<YK_ENOTYETIMPL>
662 = C<YK_ECHECKSUM>
663 = C<YK_EWOULDBLOCK>
664 = C<YK_EINVALIDCMD>
665 = C<YK_EMORETHANONE>
666 = C<YK_ENODATA>
667 = C<CONFIG1_VALID>
668 = C<CONFIG2_VALID>
669 = C<CONFIG1_TOUCH>
670 = C<CONFIG2_TOUCH>
671 = C<CONFIG_LED_INV>
672 = C<CONFIG_STATUS_MASK>
673
674 =cut
This page took 0.06911 seconds and 4 git commands to generate.