34#ifndef _QORE_QL_CRYPTO_H
36#define _QORE_QL_CRYPTO_H
38#include <openssl/err.h>
39#include <openssl/evp.h>
40#include <openssl/des.h>
41#include <openssl/hmac.h>
43#define MD2_ERR "MD2-DIGEST-ERROR"
44#define MD4_ERR "MD4-DIGEST-ERROR"
45#define MD5_ERR "MD5-DIGEST-ERROR"
46#define SHA_ERR "SHA-DIGEST-ERROR"
47#define SHA1_ERR "SHA1-DIGEST-ERROR"
48static const char SHA224_ERR[] =
"SHA224-DIGEST-ERROR";
49static const char SHA256_ERR[] =
"SHA256-DIGEST-ERROR";
50static const char SHA384_ERR[] =
"SHA384-DIGEST-ERROR";
51static const char SHA512_ERR[] =
"SHA512-DIGEST-ERROR";
52#define DSS_ERR "DSS-DIGEST-ERROR"
53#define DSS1_ERR "DSS1-DIGEST-ERROR"
54static const char MDC2_ERR[] =
"MDC2-DIGEST-ERROR";
55#define RIPEMD160_ERR "RIPEMD160-DIGEST-ERROR"
64 unsigned char md_value[EVP_MAX_MD_SIZE > HMAC_MAX_MD_CBLOCK ? EVP_MAX_MD_SIZE : HMAC_MAX_MD_CBLOCK];
67 DLLLOCAL
void setInput(
const QoreString& str) {
68 input = (
unsigned char*)str.
c_str();
73 input = (
unsigned char*)b.
getPtr();
77 DLLLOCAL
void setInput(
const QoreValue pt) {
87 DLLLOCAL
unsigned int size()
const {
91 DLLLOCAL
const void* getBuffer()
const {
92 return (
const void*)md_value;
95 DLLLOCAL
const void* c_str()
const {
96 return (
const void*)md_value;
99 DLLLOCAL
void getString(
QoreString& str)
const {
100 for (
unsigned i = 0; i < md_len; i++)
101 str.
sprintf(
"%02x", md_value[i]);
106 for (
unsigned i = 0; i < md_len; i++)
107 str->
sprintf(
"%02x", md_value[i]);
114 b->
append(md_value, md_len);
121 DLLLOCAL QoreEvpHelper() : mdctx(EVP_MD_CTX_create()) {
124 DLLLOCAL ~QoreEvpHelper() {
126 EVP_MD_CTX_destroy(mdctx);
130 DLLLOCAL EVP_MD_CTX* operator*() {
134 DLLLOCAL
const EVP_MD_CTX* operator*()
const {
142class QoreEvpCipherCtxHelper {
144 DLLLOCAL QoreEvpCipherCtxHelper() : ctx(EVP_CIPHER_CTX_new()) {
146 EVP_CIPHER_CTX_init(ctx);
150 DLLLOCAL ~QoreEvpCipherCtxHelper() {
152 EVP_CIPHER_CTX_free(ctx);
156 DLLLOCAL EVP_CIPHER_CTX* operator*() {
160 DLLLOCAL
const EVP_CIPHER_CTX* operator*()
const {
164 DLLLOCAL
operator bool()
const {
165 return ctx ? true :
false;
172class DigestHelper :
public BaseHelper {
174 DLLLOCAL DigestHelper(
const QoreValue v) {
182 DLLLOCAL DigestHelper(
const QoreString& str) {
190 DLLLOCAL DigestHelper(
const void* buf,
size_t len) {
191 input = (
unsigned char*)buf;
195 DLLLOCAL
int doDigest(
const char* err,
const EVP_MD* md,
ExceptionSink* xsink =
nullptr) {
200 xsink->raiseException(err,
"error creating digest object");
202 printd(0,
"DigestHelper::doDigest(): error creating digest object\n");
207 if (!EVP_DigestInit_ex(*mdctx, md,
nullptr)) {
209 xsink->raiseException(err,
"error initializing digest");
211 printd(0,
"DigestHelper::doDigest(): error initializing digest (%p, %p)\n", *mdctx, md);
215 if (!EVP_DigestUpdate(*mdctx, input, input_len) || !EVP_DigestFinal_ex(*mdctx, md_value, &md_len)) {
217 xsink->raiseException(err,
"error calculating digest");
219 printd(0,
"DigestHelper::doDigest(): error calculating digest\n");
228#if !defined(OPENSSL_VERSION_MAJOR) || OPENSSL_VERSION_MAJOR < 3
229class QoreHmacHelper {
231 DLLLOCAL QoreHmacHelper() {
232#if defined(HAVE_OPENSSL_INIT_CRYPTO)
233 ctx = HMAC_CTX_new();
239 DLLLOCAL ~QoreHmacHelper() {
240#ifdef HAVE_OPENSSL_INIT_CRYPTO
243 HMAC_CTX_cleanup(&ctx);
247 DLLLOCAL HMAC_CTX* operator*() {
248#ifdef HAVE_OPENSSL_INIT_CRYPTO
255 DLLLOCAL
const HMAC_CTX* operator*()
const {
256#ifdef HAVE_OPENSSL_INIT_CRYPTO
264#ifdef HAVE_OPENSSL_INIT_CRYPTO
265 typedef HMAC_CTX* q_hmac_t;
267 typedef HMAC_CTX q_hmac_t;
274class HMACHelper :
public BaseHelper {
292 DLLLOCAL HMACHelper(
const void* buf,
size_t len) {
293 input = (
unsigned char*)buf;
297 DLLLOCAL
int doHMAC(
const char* err,
const char* digest,
const char* ptr,
size_t len,
ExceptionSink* xsink);
holds arbitrary binary data
Definition: BinaryNode.h:41
DLLEXPORT void append(const void *nptr, size_t size)
resizes the object and appends a copy of the data passed to the object
DLLEXPORT size_t size() const
returns the number of bytes in the object
DLLEXPORT const void * getPtr() const
returns the pointer to the data
container for holding Qore-language exception information and also for registering a "thread_exit" ca...
Definition: ExceptionSink.h:50
This is the list container type in Qore, dynamically allocated only, reference counted.
Definition: QoreListNode.h:52
contains constants, classes, and subnamespaces in QoreProgram objects
Definition: QoreNamespace.h:65
DLLLOCAL detail::QoreValueCastHelper< T >::Result get()
returns the value as the given type
Definition: QoreValue.h:214
DLLEXPORT qore_type_t getType() const
returns the type of value contained
Qore's string type supported by the QoreEncoding class.
Definition: QoreString.h:93
DLLEXPORT const char * c_str() const
returns the string's buffer; this data should not be changed
DLLEXPORT size_t strlen() const
returns number of bytes in the string (not including the null pointer)
DLLEXPORT int sprintf(const char *fmt,...)
this will concatentate a formatted string to the existing string according to the format string and t...
Qore's string value type, reference counted, dynamically-allocated only.
Definition: QoreStringNode.h:50
const qore_type_t NT_BINARY
type value for BinaryNode
Definition: node_types.h:49
const qore_type_t NT_STRING
type value for QoreStringNode
Definition: node_types.h:45
static QoreValue get_param_value(const QoreListNode *n, size_t i)
returns the argument in the position given or 0 if there is none
Definition: params.h:78
The main value class in Qore, designed to be passed by value.
Definition: QoreValue.h:276