24 #include <openssl/err.h>
25 #include <openssl/hmac.h>
42 #define USE_RESOWNER_FOR_HMAC
43 #define ALLOC(size) MemoryContextAlloc(TopMemoryContext, size)
44 #define FREE(ptr) pfree(ptr)
46 #define ALLOC(size) malloc(size)
47 #define FREE(ptr) free(ptr)
66 #ifdef USE_RESOWNER_FOR_HMAC
72 #ifdef USE_RESOWNER_FOR_HMAC
77 .
name =
"OpenSSL HMAC context",
107 return ERR_reason_error_string(ecode);
138 #ifdef USE_RESOWNER_FOR_HMAC
150 (
errcode(ERRCODE_OUT_OF_MEMORY),
151 errmsg(
"out of memory")));
157 #ifdef USE_RESOWNER_FOR_HMAC
181 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_md5(), NULL);
184 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_sha1(), NULL);
187 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_sha224(), NULL);
190 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_sha256(), NULL);
193 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_sha384(), NULL);
196 status = HMAC_Init_ex(ctx->
hmacctx,
key,
len, EVP_sha512(), NULL);
320 #ifdef USE_RESOWNER_FOR_HMAC
339 return _(
"out of memory");
353 return _(
"destination buffer too small");
355 return _(
"OpenSSL failure");
364 #ifdef USE_RESOWNER_FOR_HMAC
#define Assert(condition)
static void PGresult * res
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
#define ereport(elevel,...)
static void ResOwnerReleaseHMAC(Datum res)
pg_hmac_ctx * pg_hmac_create(pg_cryptohash_type type)
const char * pg_hmac_error(pg_hmac_ctx *ctx)
static const ResourceOwnerDesc hmac_resowner_desc
static void ResourceOwnerForgetHMAC(ResourceOwner owner, pg_hmac_ctx *ctx)
static const char * SSLerrmessage(unsigned long ecode)
static void ResourceOwnerRememberHMAC(ResourceOwner owner, pg_hmac_ctx *ctx)
void pg_hmac_free(pg_hmac_ctx *ctx)
int pg_hmac_update(pg_hmac_ctx *ctx, const uint8 *data, size_t len)
int pg_hmac_init(pg_hmac_ctx *ctx, const uint8 *key, size_t len)
int pg_hmac_final(pg_hmac_ctx *ctx, uint8 *dest, size_t len)
#define MD5_DIGEST_LENGTH
void explicit_bzero(void *buf, size_t len)
static Datum PointerGetDatum(const void *X)
static Pointer DatumGetPointer(Datum X)
ResourceOwner CurrentResourceOwner
void ResourceOwnerForget(ResourceOwner owner, Datum value, const ResourceOwnerDesc *kind)
void ResourceOwnerRemember(ResourceOwner owner, Datum value, const ResourceOwnerDesc *kind)
void ResourceOwnerEnlarge(ResourceOwner owner)
#define RELEASE_PRIO_HMAC_CONTEXTS
@ RESOURCE_RELEASE_BEFORE_LOCKS
#define SHA1_DIGEST_LENGTH
#define PG_SHA256_DIGEST_LENGTH
#define PG_SHA384_DIGEST_LENGTH
#define PG_SHA512_DIGEST_LENGTH
#define PG_SHA224_DIGEST_LENGTH