| /*------------------------------------------------------------------------- |
| * |
| * checksum_helper.h |
| * Compute a checksum of any of various types using common routines |
| * |
| * Portions Copyright (c) 2016-2023, PostgreSQL Global Development Group |
| * |
| * IDENTIFICATION |
| * src/include/common/checksum_helper.h |
| * |
| *------------------------------------------------------------------------- |
| */ |
| |
| #ifndef CHECKSUM_HELPER_H |
| #define CHECKSUM_HELPER_H |
| |
| #include "common/cryptohash.h" |
| #include "common/sha2.h" |
| #include "port/pg_crc32c.h" |
| |
| /* |
| * Supported checksum types. It's not necessarily the case that code using |
| * these functions needs a cryptographically strong checksum; it may only |
| * need to detect accidental modification. That's why we include CRC-32C: it's |
| * much faster than any of the other algorithms. On the other hand, we omit |
| * MD5 here because any new that does need a cryptographically strong checksum |
| * should use something better. |
| */ |
| typedef enum pg_checksum_type |
| { |
| CHECKSUM_TYPE_NONE, |
| CHECKSUM_TYPE_CRC32C, |
| CHECKSUM_TYPE_SHA224, |
| CHECKSUM_TYPE_SHA256, |
| CHECKSUM_TYPE_SHA384, |
| CHECKSUM_TYPE_SHA512, |
| CHECKSUM_TYPE_SM3 |
| } pg_checksum_type; |
| |
| /* |
| * This is just a union of all applicable context types. |
| */ |
| typedef union pg_checksum_raw_context |
| { |
| pg_crc32c c_crc32c; |
| pg_cryptohash_ctx *c_sha2; |
| } pg_checksum_raw_context; |
| |
| /* |
| * This structure provides a convenient way to pass the checksum type and the |
| * checksum context around together. |
| */ |
| typedef struct pg_checksum_context |
| { |
| pg_checksum_type type; |
| pg_checksum_raw_context raw_context; |
| } pg_checksum_context; |
| |
| /* |
| * This is the longest possible output for any checksum algorithm supported |
| * by this file. |
| */ |
| #define PG_CHECKSUM_MAX_LENGTH PG_SHA512_DIGEST_LENGTH |
| |
| extern bool pg_checksum_parse_type(char *name, pg_checksum_type *); |
| extern char *pg_checksum_type_name(pg_checksum_type); |
| |
| extern int pg_checksum_init(pg_checksum_context *, pg_checksum_type); |
| extern int pg_checksum_update(pg_checksum_context *, const uint8 *input, |
| size_t len); |
| extern int pg_checksum_final(pg_checksum_context *, uint8 *output); |
| |
| #endif |