Example of PQC signature and verification with SLH-DSA.
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#define HOST_ADDR "127.0.0.1"
#define USER_ID "master"
#define USER_PWD "12345678"
#define KEY_ID "test_key"
#define PUB_KEY_ID "test_pub_key"
{
int nRet = 0;
if (nRet) {
printf("Falha na funcao: DSetKeyParam (DKP_PQC_SIG_PH) \nCodigo de erro: %d\n", nRet);
return nRet;
}
printf("Parametro DKP_PQC_SIG_PH definido com sucesso.\n");
if (pbCtx && cbCtx > 0) {
if (nRet) {
printf("Falha na funcao: DSetKeyParam (DKP_PQC_SIG_CTX) \nCodigo de erro: %d\n", nRet);
return nRet;
}
printf("Parametro DKP_PQC_SIG_CTX definido com sucesso.\n");
} else {
printf("Contexto de assinatura PQC nao fornecido.\n");
}
return nRet;
}
int main()
{
int nRet = 0;
DWORD cbSignature =
sizeof(pbSignature);
BYTE pbCtx[10] = {0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A};
DWORD cbCtx =
sizeof(pbCtx);
if (nRet){
printf("Falha na funcao: DInitialize \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Bibliotecas inicializadas.\n");
strncpy(authPwd.szAddr, HOST_ADDR, sizeof(authPwd.szAddr));
strncpy(authPwd.szUserId, USER_ID, sizeof(authPwd.szUserId));
strncpy(authPwd.szPassword, USER_PWD, sizeof(authPwd.szPassword));
if (nRet){
printf("Falha na funcao: DOpenSession \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Sessao com o Dinamo estabelecida.\n");
if (nRet){
printf("Falha na funcao: DCreateHash \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Contexto de hash criado.\n");
cbData = sizeof(pbData);
memset(pbData, 'A', cbData);
if (nRet){
printf("Falha na funcao: DHashData \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Dados adicionados ao hash.\n");
if (nRet){
printf("Falha na funcao: DGenerateKey \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Chave criada com sucesso.\n");
nRet = SetPqcKeyParams(hKey, bPh, pbCtx, cbCtx);
if (nRet){
printf("Falha ao definir parametros PQC na chave privada.\nCodigo de erro: %d\n", nRet);
goto clean;
}
nRet =
DSignHash(hHash, hKey, 0, pbSignature, &cbSignature);
if (nRet){
printf("Falha na funcao: DSignHash \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Buffer assinado.\n");
if (nRet){
printf("Falha na funcao: DExportKey \nCodigo de erro: %d\n",nRet);
goto clean;
}
pbPubKey = (
BYTE *)malloc(cbPubKey);
if (pbPubKey == NULL){
printf("Falha ao alocar memoria para a chave publica.\n");
nRet = -1;
goto clean;
}
if (nRet){
printf("Falha na funcao: DExportKey \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Chave publica exportada com sucesso.\n");
cbPubKey, &hPubKey);
if (nRet){
printf("Falha na funcao: DImportKey \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Chave publica importada com sucesso.\n");
nRet = SetPqcKeyParams(hPubKey, bPh, pbCtx, cbCtx);
if (nRet)
{
printf("Falha ao definir parametros PQC na chave pública.\nCodigo de erro: %d\n", nRet);
goto clean;
}
if (nRet){
printf("Falha na funcao: DVerifySignature \nCodigo de erro: %d\n",nRet);
goto clean;
}
printf("Assinatura verificada com sucesso.\n");
clean:
if (pbPubKey)
free(pbPubKey);
if (hKey){
printf("Contexto da chave privada liberado.\n");
}
if (hPubKey){
printf("Contexto da chave publica liberado.\n");
}
if (hHash){
printf("Contexto de hash liberado.\n");
}
if (hSession){
printf("Sessao encerrada.\n");
}
printf("Bibliotecas finalizada.\n");
return nRet;
}
Application Programming Interface (API) do HSM Dinamo.
void * HSESSIONCTX
Definição dinamo.h:68
#define DEFAULT_PORT
Definição dinamo.h:2021
#define PUBLICKEY_BLOB
Definição dinamo.h:1447
#define DKP_PQC_SIG_PH
Definição dinamo.h:1559
#define REMOVE_FROM_HSM
Definição dinamo.h:1532
unsigned char BYTE
Definição dinamo.h:45
#define ALG_SLH_DSA_SHA2_128S
Definição dinamo.h:1193
#define PUBLICKEY_BLOB_HSM
Definição dinamo.h:1457
unsigned int DWORD
Definição dinamo.h:46
void * HHASHCTX
Definição dinamo.h:69
#define ALG_IDENTITY_FUNC
Definição dinamo.h:907
#define ENCRYPTED_CONN
Definição dinamo.h:578
#define SS_USER_PWD
Definição dinamo.h:569
#define DN_SLH_DSA_128S_SIG_LEN
Definição dinamo.h:1034
#define ALG_OBJ_PUBKEY_BLOB
Definição dinamo.h:1220
#define DKP_PQC_CTX
Definição dinamo.h:1560
void * HKEYCTX
Definição dinamo.h:70
#define EXPORTABLE_KEY
Definição dinamo.h:1492
int AAP_API DCreateHash(HSESSIONCTX hSession, int nAlgId, HKEYCTX hKey, DWORD dwFlags, HHASHCTX *hHash)
int AAP_API DDestroyHash(HHASHCTX *phHash)
int AAP_API DHashData(HHASHCTX hHash, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DSignHash(HHASHCTX hHash, HKEYCTX hKey, DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen)
int AAP_API DVerifySignature(HHASHCTX hHash, BYTE *pbSignature, DWORD dwSigLen, HKEYCTX hPubKey, DWORD dwFlags)
int AAP_API DSetKeyParam(HKEYCTX hKey, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DGenerateKey(HSESSIONCTX hSession, char *szKeyId, int nAlgId, DWORD dwFlags, HKEYCTX *phKey)
int AAP_API DDestroyKey(HKEYCTX *phKey, DWORD dwFlags)
int AAP_API DImportKey(HSESSIONCTX hSession, char *szKeyId, HKEYCTX hKEKey, DWORD dwBlobType, int nAlgId, DWORD dwFlags, BYTE *pbData, DWORD dwDataLen, HKEYCTX *phKey)
int AAP_API DExportKey(HKEYCTX hKey, HKEYCTX hKEKey, DWORD dwBlobType, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen)
int AAP_API DOpenSession(HSESSIONCTX *phSession, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DCloseSession(HSESSIONCTX *phSession, DWORD dwFlags)
int AAP_API DInitialize(DWORD dwReserved)