Hex Artifact Content
Not logged in

Artifact 3db8ba6f691b0135f8df1f591c21c3642323d865:


0000: 2f 2a 20 68 61 73 68 5f 63 68 65 63 6b 2e 68 20  /* hash_check.h 
0010: 2d 20 66 75 6e 63 74 69 6f 6e 73 20 74 6f 20 70  - functions to p
0020: 61 72 73 65 20 61 20 66 69 6c 65 20 77 69 74 68  arse a file with
0030: 20 68 61 73 68 20 73 75 6d 73 20 74 6f 20 76 65   hash sums to ve
0040: 72 69 66 79 20 69 74 20 2a 2f 0a 23 69 66 6e 64  rify it */.#ifnd
0050: 65 66 20 48 41 53 48 5f 43 48 45 43 4b 5f 48 0a  ef HASH_CHECK_H.
0060: 23 64 65 66 69 6e 65 20 48 41 53 48 5f 43 48 45  #define HASH_CHE
0070: 43 4b 5f 48 0a 0a 23 69 6e 63 6c 75 64 65 20 3c  CK_H..#include <
0080: 73 74 64 69 6e 74 2e 68 3e 0a 0a 23 69 66 64 65  stdint.h>..#ifde
0090: 66 20 5f 5f 63 70 6c 75 73 70 6c 75 73 0a 65 78  f __cplusplus.ex
00a0: 74 65 72 6e 20 22 43 22 20 7b 0a 23 65 6e 64 69  tern "C" {.#endi
00b0: 66 0a 0a 2f 2a 20 62 69 74 20 66 6c 61 67 73 20  f../* bit flags 
00c0: 66 6f 72 20 68 61 73 68 5f 63 68 65 63 6b 2e 66  for hash_check.f
00d0: 6c 61 67 73 20 2a 2f 0a 23 64 65 66 69 6e 65 20  lags */.#define 
00e0: 48 43 5f 48 41 53 5f 46 49 4c 45 53 49 5a 45 20  HC_HAS_FILESIZE 
00f0: 31 0a 23 64 65 66 69 6e 65 20 48 43 5f 48 41 53  1.#define HC_HAS
0100: 5f 45 4d 42 43 52 43 33 32 20 32 0a 23 64 65 66  _EMBCRC32 2.#def
0110: 69 6e 65 20 48 43 5f 57 52 4f 4e 47 5f 46 49 4c  ine HC_WRONG_FIL
0120: 45 53 49 5a 45 20 34 0a 23 64 65 66 69 6e 65 20  ESIZE 4.#define 
0130: 48 43 5f 57 52 4f 4e 47 5f 45 4d 42 43 52 43 33  HC_WRONG_EMBCRC3
0140: 32 20 38 0a 23 64 65 66 69 6e 65 20 48 43 5f 57  2 8.#define HC_W
0150: 52 4f 4e 47 5f 48 41 53 48 45 53 20 31 36 0a 23  RONG_HASHES 16.#
0160: 64 65 66 69 6e 65 20 48 43 5f 46 41 49 4c 45 44  define HC_FAILED
0170: 28 66 6c 61 67 73 29 20 28 28 66 6c 61 67 73 29  (flags) ((flags)
0180: 20 26 20 28 48 43 5f 57 52 4f 4e 47 5f 46 49 4c   & (HC_WRONG_FIL
0190: 45 53 49 5a 45 20 7c 20 48 43 5f 57 52 4f 4e 47  ESIZE | HC_WRONG
01a0: 5f 45 4d 42 43 52 43 33 32 20 7c 20 48 43 5f 57  _EMBCRC32 | HC_W
01b0: 52 4f 4e 47 5f 48 41 53 48 45 53 29 29 0a 0a 23  RONG_HASHES))..#
01c0: 64 65 66 69 6e 65 20 48 43 5f 4d 41 58 5f 48 41  define HC_MAX_HA
01d0: 53 48 45 53 20 33 32 0a 0a 2f 2a 2a 0a 20 2a 20  SHES 32../**. * 
01e0: 50 61 72 73 65 64 20 68 61 73 68 20 76 61 6c 75  Parsed hash valu
01f0: 65 2e 0a 20 2a 2f 0a 74 79 70 65 64 65 66 20 73  e.. */.typedef s
0200: 74 72 75 63 74 20 68 61 73 68 5f 76 61 6c 75 65  truct hash_value
0210: 0a 7b 0a 09 75 6e 73 69 67 6e 65 64 20 68 61 73  .{..unsigned has
0220: 68 5f 69 64 3b 20 2f 2a 20 74 68 65 20 69 64 20  h_id; /* the id 
0230: 6f 66 20 68 61 73 68 2c 20 69 66 20 69 74 20 77  of hash, if it w
0240: 61 73 20 64 65 74 65 63 74 65 64 20 2a 2f 0a 09  as detected */..
0250: 75 6e 73 69 67 6e 65 64 20 73 68 6f 72 74 20 6f  unsigned short o
0260: 66 66 73 65 74 3b 0a 09 75 6e 73 69 67 6e 65 64  ffset;..unsigned
0270: 20 63 68 61 72 20 6c 65 6e 67 74 68 3b 0a 09 75   char length;..u
0280: 6e 73 69 67 6e 65 64 20 63 68 61 72 20 66 6f 72  nsigned char for
0290: 6d 61 74 3b 0a 7d 20 68 61 73 68 5f 76 61 6c 75  mat;.} hash_valu
02a0: 65 3b 0a 0a 73 74 72 75 63 74 20 72 68 61 73 68  e;..struct rhash
02b0: 5f 63 6f 6e 74 65 78 74 3b 0a 0a 2f 2a 2a 0a 20  _context;../**. 
02c0: 2a 20 50 61 72 73 65 64 20 66 69 6c 65 20 69 6e  * Parsed file in
02d0: 66 6f 2c 20 6c 69 6b 65 20 74 68 65 20 70 61 74  fo, like the pat
02e0: 68 2c 20 73 69 7a 65 20 61 6e 64 20 66 69 6c 65  h, size and file
02f0: 20 68 61 73 68 20 76 61 6c 75 65 73 2e 0a 20 2a   hash values.. *
0300: 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74  /.typedef struct
0310: 20 68 61 73 68 5f 63 68 65 63 6b 0a 7b 0a 09 63   hash_check.{..c
0320: 68 61 72 20 2a 66 69 6c 65 5f 70 61 74 68 3b 20  har *file_path; 
0330: 2f 2a 20 70 61 72 73 65 64 20 66 69 6c 65 20 70  /* parsed file p
0340: 61 74 68 20 2a 2f 0a 09 75 69 6e 74 36 34 5f 74  ath */..uint64_t
0350: 20 66 69 6c 65 5f 73 69 7a 65 3b 20 2f 2a 20 70   file_size; /* p
0360: 61 72 73 65 64 20 66 69 6c 65 20 73 69 7a 65 2c  arsed file size,
0370: 20 65 2e 67 2e 20 66 72 6f 6d 20 6d 61 67 6e 65   e.g. from magne
0380: 74 20 6c 69 6e 6b 20 2a 2f 0a 09 75 6e 73 69 67  t link */..unsig
0390: 6e 65 64 20 68 61 73 68 5f 6d 61 73 6b 3b 20 2f  ned hash_mask; /
03a0: 2a 20 74 68 65 20 6d 61 73 6b 20 6f 66 20 68 61  * the mask of ha
03b0: 73 68 20 69 64 73 20 74 6f 20 76 65 72 69 66 79  sh ids to verify
03c0: 20 61 67 61 69 6e 73 74 20 2a 2f 0a 09 75 6e 73   against */..uns
03d0: 69 67 6e 65 64 20 66 6c 61 67 73 3b 20 2f 2a 20  igned flags; /* 
03e0: 62 69 74 20 66 6c 61 67 73 20 2a 2f 0a 09 75 6e  bit flags */..un
03f0: 73 69 67 6e 65 64 20 65 6d 62 65 64 64 65 64 5f  signed embedded_
0400: 63 72 63 33 32 3b 20 20 2f 2a 20 43 52 43 33 32  crc32;  /* CRC32
0410: 20 65 6d 62 65 64 64 65 64 20 69 6e 74 6f 20 66   embedded into f
0420: 69 6c 65 6e 61 6d 65 20 2a 2f 0a 09 63 68 61 72  ilename */..char
0430: 20 2a 64 61 74 61 3b 20 2f 2a 20 74 68 65 20 62   *data; /* the b
0440: 75 66 66 65 72 20 77 69 74 68 20 74 68 65 20 63  uffer with the c
0450: 75 72 72 65 6e 74 20 68 61 73 68 20 66 69 6c 65  urrent hash file
0460: 20 6c 69 6e 65 20 2a 2f 0a 09 75 6e 73 69 67 6e   line */..unsign
0470: 65 64 20 66 6f 75 6e 64 5f 68 61 73 68 5f 69 64  ed found_hash_id
0480: 73 3b 20 2f 2a 20 62 69 74 20 6d 61 73 6b 20 66  s; /* bit mask f
0490: 6f 72 20 6d 61 74 63 68 65 64 20 68 61 73 68 20  or matched hash 
04a0: 69 64 73 20 2a 2f 0a 09 75 6e 73 69 67 6e 65 64  ids */..unsigned
04b0: 20 77 72 6f 6e 67 5f 68 61 73 68 65 73 3b 20 20   wrong_hashes;  
04c0: 20 2f 2a 20 62 69 74 20 6d 61 73 6b 20 66 6f 72   /* bit mask for
04d0: 20 6d 69 73 6d 61 74 63 68 65 64 20 68 61 73 68   mismatched hash
04e0: 65 73 20 2a 2f 0a 09 69 6e 74 20 68 61 73 68 65  es */..int hashe
04f0: 73 5f 6e 75 6d 3b 20 2f 2a 20 6e 75 6d 62 65 72  s_num; /* number
0500: 20 6f 66 20 70 61 72 73 65 64 20 68 61 73 68 65   of parsed hashe
0510: 73 20 2a 2f 0a 09 68 61 73 68 5f 76 61 6c 75 65  s */..hash_value
0520: 20 68 61 73 68 65 73 5b 48 43 5f 4d 41 58 5f 48   hashes[HC_MAX_H
0530: 41 53 48 45 53 5d 3b 0a 7d 20 68 61 73 68 5f 63  ASHES];.} hash_c
0540: 68 65 63 6b 3b 0a 0a 69 6e 74 20 68 61 73 68 5f  heck;..int hash_
0550: 63 68 65 63 6b 5f 70 61 72 73 65 5f 6c 69 6e 65  check_parse_line
0560: 28 63 68 61 72 2a 20 6c 69 6e 65 2c 20 68 61 73  (char* line, has
0570: 68 5f 63 68 65 63 6b 2a 20 68 61 73 68 65 73 2c  h_check* hashes,
0580: 20 69 6e 74 20 63 68 65 63 6b 5f 65 6f 6c 29 3b   int check_eol);
0590: 0a 69 6e 74 20 68 61 73 68 5f 63 68 65 63 6b 5f  .int hash_check_
05a0: 76 65 72 69 66 79 28 68 61 73 68 5f 63 68 65 63  verify(hash_chec
05b0: 6b 2a 20 68 61 73 68 65 73 2c 20 73 74 72 75 63  k* hashes, struc
05c0: 74 20 72 68 61 73 68 5f 63 6f 6e 74 65 78 74 2a  t rhash_context*
05d0: 20 63 74 78 29 3b 0a 0a 76 6f 69 64 20 72 68 61   ctx);..void rha
05e0: 73 68 5f 62 61 73 65 33 32 5f 74 6f 5f 62 79 74  sh_base32_to_byt
05f0: 65 28 63 6f 6e 73 74 20 63 68 61 72 2a 20 73 74  e(const char* st
0600: 72 2c 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  r, unsigned char
0610: 2a 20 62 69 6e 2c 20 69 6e 74 20 6c 65 6e 29 3b  * bin, int len);
0620: 0a 76 6f 69 64 20 72 68 61 73 68 5f 68 65 78 5f  .void rhash_hex_
0630: 74 6f 5f 62 79 74 65 28 63 6f 6e 73 74 20 63 68  to_byte(const ch
0640: 61 72 2a 20 73 74 72 2c 20 75 6e 73 69 67 6e 65  ar* str, unsigne
0650: 64 20 63 68 61 72 2a 20 62 69 6e 2c 20 69 6e 74  d char* bin, int
0660: 20 6c 65 6e 29 3b 0a 75 6e 73 69 67 6e 65 64 20   len);.unsigned 
0670: 67 65 74 5f 63 72 63 33 32 28 73 74 72 75 63 74  get_crc32(struct
0680: 20 72 68 61 73 68 5f 63 6f 6e 74 65 78 74 2a 20   rhash_context* 
0690: 63 74 78 29 3b 0a 0a 2f 2a 20 6e 6f 74 65 3a 20  ctx);../* note: 
06a0: 49 53 5f 48 45 58 28 29 20 69 73 20 64 65 66 69  IS_HEX() is defi
06b0: 6e 65 64 20 6f 6e 20 41 53 43 49 49 2d 38 20 77  ned on ASCII-8 w
06c0: 68 69 6c 65 20 69 73 78 64 69 67 69 74 28 29 20  hile isxdigit() 
06d0: 6f 6e 6c 79 20 77 68 65 6e 20 69 73 61 73 63 69  only when isasci
06e0: 69 28 29 3d 3d 74 72 75 65 20 2a 2f 0a 23 64 65  i()==true */.#de
06f0: 66 69 6e 65 20 49 53 5f 48 45 58 28 63 29 20 28  fine IS_HEX(c) (
0700: 28 63 29 20 3c 3d 20 27 39 27 20 3f 20 28 63 29  (c) <= '9' ? (c)
0710: 20 3e 3d 20 27 30 27 20 3a 20 28 75 6e 73 69 67   >= '0' : (unsig
0720: 6e 65 64 29 28 28 28 63 29 20 2d 20 27 41 27 29  ned)(((c) - 'A')
0730: 20 26 20 7e 30 78 32 30 29 20 3c 3d 20 28 27 46   & ~0x20) <= ('F
0740: 27 20 2d 20 27 41 27 20 2b 20 30 55 29 29 0a 23  ' - 'A' + 0U)).#
0750: 64 65 66 69 6e 65 20 49 53 5f 42 41 53 45 33 32  define IS_BASE32
0760: 28 63 29 20 28 28 28 63 29 20 3c 3d 20 27 37 27  (c) (((c) <= '7'
0770: 20 3f 20 28 27 32 27 20 3c 3d 20 28 63 29 29 20   ? ('2' <= (c)) 
0780: 3a 20 28 75 6e 73 69 67 6e 65 64 29 28 28 28 63  : (unsigned)(((c
0790: 29 20 2d 20 27 41 27 29 20 26 20 7e 30 78 32 30  ) - 'A') & ~0x20
07a0: 29 20 3c 3d 20 28 27 5a 27 20 2d 20 27 41 27 20  ) <= ('Z' - 'A' 
07b0: 2b 20 30 55 29 29 29 0a 0a 23 69 66 64 65 66 20  + 0U)))..#ifdef 
07c0: 5f 5f 63 70 6c 75 73 70 6c 75 73 0a 7d 20 2f 2a  __cplusplus.} /*
07d0: 20 65 78 74 65 72 6e 20 22 43 22 20 2a 2f 0a 23   extern "C" */.#
07e0: 65 6e 64 69 66 20 2f 2a 20 5f 5f 63 70 6c 75 73  endif /* __cplus
07f0: 70 6c 75 73 20 2a 2f 0a 0a 23 65 6e 64 69 66 20  plus */..#endif 
0800: 2f 2a 20 48 41 53 48 5f 43 48 45 43 4b 5f 48 20  /* HASH_CHECK_H 
0810: 2a 2f 0a                                         */.