API C/C++
HSM Dinamo
Carregando...
Procurando...
Nenhuma entrada encontrado
dinamo.h
Ir para a documentação desse arquivo.
1/* Dinamo Networks. */
2/* Date: 20220930(AAAAMMDD) */
3
4#ifndef DINAMO_H_INCLUDED
5#define DINAMO_H_INCLUDED
6
12#ifdef _WIN32
13 #include <windows.h>
14#endif
15
16#include <time.h>
17
27#ifdef _WIN32
28 typedef unsigned __int64 ND_uint64_t;
29 typedef unsigned __int64 ND_OATH_uint64_t;
30 #define AAP_API __stdcall
31
32 typedef unsigned long long int QWORD;
33 #define DWORD_PRINT_TYPE "lu"
34 #define DWORD_PRINT "%" DWORD_PRINT_TYPE
35#else
36 typedef unsigned long long ND_uint64_t;
37 typedef unsigned long long ND_OATH_uint64_t;
38 #ifdef INTEL_GCC
39 #define AAP_API __attribute__((stdcall))
40 #else
41 #define AAP_API
42 #endif /* INTEL_GCC */
43
44 typedef unsigned char BYTE;
45 typedef unsigned int DWORD;
46 typedef unsigned long long int QWORD;
47 typedef unsigned short WORD;
48 typedef int BOOL;
49 typedef unsigned int UINT;
50 typedef signed int INT;
51 typedef signed char CHAR;
52
53 #define DWORD_PRINT_TYPE "u"
54 #define DWORD_PRINT "%" DWORD_PRINT_TYPE
55
56 #ifndef FALSE
57 #define FALSE (0)
58 #endif
59 #ifndef TRUE
60 #define TRUE (1)
61 #endif
62
63#endif
64
65typedef unsigned long DN_ULONG;
66
67typedef void *HSESSIONCTX;
68typedef void *HHASHCTX;
69typedef void *HKEYCTX;
70typedef void *HCERTCTX;
71typedef void *HSPBCTX;
72typedef void *HCHAPCTX;
73typedef void *HLOGCTX;
74typedef void *HOBJMETACTX;
75typedef void *HP11ATTRCTX;
76typedef void *HOBJMETASEARCHCTX;
77
78#define D_SOCKET_FAILED (-10)
79#define D_GETHOSTNAME_FAILED (-11)
80#define D_CONNECT_FAILED (-12)
81#define D_SEND_FAILED (-13)
82#define D_RECV_FAILED (-14)
83#define D_INVALID_PACKAGE_SIZE (-15)
84#define D_SETSOCKOPT_FAILED (-16)
85#define D_GETSOCKOPT_FAILED (-17)
86#define D_ALL_LOAD_BALANCE_HSM_FAILED (-18)
87#define D_RESET_BY_PEER_ERROR (-19)
88#define D_CONNECTION_REFUSED_ERROR (-20)
89#define D_CONNECTION_TIMEDOUT_ERROR (-21)
90#define D_NETWORK_DOWN_ERROR (-22)
91#define D_SSL_ZERO_RETURN_ERROR (-23)
92#define D_SSL_ERROR (-24)
93#define D_SSL_CTX_NEW_FAILED (1)
94#define D_SSL_NEW_FAILED (2)
95#define D_SSL_CONNECT_FAILED (3)
96#define D_SSL_GENERAL_ERROR (4)
97#define D_CRL_GENERAL_ERROR (101)
98#define D_CRL_SSL_CACERT_BADFILE (102)
99#define D_CRL_COULDNT_RESOLVE_HOST (103)
100#define D_CRL_COULDNT_CONNECT (104)
101#define D_CRL_OPERATION_TIMEDOUT (105)
102#define D_CRL_PEER_FAILED_VERIFICATION (106)
103#define D_CRL_SSL_CONNECT_ERROR (107)
104#define D_CRL_SEND_ERROR (108)
105#define D_CRL_RECV_ERROR (109)
106#define D_CRL_SSL_CERTPROBLEM (110)
107#define D_CRL_SSL_ISSUER_ERROR (111)
108#define D_CRL_AUTH_ERROR (112)
109#define D_CRL_GOT_NOTHING (113)
110#define D_CRL_UNSUPPORTED_PROTOCOL (114)
111#define D_CRL_URL_MALFORMAT (115)
112#define D_CRL_WEIRD_SERVER_REPLY (116)
113#define D_CRL_REMOTE_ACCESS_DENIED (117)
114#define D_CRL_HTTP2 (118)
115#define D_CRL_WRITE_ERROR (119)
116#define D_CRL_READ_ERROR (120)
117#define D_CRL_HTTP_POST_ERROR (121)
118#define D_CRL_ABORTED_BY_CALLBACK (122)
119#define D_CRL_TOO_MANY_REDIRECTS (123)
120#define D_CRL_SSL_CIPHER (124)
121#define D_CRL_BAD_CONTENT_ENCODING (125)
122#define D_CRL_LOGIN_DENIED (126)
123#define D_CRL_INSTALL_SIGN_CALL_FAILED (127)
124#define D_CRL_CERT_LOAD_FAILED (128)
125#define D_CRL_CHAIN_LOAD_FAILED (129)
126#define D_CRL_PRIVATE_KEY_LOAD_FAILED (130)
127#define D_WSASTARTUP (2001)
128#define D_MEMORY_ALLOC (2002)
129#define D_INVALID_PARAM (1001)
130#define D_INVALID_TYPE (1002)
131#define D_INVALID_STATE (1003)
132#define D_LOGGING_NOT_STARTED (1004)
133#define D_MORE_DATA (1005)
134#define D_INVALID_RESPONSE (1006)
135#define D_INVALID_CONTEXT (1007)
136#define D_KEY_GEN_ERROR (1008)
137#define D_KEY_DEL_ERROR (1009)
138#define D_KEY_NOT_EXISTS (1010)
139#define D_INVALID_DATA_LENGTH (1011)
140#define D_INVALID_KEY_ALG (1012)
141#define D_INVALID_PADDING (1013)
142#define D_INVALID_KEY (1014)
143#define D_BAD_DATA (1015)
144#define D_INVALID_PUBKEY (1016)
145#define D_INVALID_ALG_ID (1017)
146#define D_INVALID_HASH (1018)
147#define D_INIT_HASH_FAILED (1019)
148#define D_INVALID_HASH_STATE (1020)
149#define D_END_HASH_FAILED (1021)
150#define D_GET_INFO_ERROR (1022)
151#define D_INVALID_PIN_LEN (1023)
152#define D_OPEN_FILE_FAILED (1025)
153#define D_BACKUP_FAILED (1026)
154#define D_RESTORE_FAILED (1027)
155#define D_INVALID_CALLBACK (1028)
156#define D_NOT_IMPLEMENTED (1029)
157#define D_AUTH_FAILED (1030)
158#define D_INVALID_CLEAR_OP (1031)
159#define D_CHANGE_PWD_ERROR (1032)
160#define D_PWD_SIZE_ERROR (1033)
161#define D_IMPORT_KEY_ERROR (1034)
162#define D_INVALID_KEY_ID (1035)
163#define D_INVALID_FLAG (1036)
164#define D_INVALID_SIGNATURE (1037)
165#define D_INVALID_PUB_KEY (1038)
166#define D_INVALID_KEY_STATE (1039)
167#define D_CREATE_USER_ERROR (1040)
168#define D_NO_MORE_OBJECT (1041)
169#define D_PUT_ENV_VAR_FAILED (1042)
170#define D_INVALID_FILE_SIZE (1043)
171#define D_INVALID_TEXT_SIZE (1044)
172#define D_FILE_ACCESS_ERROR (1045)
173#define D_INVALID_COUNTER (1046)
174#define D_INVALID_MODE (1047)
175#define D_INVALID_STRUCT_ID (1048)
176#define D_INVALID_IP_ADDRESS (1049)
177#define D_GET_PEER_IP_ERROR (1050)
178#define D_CERTIFICATE_PARSE_FAILED (1051)
179#define D_INVALID_KEY_PART_1 (1052)
180#define D_INVALID_KEY_PART_2 (1053)
181#define D_INVALID_KEY_PART_3 (1054)
182#define D_VERIFY_DAC_FAILED (1055)
183#define D_DEPRECATED (1056)
184#define D_NO_MATCHING_KEY_FOUND (1057)
185#define D_CALLBACK_ERROR (1058)
186#define D_INTERNAL_ERROR (1059)
187#define D_KEY_NOT_EXPORTABLE_ERROR (1060)
188#define D_INVALID_SPB_ID (1062)
189#define D_JSON_PARSE_ERROR (1063)
190#define D_JSON_PARSE_WRONG_TYPE_ERROR (1064)
191#define D_JSON_SET_VALUE_ERROR (1065)
192#define D_JSON_UNSET_VALUE_ERROR (1066)
193#define D_JSON_VALUE_NOT_FOUND (1067)
194#define D_JSON_OBJ_CREATE_ERROR (1068)
195#define D_SLP_PARSE_ERROR (1069)
196#define D_SLP_INTERNAL_ERROR (1070)
197#define D_SLP_TOO_MANY_SERVERS_ERROR (1071)
198#define D_INVALID_SERVER_VERSION (1072)
199#define D_GENERATE_PKCS12_ERROR (1073)
200#define D_SET_LOAD_BALANCE_LIST_ERROR (1074)
201#define D_OATH_BLOB_UPDATE (1075)
202#define D_GZIP_DEFLATE_ERROR (1076)
203#define D_HTTP_UNEXPECTED_STATUS_CODE (1077)
204#define D_BASE64_ERROR (1078)
205#define D_SC_READER_NOT_READY (1079)
206#define D_SC_NOT_FORMATTED (1080)
207#define D_SC_INVALID_PIN (1081)
208#define D_SC_READ_FAILED (1082)
209#define D_SC_UNEXPECTED_SVMK_STATUS (1083)
210#define D_SC_FAILED_USB_LIB_LOAD (1084)
211#define D_SC_INVALID_ATR_LEN (1085)
212#define D_SC_PIN_LOCKED (1086)
213#define D_SC_KATS_NEGOTIATION_FAILED (1087)
214#define D_SC_CHANGE_PIN_FAILED (1088)
215#define D_INVALID_DATA_FORMAT (1089)
216#define D_SC_FREEZE_FAILED (1090)
217#define D_SC_LEGACY_CARD_NOT_SUPPORTED (1091)
218#define D_SC_WOULD_OVERWRITE_SVMK (1092)
219#define D_SC_INVALID_SVMK_TYPE (1093)
220#define D_SC_WRITE_FAILED (1094)
221#define D_SC_ERASE_FAILED (1095)
222#define D_SC_SELECT_FAILED (1096)
223#define D_INVALID_HSM_OP_MODE (1097)
224#define D_KEEP_ALIVE_ERROR (3001)
225#define D_RECEIVE_LOG_ERROR (3002)
226#define D_ERROR_NOTIFY (3003)
227
228// -------------------------------------------------------------------
229#define D_SUCCESS (0)
230#define D_ERR_UNKNOWN (5000)
231#define D_ERR_NET_FAIL (5001)
232#define D_ERR_ACCESS_DENIED (5002)
233#define D_ERR_CANNOT_CREATE_OBJ (5003)
234#define D_ERR_CANNOT_OPEN_OBJ (5004)
235#define D_ERR_CANNOT_DEL_OBJ (5005)
236#define D_ERR_CANNOT_ALLOC_RES (5006)
237#define D_ERR_INVALID_CTX (5007)
238#define D_ERR_INVALID_OPERATION (5008)
239#define D_ERR_INVALID_KEY (5009)
240#define D_ERR_NO_TLS_USED (5010)
241#define D_ERR_CANNOT_CHANGE_PWD (5011)
242#define D_ERR_OBJ_NOT_EXPORTABLE (5012)
243#define D_ERR_USR_ALREADY_EXISTS (5013)
244#define D_ERR_INVALID_USR_NAME (5014)
245#define D_ERR_CANNOT_CREATE_USR (5015)
246#define D_ERR_NO_MORE_LOG_SLOTS (5016)
247#define D_ERR_CANNOT_DELETE_USR (5017)
248#define D_ERR_CANNOT_DELETE_MASTER (5018)
249#define D_ERR_NOT_IMPLEMENTED (5019)
250#define D_ERR_USR_NOT_FOUND (5020)
251#define D_ERR_INVALID_PAYLOAD (5021)
252#define D_ERR_OBJ_ALREADY_EXISTS (5022)
253#define D_ERR_INVALID_OBJ_NAME (5023)
254#define D_ERR_OBJ_IN_USE (5024)
255#define D_ERR_CANNOT_WRITE_BACKUP_BLOB (5025)
256#define D_ERR_CANNOT_OPEN_BACKUP_BLOB (5026)
257#define D_ERR_CANNOT_RESTORE_BACKUP_BLOB (5027)
258#define D_ERR_INVALID_BACKUP_PIN_OR_LEN (5028)
259#define D_ERR_INVALID_XML_SIGNATURE (5029)
260#define D_ERR_INVALID_CERTIFICATE (5030)
261#define D_ERR_VERIFY_XML_FAILED (5031)
262#define D_ERR_INVALID_XML (5032)
263#define D_ERR_SIGN_XML_FAILED (5033)
264#define D_ERR_UPACK_VERIFY_FAILED (5034)
265#define D_ERR_CANNOT_TRUNCATE_LOG (5035)
266#define D_ERR_CANNOT_BACKUP_OLD_LOG (5036)
267#define D_ERR_CERTIFICATE_EXPIRED (5037)
268#define D_ERR_CERTIFICATE_FAILED (5038)
269#define D_ERR_CERTIFICATE_NOT_FOUND (5039)
270#define D_ERR_CERTIFICATE_REVOKED (5040)
271#define D_ERR_CERTIFICATE_ISSUER_FAILED (5041)
272#define D_ERR_CERTIFICATE_NOT_YET_VALID (5042)
273#define D_ERR_CERT_EXPIRED_SIGN_VALID (5043)
274#define D_ERR_CRL_EXPIRED (5044)
275#define D_ERR_INVALID_CRL_SIGN (5045)
276#define D_ERR_CRL_CERT_MISMATCH (5046)
277#define D_ERR_CERT_REVOKED (D_ERR_CERTIFICATE_REVOKED)
278#define D_ERR_CERT_REVOKED_LIBCLIENT_FIX1 (5047)
279#define D_ERR_ACCESS_DENIED_TOKEN_NOT_NEEDED (5048)
280#define D_ERR_ACCESS_DENIED_TOKEN_NEEDED (5049)
281#define D_ERR_CERT_REVOKED_CRL_VAL_UNUSED (5050)
282#define D_ERR_CERT_VALID_CRL_VAL_UNUSED (5051)
283#define D_ERR_CANNOT_PARSE_XML (5052)
284#define D_ERR_CANNOT_CREATE_XML_SIG_TEMPL (5053)
285#define D_ERR_CANNOT_ADD_XML_SIG_TEMPL_REF (5054)
286#define D_ERR_CANNOT_ADD_XML_SIG_TEMPL_TRANS (5055)
287#define D_ERR_CANNOT_ADD_XML_SIG_KEY_INFO (5056)
288#define D_ERR_CANNOT_ADD_XML_SIG_KEY_CERT (5057)
289#define D_ERR_CANNOT_ALLOC_XML_SIG_CTX (5058)
290#define D_ERR_CANNOT_PARSE_DER_PRIV_KEY (5059)
291#define D_ERR_XML_CANNOT_LOAD_PRIV_KEY (5060)
292#define D_ERR_XML_CANNOT_LOAD_CERT (5061)
293#define D_ERR_XML_CANNOT_CREATE_KEY_MNG (5062)
294#define D_ERR_XML_CANNOT_INIT_KEY_MNG (5063)
295#define D_ERR_XML_CANNOT_LOAD_TRUSTED_CERTS (5064)
296#define D_ERR_XML_SIG_NODE_NOT_FOUND (5065)
297#define D_ERR_XML_CERT_NODE_NOT_FOUND (5066)
298#define D_ERR_XML_CANNOT_DECODE_CERT_NODE (5067)
299#define D_ERR_CANNOT_PARSE_DER_CERT (5068)
300#define D_ERR_DEPRECATED_XML_COMPRESS (5069)
301#define D_ERR_INVALID_CERTIFICATE_NULL_RES (5070)
302#define D_ERR_CANNOT_RECREATE_MASTER (5071)
303#define D_ERR_CANNOT_CREATE_USR_STORAGE1 (5072)
304#define D_ERR_CANNOT_CREATE_USR_STORAGE2 (5073)
305#define D_ERR_CANNOT_CREATE_USR_DEFAULT_ACL (5074)
306#define D_ERR_CANNOT_ALLOC_CTX (5075)
307#define D_ERR_CANNOT_LOAD_PRIV_KEY (5076)
308#define D_ERR_CANNOT_DECODE_PUB_KEY (5077)
309#define D_ERR_CANNOT_GENERATE_RND_DATA (5078)
310#define D_ERR_SYSTEM_EXHAUSTED (5079)
311#define D_ERR_RSA_POWER_SIGN_FAILED (5080)
312#define D_ERR_CANNOT_DEMOTE_MASTER (5081)
313#define D_ERR_CANNOT_GET_SYS_INFO (5100)
314#define D_ERR_CANNOT_ALLOC_UPACK_ID (5101)
315#define D_ERR_CANNOT_ALLOC_UPACK_PATH (5102)
316#define D_ERR_CANNOT_WRITE_UPACK_OBJ (5103)
317#define D_ERR_INVALID_CRL (5104)
318#define D_ERR_OPERATION_FAILED (5105)
319#define D_ERR_GET_USR_ACL_FAILED (5106)
320#define D_ERR_INVALID_SIGNATURE (5107)
321#define D_ERR_CANNOT_GENERATE_SOFT_TOKEN (5108)
322#define D_ERR_INVALID_SECRET (5109)
323#define D_ERR_ACCESS_DENIED_USR_BLOCKED (5120)
324#define D_ERR_INVALID_IMEI (5121)
325#define D_ERR_REPLAY_DETECTED (5122)
326#define D_ERR_NON_APPROVED_OPERATION (5123)
327#define D_ERR_ACCESS_DENIED_OBJ_BLOCKED (5124)
328#define D_ERR_DRBG_CONTINUOUS_TEST (5125)
329#define D_ERR_RSA_CONTINUOUS_TEST (5126)
330#define D_ERR_ECC_CONTINUOUS_TEST (5127)
331#define D_ERR_DES_CONTINUOUS_TEST (5128)
332#define D_ERR_AES_CONTINUOUS_TEST (5129)
333#define D_ERR_ALT_BN128_CONTINUOUS_TEST (5130)
334#define D_ERR_CANNOT_UPDATE_OBJ (5175)
335#define D_ERR_CANNOT_GET_PWD_POLICY (5176)
336#define D_ERR_PWD_BLOCKED_BY_POLICY (5177)
337#define D_ERR_PWD_EXPIRED (5178)
338#define D_ERR_CERT_VALID_CRL_VAL_UNUSED_CRL_EXPIRED (5179)
339#define D_ERR_CERT_VALID_CRL_EXPIRED (5180)
340#define D_ERR_INVALID_CERT_SIGN (5181)
341#define D_ERR_CANNOT_LOAD_CORRUPTED_OBJ (5200)
342#define D_ERR_INVALID_CERT_ISPB_MISMATCH (5230)
343#define D_ERR_INVALID_CA (5231)
344#define D_ERR_OPERATION_BLOCKED_BY_SEPOL (5232)
345#define D_ERR_DEPRECATED_FUNCTION (5303)
346#define D_ERR_SERVER_BUSY (5304)
347#define D_ERR_SL_BE_BUSY (5305)
348#define D_ERR_SVMK_MISMATCH (5306)
349#define D_ERR_INVALID_CERT_SN_MISMATCH (5307)
350#define D_ERR_CANNOT_DEC_SYM_KEY (5308)
351#define D_ERR_CANNOT_REC_SYM_KEY (5309)
352#define D_SUCCESS_CANNOT_OPEN_OBJ_AT_REPL (5401)
353#define D_ERR_CANNOT_OPEN_INVALID_OBJ_AT_REPL (5402)
354#define D_ERR_CANNOT_SL_BE_CHECK_OBJ (5500)
355#define D_ERR_CANNOT_WRITE_AUTH_INFO_OBJ (5501)
356#define D_ERR_CANNOT_GEN_RSA_KEY (5502)
357#define D_ERR_CANNOT_GEN_ECC_CURVE (5503)
358#define D_ERR_CANNOT_GEN_ECC_KEY (5504)
359#define D_ERR_CANNOT_GEN_ECC_DER (5505)
360#define D_ERR_CANNOT_GEN_ECC_DER_KEY (5506)
361#define D_ERR_CANNOT_CREATE_UNKNOWN_OBJ (5507)
362#define D_ERR_CANNOT_WRITE_HSM_MODE (5508)
363#define D_ERR_CANNOT_WRITE_LOGIN_BLOCK_INFO (5509)
364#define D_ERR_CANNOT_SETUP_LIVE_SYNC_OBJ (5510)
365#define D_ERR_CANNOT_CREATE_LIVE_SYNC_OBJ (5511)
366#define D_ERR_CANNOT_OPEN_LOG (5512)
367#define D_ERR_COULD_NOT_OPEN_OBJ (5513)
368#define D_ERR_CANNOT_EXPORT_RAW_OBJ (5514)
369#define D_ERR_CANNOT_RENAME_OBJ (5515)
370#define D_ERR_REPLICATION_CANNOT_OPEN_OBJ (5516)
371#define D_ERR_CANNOT_SETUP_LIVE_SYNC_IMG (5517)
372#define D_ERR_CANNOT_LOAD_LIVE_SYNC_IMG (5518)
373#define D_ERR_CANNOT_SETUP_LIVE_SYNC_DEL_USR (5519)
374#define D_ERR_CANNOT_DEL_LIVE_SYNC_USR (5520)
375#define D_ERR_CANNOT_SETUP_LIVE_SYNC_DEL_CONFIG (5521)
376#define D_ERR_CANNOT_DEL_LIVE_SYNC_CONFIG (5522)
377#define D_ERR_CANNOT_SETUP_LIVE_SYNC_CONFIG (5523)
378#define D_ERR_CANNOT_CREATE_LIVE_SYNC_CONFIG (5524)
379#define D_ERR_CANNOT_SETUP_LIVE_SYNC_USER (5525)
380#define D_ERR_CANNOT_CREATE_LIVE_SYNC_USER (5526)
381#define D_ERR_CANNOT_SETUP_LIVE_SYNC_ACL (5527)
382#define D_ERR_CANNOT_CREATE_LIVE_SYNC_ACL (5528)
383#define D_ERR_CANNOT_DEL_AUTH_INFO_OBJ (5529)
384#define D_ERR_INVALID_KEY_NULL_RES (5530)
385#define D_ERR_INVALID_MSG_NULL_RES (5531)
386#define D_ERR_CANNOT_GEN_SYM_KEY (5532)
387#define D_ERR_CANNOT_SETUP_USR_AUTH_INFO (5533)
388#define D_ERR_CANNOT_BIND_USR_AUTH_INFO (5534)
389#define D_ERR_CANNOT_GET_CERT_SN (5535)
390#define D_ERR_CANNOT_GET_CERT_ISPB (5536)
391#define D_ERR_INVALID_HASH (5537)
392#define D_ERR_INVALID_SIG_LEN (5538)
393#define D_ERR_INVALID_PUBKEY_LEN (5539)
394#define D_ERR_INVALID_PSKC_XML (5540)
395#define D_ERR_CANNOT_FIND_PSKC_XML_NODE (5541)
396#define D_ERR_CANNOT_FIND_PSKC_XML_ATTR (5542)
397#define D_ERR_INVALID_PSKC_KEY_DERIVATION (5543)
398#define D_ERR_INVALID_PSKC_KEY_DERIVATION_IT (5544)
399#define D_ERR_INVALID_PSKC_KEY_DERIVATION_LEN (5545)
400#define D_ERR_INVALID_PSKC_KEY_DERIVATION_SALT_LEN (5546)
401#define D_ERR_PSKC_KEY_DERIVATION_FAILED (5547)
402#define D_ERR_INVALID_PSKC_KEY_ALG (5548)
403#define D_ERR_INVALID_PSKC_KEY_METHOD (5549)
404#define D_ERR_INVALID_OATH_EPOCH (5550)
405#define D_ERR_INVALID_OATH_TIMESTEP (5551)
406#define D_ERR_INVALID_OATH_DRIFT (5552)
407#define D_ERR_INVALID_PSKC_SECRET_LEN (5553)
408#define D_ERR_UNKNOWN_PADDING_TYPE (5554)
409#define D_ERR_DATA_TOO_LARGE_FOR_MODULUS (5555)
410#define D_ERR_DATA_GREATER_THAN_MODULUS_LEN (5556)
411#define D_ERR_PADDING_CHECK_FAILED (5557)
412#define D_ERR_DATA_TOO_LARGE_FOR_KEY_SIZE (5558)
413#define D_ERR_DATA_TOO_SMALL_FOR_KEY_SIZE (5559)
414#define D_ERR_INVALID_TYPE1_PADDING (5560)
415#define D_ERR_INVALID_TYPE2_PADDING (5561)
416#define D_ERR_BAD_FIXED_HDR_PADDING (5562)
417#define D_ERR_MISSING_NULL_PADDING (5563)
418#define D_ERR_BAD_PAD_BYTE_COUNT (5564)
419#define D_ERR_DATA_TOO_LARGE_FOR_PADDING (5565)
420#define D_ERR_BN_NO_INVERSE (5566)
421#define D_ERR_STATIC_BN_CANNOT_EXPAND (5567)
422#define D_ERR_BN_IS_NOT_PRIME (5568)
423#define D_ERR_TOO_MANY_BN_ITERATIONS (5569)
424#define D_ERR_BN_IS_NOT_A_SQUARE (5570)
425#define D_ERR_BN_DIV_BY_ZERO (5571)
426#define D_ERR_BN_NOT_INITIALIZED (5572)
427#define D_ERR_BN_INVALID_RANGE (5573)
428#define D_ERR_BN_BAD_RECIPROCAL (5574)
429#define D_ERR_BN_CALLED_WITH_EVEN_MODULUS (5575)
430#define D_ERR_BN_INPUT_NOT_REDUCED (5576)
431#define D_ERR_BN_TOO_MANY_TMP_VARIABLES (5577)
432#define D_ERR_BN_INVALID_LEN (5578)
433#define D_ERR_BN_ENCODING_ERROR (5579)
434#define D_ERR_INVALID_PUBLIC_EXP (5580)
435#define D_ERR_INVALID_SPB_HDR_LEN (5581)
436#define D_ERR_INVALID_SPB_HDR_VER (5582)
437#define D_ERR_INVALID_SPB_HDR_SPECIAL_TREATMENT (5583)
438#define D_ERR_INVALID_SPB_HDR_R0 (5584)
439#define D_ERR_INVALID_SPB_HDR_DST_ASYM_ALG (5585)
440#define D_ERR_INVALID_SPB_HDR_DST_SYM_ALG (5586)
441#define D_ERR_INVALID_SPB_HDR_SIGN_KEY_TYPE (5587)
442#define D_ERR_INVALID_SPB_HDR_DST_CA (5588)
443#define D_ERR_INVALID_SPB_HDR_SIGN_CA (5589)
444#define D_ERR_INVALID_SIGN_CERT_SN_MISMATCH (5590)
445#define D_ERR_INVALID_DST_CERT_SN_MISMATCH (5591)
446#define D_ERR_INVALID_SPB_MSG_LEN (5592)
447#define D_ERR_CANNOT_PARSE_JSON (5593)
448#define D_ERR_INVALID_SPB_CHARSET_SIG_OK (5594)
449#define D_ERR_JSON_MORE_DATA (5595)
450#define D_ERR_CANNOT_VIRTUALIZE_JSON (5596)
451#define D_ERR_CANNOT_CHANGE_OEM_JSON (5597)
452#define D_ERR_CANNOT_MERGE_JSON (5598)
453#define D_ERR_INVALID_SPB_CHARSET (5599)
454#define D_ERR_CANNOT_GET_JSON (5600)
455#define D_ERR_INVALID_SPB_CHARSET_SIG_ERR (5601)
456#define D_ERR_INVALID_SPB_DOMAIN (5602)
457#define D_ERR_CANNOT_GEN_DSA_KEY (5603)
458#define D_ERR_DSA_CONTINUOUS_TEST (5604)
459#define D_ERR_CANNOT_GEN_DH_KEY (5605)
460#define D_ERR_DH_CONTINUOUS_TEST (5606)
461#define D_ERR_CANNOT_GEN_ML_DSA_KEY (5607)
462#define D_ERR_CANNOT_GEN_ML_KEM_KEY (5608)
463#define D_ERR_CANNOT_GEN_SLH_DSA_KEY (5609)
464#define D_ERR_KEY_CONTINUOUS_TEST (5699)
465#define D_ERR_SERVER_STARTED (5700)
466#define D_ERR_HSM_AUTO_TEST_FAILURE (5701)
467#define D_ERR_SERVER_NOT_STARTED (5702)
468#define D_ERR_UNAPPROVED_TSP_OPERATION (5703)
469#define D_ERR_INVALID_LCRYPTO_R_OPERATION (5704)
470#define D_ERR_OBJ_BLOCKED_BY_DS_POLICY (7000)
471#define D_ERR_TRUNCATING_DS_LOG (7001)
472#define D_ERR_THROTTLED_VM_SIZE (10000)
473#define D_ERR_THROTTLED_RAM (10001)
474#define D_ERR_CANNOT_ALLOC_SOCKET (11000)
475#define D_ERR_CANNOT_ALLOC_MEM (11001)
476#define D_ERR_CANNOT_ALLOC_KEY (11002)
477#define D_ERR_CANNOT_ALLOC_SL_BE_HANDLE (11003)
478#define D_ERR_CANNOT_ALLOC_IOM (11004)
479#define D_ERR_CANNOT_INIT_DRBG (11005)
480#define D_ERR_CANNOT_SEED_DRBG (11006)
481#define D_ERR_CANNOT_USE_IOM (11007)
482#define D_ERR_CANNOT_ALLOC_OBJ_HANDLE (11008)
483#define D_ERR_REPL_CANNOT_ALLOC_SL_BE_HANDLE (11009)
484#define D_ERR_CANNOT_ALLOC_TLS_CTX (11010)
485#define D_ERR_CANNOT_ALLOC_TLS_SOCKET (11011)
486#define D_ERR_CANNOT_SERIALIZE_XML (11012)
487#define D_ERR_CANNOT_ALLOC_BN (11013)
488#define D_ERR_CANNOT_ALLOC_JSON (11014)
489#define D_ERR_CRYPTOHW_OPEN_FAILURE (12001)
490#define D_ERR_CRYPTOHW_SETUP_FAILURE (12002)
491#define D_ERR_CRYPTOHW_READ_FAILURE (12003)
492#define D_ERR_CRYPTOHW_INVALID_CRC (12004)
493#define D_ERR_CRYPTOHW_WRITE_FAILURE (12005)
494#define D_ERR_CRYPTOHW_UNEXPECTED_MSG (12006)
495#define D_ERR_CRYPTOHW_CONNECT_FAILED (12007)
496#define D_ERR_CRYPTOHW_SEND_FAILED (12008)
497#define D_ERR_CRYPTOHW_RECV_FAILED (12009)
498#define D_ERR_REPLICATION_BUSY (36000)
499#define D_ERR_REPLICATION_D_BUSY (36001)
500#define D_ERR_REPLICATION_S_BUSY (36002)
501#define D_ERR_REPLICATION_STORAGE_LAYER_BUSY (36003)
502#define D_ERR_REPLICATION_SEC_LAYER_BUSY (36004)
503#define D_ERR_REPLICATION_PEER_NOT_SYNCED (36500)
504#define D_ERR_REPLICATION_CANNOT_PREPARE_TRANS (37001)
505#define D_ERR_REPLICATION_CANNOT_P2P_HANDSHAKE (37002)
506#define D_ERR_REPLICATION_CANNOT_P2P_FIND (37003)
507#define D_ERR_REPLICATION_CANNOT_P2P_CONNECT (37004)
508#define D_ERR_REPLICATION_CANNOT_P2P_SEND (37005)
509#define D_ERR_REPLICATION_CANNOT_P2P_RECV (37006)
510#define D_ERR_REPLICATION_CANNOT_P2P_SEND_ALL (37007)
511#define D_ERR_REPLICATION_CANNOT_P2P_RECV_ALL (37008)
512#define D_ERR_REPLICATION_CANNOT_P2P_SCONNECT (37009)
513#define D_ERR_REPLICATION_CANNOT_P2P_SSEND (37010)
514#define D_ERR_REPLICATION_CANNOT_P2P_SRECV (37011)
515#define D_ERR_REPLICATION_CANNOT_P2P_SSEND_ALL (37012)
516#define D_ERR_REPLICATION_CANNOT_P2P_SRECV_ALL (37013)
517#define D_ERR_REPLICATION_CANNOT_P2P_WORK (37014)
518#define D_ERR_REPLICATION_NOT_FOUND (37015)
519#define D_ERR_REPLICATION_ACK_NOT_FOUND (37016)
520#define D_ERR_REPLICATION_INVALID_OPERATION (37017)
521#define D_ERR_REPLICATION_INVALID_EVENT (37018)
522#define D_ERR_REPLICATION_OPERATION_FAILED (37019)
523#define D_ERR_REPLICATION_COMMIT_FAILED (37020)
524#define D_ERR_REPLICATION_ERASE_FAILED (37021)
525#define D_ERR_REPLICATION_INQUIRE_FAILED (37022)
526#define D_ERR_REPLICATION_UPDATE_ACK_FAILED (37023)
527#define D_ERR_REPLICATION_DISPATCH_FAILED (37024)
528#define D_ERR_REPLICATION_CANNOT_SL_BE_TRANSP (37025)
529#define D_ERR_REPLICATION_CANNOT_PRUNE_LOG (37026)
530#define D_ERR_REPLICATION_CANNOT_LOAD_LOG (37027)
531#define D_ERR_REPLICATION_CANNOT_WORK (37028)
532#define D_ERR_REPLICATION_CANNOT_VALIDATE_EVENT (37029)
533#define D_ERR_REPLICATION_TRANS_MISMATCH (37030)
534#define D_ERR_REPLICATION_CANNOT_SYNC_POINT (37031)
535#define D_ERR_REPLICATION_UNDEFINED_LIVE_SYNC (37032)
536#define D_ERR_REPLICATION_CONNECTED_LIVE_SYNC (37033)
537#define D_ERR_REPLICATION_SELF_LIVE_SYNC (37034)
538#define D_ERR_REPLICATION_OBJ_IN_USE (37035)
539#define D_ERR_REPLICATION_CANNOT_BEGIN_TRANS (37036)
540#define D_ERR_REPLICATION_MAX_NODE_COUNT_REACHED (37037)
541#define D_ERR_REPL_CANNOT_PREPARE_LS_TRANS (37038)
542#define D_ERR_REPL_PART_CANNOT_ADD_LOG (37039)
543#define D_ERR_REPL_COOR_CANNOT_ADD_LOG (37040)
544#define D_ERR_CANNOT_LOAD_DEPRECATED_LICENSE (47000)
545#define D_ERR_INVALID_DEPRECATED_LICENSE (47001)
546#define D_ERR_DEPRECATED_LICENSE_EXPIRED (47002)
547#define D_ERR_DEPRECATED_LICENSE_BLOCKED (47003)
548#define D_ERR_LICENSE_NOT_FOUND (57001)
549#define D_ERR_CANNOT_UNINSTALL_OEM_LICENCE (57002)
550#define D_ERR_LPACK_VERIFY_FAILED (57003)
551#define D_ERR_CANNOT_PROCESS_LPACK (57004)
552
553// -------------------------------------------------------------------
554
555
556/* Server error macros */
557
558#define D_IS_REPL_BUSY_ERR(dw) ( \
559 (DWORD)(dw) == (DWORD) D_ERR_REPLICATION_BUSY || \
560 (DWORD)(dw) == (DWORD) D_ERR_REPLICATION_D_BUSY || \
561 (DWORD)(dw) == (DWORD) D_ERR_REPLICATION_S_BUSY || \
562 (DWORD)(dw) == (DWORD) D_ERR_REPLICATION_STORAGE_LAYER_BUSY || \
563 (DWORD)(dw) == (DWORD) D_ERR_REPLICATION_SEC_LAYER_BUSY \
564 )
565
566
567
568
569#define NOT_LISTED_ERROR (-999999)
570
571/* DOpenSession - Options/parameters */
572
573/* dwParam */
574#define SS_ANONYMOUS (0x00000001) /*pbData == AUTH_PWD ou AUTH_PWD_EX*/
575#define SS_USER_PWD (0x00000002) /*pbData == AUTH_PWD*/
576#define SS_CERTIFICATE (0x00000004) /*pbData == SS_MEDIA_FILE*/
577#define SS_CLUSTER (0x00000008) /*pbData == NULL*/
578#define SS_USR_PWD_EX (0x00000010) /*pbData == AUTH_PWD_EX*/
579#define SS_ATOKEN (0x00000020) /*pbData == AUTH_ATOKEN*/
580#define SS_HTTP (0x00000040) /*pbData == AUTH_HTTP*/
581#define SS_WIN_CREDENTIAL (0x00000080) /*pbData == AUTH_WIN_CREDENTIAL*/
582
583/* dwFlags */
584#define ENCRYPTED_CONN (0x00000001) /* Encrypted communication */
585#define USER_INTERACTIVE (0x00000002) /* User interactive. Not implemented. */
586#define CLEAR_CONN (0x00000004) /* Not encrypted communication */
587#define LB_BYPASS (0x00000008) /* Load balance bypass */
588#define CACHE_BYPASS (0x00000010) /* Session Cache bypass */
589#define DS_BYPASS (0x00000020) /* Dinamo Services bypass */
590
591/* Strong authentication */
592
593#define SA_AUTH_NONE (0x00000000) /* No strong authentication */
594#define SA_AUTH_OTP (0x00000001) /* OTP authentication */
595#define SA_AUTH_CERTIFICATE (0x00000002) /* Certificate authentication */
596
597/* Modos de operação do HSM */
598
599#define DN_HSM_OP_NRM (0)
600#define DN_HSM_OP_RM1 (1)
601#define DN_HSM_OP_RM2 (2)
602#define DN_HSM_OP_RM3 (3)
604/* SetSessionParam/GetSessionParam */
605
606/* dwParam */
607#define SP_SESSION_TIMEOUT (0x00000001) /* Time-out sessao pbData == dwTimeout (ms) */
608#define SP_SEND_TIMEOUT (0x00000002) /* Time-out send pbData == dwTimeout (ms) */
609#define SP_RECV_TIMEOUT (0x00000004) /* Time-out recv pbData == dwTimeout (ms) */
610#define SP_ENCRYPTED (0x00000008) /* Read-only pbData == bSessionEncrypted (TRUE/FALSE) */
611#define SP_SESSION_ID (0x00000010) /* Read-only pbData == dwSessionId */
612#define SP_SESSION_CID (0x00000020) /* Read-only pbData == DWORD */
613#define SP_SESSION_TYPE (0x00000040) /* Read-only pbData == DWORD */
614#define SP_SESSION_CIPHER (0x00000080) /* Read-only pbData == char * */
615#define SP_SESSION_PIX_HTTP_RET (0x00000100) /* Read-only pbData == long */
616#define SP_SESSION_PIX_HTTP_REQ_DETAILS (0x00000200) /* Read-only pbData == PIX_HTTP_REQUEST_DETAILS */
617#define SP_HSM_OP_MODE (0x00000400) /* Read-only pbData == DWORD (DN_HSM_OP_NRM ...)*/
618
619/* SP_SESSION_TYPE */
620
621#define SP_SESSION_TYPE_CLEAR_CONN (1)
622#define SP_SESSION_TYPE_SSL2 (2)
623#define SP_SESSION_TYPE_SSL3 (3)
624#define SP_SESSION_TYPE_TLS1 (4)
625#define SP_SESSION_TYPE_TLS1_1 (5)
626#define SP_SESSION_TYPE_TLS1_2 (6)
627#define SP_SESSION_TYPE_TLS1_3 (7)
628#define SP_SESSION_TYPE_UNKNOWN (8)
629
630
631/* CloseSession */
632
633/* dwFlags */
634#define WAIT_OPERATIONS (0x00000004) /* Wait the end of all operations in progress. Not implemented. */
635#define CLOSE_PHYSICALLY (0x00000008) /* Force the end of the connection with the HSM. Session will not be cached. */
636
637/* DDSBindHSM */
638
639#define D_DS_BIND_VERSION (1)
640#define D_MAX_DS_BIND_URL (255)
641#define D_DS_BIND_PSK_LEN (16)
642#define D_MIN_DS_BIND_B62_ID (1)
643#define D_MAX_DS_BIND_B62_ID (22)
644
645/* DBackupObject */
646
647#define D_BACKUP_OBJ (1)
648#define D_RESTORE_OBJ (2)
649
650#define D_MAX_BACKUP_OBJ_LEN (1024*4)
651
652/* Backup */
653
654#define MAKE_BACKUP (0)
655#define MAKE_RESTORE (1)
656#define MAKE_RESTORE_WITH_NET_CONFIG MAKE_RESTORE
657#define MAKE_RESTORE_WITHOUT_NET_CONFIG (2)
658#define MAKE_USE_WIN_CREDENTIAL (0x80000000)
660/* GetHsmData/SetHsmData */
661
662/* dwParam */
663#define HD_AUDIT_START (0x00000001) /* Indicate that the connection will be used to retrieve logs. */
664#define HD_AUDIT_RECV (0x00000002) /* Receive logs from server. */
665
666/* dwFlags */
667#define DATA_ONLY (0x00000008) /* Backup/Restore only data */
668#define CONFIG_ONLY (0x00000010) /* Backup/Restore only configurations*/
669
670
671/* GetHsmConfig/SetHsmConfig */
672
673/* dwParam*/
674#define HC_PASS_PORT_VALUE (0x00000001) /* Monitoring port. pbData == wPortNumber */
675#define HC_PASS_PORT_ENABLE (0x00000002) /* Enable/disable monitoring port. pbData == bEnable */
676#define HC_MAX_CONNECT (0x00000004) /* Maximum connections (processing). pbData == dwMaxConnections */
677#define HC_MAX_MONITORING (0x00000008) /* Maximum connections (monitoring). pbData == dwMaxConnections */
678#define HC_PERMISSION_IP (0x00000010) /* Clients IP list. pbData == szIPList (xxx.xxx.xxx.xxx;xxx...) */
679
680/* dwFlags */
681#define ENABLE_VALUES (0x00000020) /* Enable values indicated by pbData. */
682#define DISABLE_VALUES (0x00000040) /* Disable values indicated by pbData. */
683
684
685/* DAdmOperation */
686
687/* dwParam */
688#define AO_SHUTDOWN (1) /* Shutdown HSM. pbData == NULL */
689#define AO_RESTART (2) /* Restart HSM services. pbData == NULL */
690#define AO_KEEPALIVE (4) /* Keep session alive. */
691#define AO_SET_DATE_TIME (8) /* Set the HSM's time and date. pbData == struct tm (time.h) */
692#define AO_ADD_CLUSTER_LIST (16) /* DEPRECATED! */
693#define AO_DEL_CLUSTER_LIST (18) /* DEPRECATED! */
694#define AO_GET_CLUSTER_LIST (20) /* DEPRECATED! */
695#define AO_RST_CLUSTER_LIST (24) /* DEPRECATED! */
696#define AO_SET_PWD_SEC_POLICY (25) /* Define password security policies. */
697#define AO_GET_PWD_SEC_POLICY (32) /* Recover password security policies. */
698#define AO_REPL_UPDATE (33) /* Process an update replication command. pbData == NULL */
699#define AO_REPL_NODE_MESSAGE (34) /* Send comands to the HSM's replication subsystem. pbData == *REPL_NODE_MSG */
700#define AO_LOG_CACHE_STATE (35) /* Get cache log state. pbData == *DWORD */
701#define AO_LOG_CACHE_ENABLE (36) /* Enable log cache. pbData == NULL */
702#define AO_LOG_CACHE_DISABLE (37) /* Disable log cache. pbData == NULL */
703#define AO_SET_TLS_BUNDLE (38) /* Set TLS bundle. pbData == TLS_BUNDLE_INFO */
704
705#define AO_EFTD_ACTIVATE (39)
706#define AO_EFTD_DEACTIVATE (40)
707#define AO_EFTD_RESET_CONF (41)
708#define AO_EFTD_GET_CONF (42)
709#define AO_EFTD_SET_MSG_HEADER_LEN (43)
710#define AO_EFTD_SET_PIN_LEN (44)
711#define AO_GET_GLOBAL_OBJ_STATS (45)
712#define AO_GET_SEC_POLICY_GFLAGS (46)
713#define AO_SET_SEC_POLICY_GFLAGS (47)
714#define AO_GET_HMON_INFO (48)
715#define AO_DRBG_HEALTH_TEST (49)
716#define AO_TSSP_ZERO_COMPLETED (50)
717#define AO_INSTALL_LICENSE (51)
718#define AO_UNINSTALL_LICENSE (52)
719#define AO_GET_INSTALLED_LICENSES (53)
720#define AO_EFTD_SET_ALIAS (54)
721#define AO_EFTD_SET_RESTRICT_KCV (55)
723#define AO_KEEPALIVE_FLAG_NOISELESS ((DWORD) -2371)
724
725#define AO_LOG_CACHE_STATE_ENABLED (11)
726#define AO_LOG_CACHE_STATE_DISABLED (22)
727
728#define DN_LIC_MAX_NAME (51)
730#define DN_LIC_NAME_VIRTUAL_PREFIX '>'
731#define DN_LIC_NAME_OEM_PREFIX '@'
734/*
735 AO_GET_SEC_POLICY_GFLAGS and AO_SET_SEC_POLICY_GFLAGS supported GFLAGS.
736*/
737
738#define DN_SEPOL_GF_ENABLE_HTTP_X509_SA (1 << 0)
739#define DN_SEPOL_GF_ENABLE_NSA_API_AUTH (1 << 1)
741//
742// Replication operation messages
743// to be used with AO_REPL_NODE_MESSAGE.
744//
745#define RNM_PROBE (1)
746#define RNM_DOWN (2)
747#define RNM_SLP_BYPASS_ADD (3)
748#define RNM_SLP_BYPASS_DEL (4)
749
750#define DN_EFTD_DEFAULT_USER "eftd0"
751#define DN_EFTD_MIN_MSG_HEADER_LEN (1)
752#define DN_EFTD_MAX_MSG_HEADER_LEN (255)
753#define DN_EFTD_MIN_PIN_LEN (5)
754#define DN_EFTD_MAX_PIN_LEN (13)
755#define DN_EFTD_MAX_KEY_ALIAS_LEN (159)
757#define DN_EFTD_JSON_CONF_MSG_HDR_LEN "msg-hdr-len"
758#define DN_EFTD_JSON_CONF_PIN_LEN "pin-len"
759#define DN_EFTD_JSON_CONF_EFTD0_ACTIV "eftd0"
760#define DN_EFTD_JSON_CONF_RESTRICT_KCV "restrict-kcv"
761#define DN_EFTD_JSON_CONF_ALIAS "alias"
763/* SetUserParam/GetUserParam */
764
765/* dwParam */
766#define UP_USER_NAME (0x00000001) /* User name. pbData == szUserName */
767#define UP_AUTH_MASK (0x00000002) /* Authorization mask. pdData == dwAuthMask */
768#define UP_ACCESS_TYPE (0x00000004) /* Access type mask. pbData == dwAccessType */
769#define UP_CERTIFICATE (0x00000008) /* User certificate. pbData == pbCertificate */
770#define UP_PASSWORD (0x00000010) /* User password. pbData == pwd */
771#define UP_INVALID_LOGIN_ATTEMPTS (0x00000020) /* Amount of invalid login attempts. pbData == DWORD */
772#define UP_BLOCK_USR (0x00000040) /* Block user. == szUserName */
773#define UP_UNBLOCK_USR (0x00000080) /* Unblock user. == szUserName */
774#define UP_USR_PASSWORD (0x00000100) /* Re-define user password. == USER_INFO */
775#define UP_USR_PA_STATE (0x00000200) /* Partition autorization state. == USER_PA_INFO */
776#define UP_USR_OBJ_COUNT (0x00000400) /* User persisting object count. == DN_USER_OBJ_COUNT */
777
778/* FindUser */
779
780/* dwFindType */
781#define FU_USER_ID (0x00000001) /* User ID pvFindParam == szUserId */
782#define FU_USER_NAME (0x00000002) /* User ID pvFindParam == szUserName */
783#define FU_AUTH_MASK (0x00000004) /* Authorization mask. pvFindParam == dwAuthMask */
784#define FU_ACCESS_TYPE (0x00000008) /* Access type. pvFindParam == dwAccessType */
785#define FU_ROOT_ID (0x00000010) /* Root certificate issuer. pvFindParam == szRootCN */
786
787/* dwFlags */
788#define PARTIAL_VALUE (0x00000080) /* pvFindParam contains part of the search value. */
789
790/* DGetHsmInfo */
791
792#define HI_BATTERY_LIFE (0x00000001) /* Battery remaining life time. pbData == tLife (time_t) */
793#define HI_PERFOMANCE_COUNT (0x00000002) /* Use percentage: CPU, Memory e disk. pbData == * PERFOMANCE_COUNT */
794#define HI_MODULE_INFO (0x00000004) /* Existing modules. pbData == * MODULE_INFO */
795#define HI_HSM_INFO (0x00000008) /* HSM's model and version. pbData == szHsmInfo */
796#define HI_OPERATIONS_COUNT (0x00000010) /* Operation counter. pbData == * OPERATIONS_INFO */
797#define HI_SYS_HEALTH (0x00000020) /* Elapsed time since last update and battery check. pbData == * SYS_HEALTH */
798#define HI_FIPS_MODE (0x00000040) /* Recover HSM's operation mode. pbData == *DWORD */
799#define HI_DISK_INFO (0x00000080) /* Recover HSM's disk usage information. pbData == *SYS_DISK_INFO */
800#define HI_REPL_INFO (0x00000100) /* Recover HSM's replication information. pbData == *SYS_REPL_INFO */
801#define HI_CURRENT_DATE (0x00000200) /* Recover HSM's date and time. pbData == *QWORD */
802#define HI_HW_STR (0x00000400) /* Recover HSM's date and time. pbData == *SYS_HW_STR_INFO */
803#define HI_NTP_INFO (0x00000800) /* Recover HSM's date and time. pbData == *SYS_NTP_INFO */
804#define HI_STATS_INFO (0x00001000) /* Recover HSM's statistics info. pbData == *SYS_STATUS_INFO */
805#define HI_COUNTER_INFO (0x00002000) /* Recover HSM's counter info. pbData == *SYS_COUNTER_INFO */
806#define HI_FIPS_RCODE_INFO (0x00004000) /* Recover HSM's Restrict Modes auto-test return code. pbData == *DWORD */
807#define HI_PENDING_INFO (0x00008000) /* Recover HSM's pending info. pbData == *SYS_PENDING_INFO */
808#define HI_ALL_INFO (0x00010000) /* Recover HSM's ALL info. pbData == *SYS_ALL_INFO */
809
810
811#define INVALID_OBJ_TYPE (0)
812
813#define MSGSH_NO_INFO (0xFFFFFFFF)
814
815
816#define GET_INFO_MAX_REPL_DOMAIN_NAME (1024)
817#define GET_INFO_MAX_REPL_NODES (255)
818#define GET_INFO_MAX_SN_LEN (255)
819#define GET_INFO_MAX_HW_STR_LEN (255)
820#define GET_INFO_MAX_TPKEY_LEN (16)
821#define GET_INFO_MAX_NTP_SVRS (16)
822#define GET_INFO_MAX_NTPQ_LEN (256)
823#define GET_INFO_MAX_NTP_KT_LEN (16)
824#define GET_INFO_MAX_NTP_KM_LEN (64)
825
826
827//Replication states returned by SYS_REPL_INFO structure.
828#define REPL_STATE_TWOPC_VIRTUAL (1)
829#define REPL_STATE_TWOPC_PREPARED (2)
830#define REPL_STATE_TWOPC_COMMITTED (3)
831#define REPL_STATE_TWOPC_COMMITTED_TM (4)
832
833//Replication events returned by SYS_REPL_INFO structure.
834#define REPL_EVENT_ET_NULL (1)
835#define REPL_EVENT_ET_CREATE_USR (2)
836#define REPL_EVENT_ET_DELETE_USR (3)
837#define REPL_EVENT_ET_CREATE_OBJ (4)
838#define REPL_EVENT_ET_DELETE_OBJ (5)
839#define REPL_EVENT_ET_DELETE_USR_OTP_AUTH_INFO (6)
840#define REPL_EVENT_ET_WRITE_USR_OTP_AUTH_INFO (7)
841#define REPL_EVENT_ET_UPDATE_USR_OTP_AUTH_INFO (8)
842#define REPL_EVENT_ET_CHANGE_USR_PWD (9)
843#define REPL_EVENT_ET_SET_USR_LOCK_COUNT (10)
844#define REPL_EVENT_ET_SET_GLOBAL_SEC_POLICY (11)
845#define REPL_EVENT_ET_SET_SYS_DATE_TIME (12)
846#define REPL_EVENT_ET_UPDATE_ACL (13)
847#define REPL_EVENT_ET_BLOCK_OBJ (14)
848#define REPL_EVENT_ET_UPDATE_OBJ (15)
849#define REPL_EVENT_ET_SET_USR_NS_AUTH_COOKIE (16)
850#define REPL_EVENT_ET_SET_USR_OTP_MOV_FACTOR (17)
851
852/* DListUserTrusts */
853
854#define OP_LST_USR_TRUSTERS (0x01) /* List users that permits the current logged user to access it's partition. */
855#define OP_LST_USR_TRUSTEES (0x02) /* List users that have permission to access the current logged user's partition. */
856
857
858/* DAssignToken/DUnassignToken */
859
860#define AT_GO3_TOKEN (1) /* DEPRECATED! */
861#define AT_OATH_TOKEN (2) /* Assign a OATH EVENT OTP token */
862#define AT_OATH_TOKEN_TOTP (3) /* Assign a OATH TIME OTP token */
863
864//
865// mod_OATH's NEW_SA; use with structure OATH_SA_v1.
866//
867#define MAX_OATH_HMAC_LEN (128) // up to hmac-sha512, in bytes
868
869#define OATH_SA_v1_type_SHA1 (0x01)
870#define OATH_SA_v1_HOTP_DYN_TRUNC_OFF (16)
871#define OATH_SA_v2_default_TIME_STEP (30)
872#define OATH_SA_v2_default_T0_Epoch (0)
873
874
875/* DOATHResync */
876
877#define OATH_MIN_HOTP_LEN (6 + 1) //plus 1 for the null terminator
878#define OATH_MAX_HOTP_LEN (16 + 1) //plus 1 for the null terminator
879
880/* DOATHGetBlobInfo */
881
882#define OATH_ISSUE_OATH_BLOB_t (1)
883#define OATH_ISSUE_OATH_INFO_t (2)
884
885
886/* DEncrypt/DDecrypt */
887
888#define D_NO_RSA_PADDING (3)
889#define D_FORCE_ACTUAL_RSA (4)
890
891
892/* DPKCS7Sign - Sign using PKCS#7 */
893
894#define TAC_MOD_CORE_P7_TEXT 0x0001
895#define TAC_MOD_CORE_P7_NOCERTS 0x0002
896#define TAC_MOD_CORE_P7_NOSIGS 0x0004
897#define TAC_MOD_CORE_P7_NOCHAIN 0x0008
898#define TAC_MOD_CORE_P7_NOINTERN 0x0010
899#define TAC_MOD_CORE_P7_NOVERIFY 0x0020
900#define TAC_MOD_CORE_P7_DETACHED 0x0040
901#define TAC_MOD_CORE_P7_BINARY 0x0080
902#define TAC_MOD_CORE_P7_NOATTR 0x0100
903#define TAC_MOD_CORE_P7_NOSMIMECAP 0x0200
904#define TAC_MOD_CORE_P7_NOOLDMIMETYPE 0x0400
905#define TAC_MOD_CORE_P7_CRLFEOL 0x0800
906#define TAC_MOD_CORE_P7_NOCRL 0x2000
907
908#define TAC_MOD_CORE_P7_COSIGN 0x80000000
909
910
911
912/* HASH algorithms */
913
914#define ALG_MD5 (1)
915#define ALG_SHA1 (2)
916#define ALG_SSL_SHA1_MD5 (3)
917#define ALG_SHA2_256 (4)
918#define ALG_SHA2_384 (5)
919#define ALG_SHA2_512 (6)
920#define ALG_SHA2_224 (7)
921#define ALG_SHA3_224 (8)
922#define ALG_SHA3_256 (9)
923#define ALG_SHA3_384 (10)
924#define ALG_SHA3_512 (11)
925
926#define ALG_IDENTITY_FUNC (255)
927
928/*
929 DSignXML/DSignXML2/DPIXSign hash mode options.
930*/
931#define ALG_MD5_InclC14N (1)
932#define ALG_SHA1_InclC14N (2)
933#define ALG_SHA256_InclC14N (3)
934#define ALG_SHA384_InclC14N (4)
935#define ALG_SHA512_InclC14N (5)
936#define ALG_SHA224_InclC14N (6)
937#define ALG_MD5_ExclC14N (31)
938#define ALG_SHA1_ExclC14N (32)
939#define ALG_MD5_InclC14NWithComments (33)
940#define ALG_SHA1_InclC14NWithComments (34)
941#define ALG_MD5_ExclC14NWithComments (35)
942#define ALG_SHA1_ExclC14NWithComments (36)
943#define ALG_SHA256_ExclC14N (37)
944#define ALG_SHA256_InclC14NWithComments (38)
945#define ALG_SHA256_ExclC14NWithComments (39)
946#define ALG_SHA384_ExclC14N (40)
947#define ALG_SHA384_InclC14NWithComments (41)
948#define ALG_SHA384_ExclC14NWithComments (42)
949#define ALG_SHA512_ExclC14N (43)
950#define ALG_SHA512_InclC14NWithComments (44)
951#define ALG_SHA512_ExclC14NWithComments (45)
952#define ALG_SHA224_ExclC14N (46)
953#define ALG_SHA224_InclC14NWithComments (47)
954#define ALG_SHA224_ExclC14NWithComments (48)
955
956/*
957 DSignXML2 flags
958*/
959
960
961#define XML_SIGN_FLAGS_FQN (1 << 31)
962#define XML_SIGN_FLAGS_NOL (1 << 30)
963#define XML_SIGN_FLAGS_NO_RNS (1 << 29)
964
965
966/*
967 DSignXML/DSignXML2 filter options
968*/
969
970#define XML_FILTER_NULL_URI "''"
971
972/*
973 DPIXSign flags
974*/
975
976#define PIX_SIGN_RNS (1)
977
978/* DPIXPost/DPIXGet/DPIXDelete */
979
980#define PIX_VERIFY_HOST_NAME (0x00000001)
981#define PIX_BASIC_HTTP_HEADER (0x00000002)
982#define PIX_GZIP (0x00000004)
983
984/*
985 DPIXJWSSign
986*/
987
988#define PIX_JWS_GEN_MAX_LEN (8*1024)
989
990#define MD5_LEN (16)
991#define SHA1_LEN (20)
992#define SSL_SHA1_MD5_LEN (36)
993#define SHA2_224_LEN (28)
994#define SHA2_256_LEN (32)
995#define SHA2_384_LEN (48)
996#define SHA2_512_LEN (64)
997#define CMAC_3DES_LEN (8)
998#define CMAC_AES_LEN (16)
999#define SHA3_224_LEN (28)
1000#define SHA3_256_LEN (32)
1001#define SHA3_384_LEN (48)
1002#define SHA3_512_LEN (64)
1003
1004#define MAX_HASH_LEN (64)//SHA2_512_LEN
1005
1006/* Digital signature */
1007
1008#define NO_HASH_OID (1)
1009#define MD5_HASH_OID (2)
1010#define SHA_HASH_OID (3)
1011#define SHA256_HASH_OID (4)
1012#define SHA384_HASH_OID (5)
1013#define SHA512_HASH_OID (6)
1014#define SHA224_HASH_OID (7)
1015
1016#define MD5_HASH_OID_LEN (18)
1017#define SHA_HASH_OID_LEN (15)
1018#define SHA224_HASH_OID_LEN (19)
1019#define SHA256_HASH_OID_LEN (19)
1020#define SHA384_HASH_OID_LEN (19)
1021#define SHA512_HASH_OID_LEN (19)
1022
1023#define MAX_OID_LEN (SHA512_HASH_OID_LEN)
1024
1025/* DSignHash flags */
1026
1027#define DN_SIGN_NO_HASH_OID (0x01)
1028#define DN_SIGN_DISABLE_LEGACY_OPERATION (0x02)
1029#define DN_SIGN_ECC_P11_FMT (0x04)
1030
1031/* DVerifySignature flags */
1032
1033#define DN_VERIFY_NO_HASH_OID (0x01)
1034#define DN_VERIFY_ECC_P11_FMT (0x02)
1035#define DN_VERIFY_LOCAL (0x04)
1037#define DN_SIG_EDDSA_MAX_DATA_LEN (4 * 1024 * 1024)
1038#define DN_MAX_EDDSA_SIG_LEN (256)
1039#define DN_MAX_SLH_DSA_SIG_LEN (49856)
1040#define DN_MAX_ML_DSA_SIG_LEN (4627)
1042#define DN_MAX_PQC_SIG_LEN (DN_MAX_SLH_DSA_SIG_LEN)
1044/* PQC */
1045
1046#define DN_MAX_PQC_DSA_CTX_LEN (255)
1047#define DN_MAX_PQC_DSA_DATA_LEN (4 * 1024 * 1024)
1049/* PQC signature sizes */
1050
1051#define DN_ML_DSA_44_SIG_LEN (2420)
1052#define DN_ML_DSA_65_SIG_LEN (3309)
1053#define DN_ML_DSA_87_SIG_LEN (4627)
1055#define DN_SLH_DSA_128S_SIG_LEN (7856)
1056#define DN_SLH_DSA_128F_SIG_LEN (17088)
1057#define DN_SLH_DSA_192S_SIG_LEN (16224)
1058#define DN_SLH_DSA_192F_SIG_LEN (35664)
1059#define DN_SLH_DSA_256S_SIG_LEN (29792)
1060#define DN_SLH_DSA_256F_SIG_LEN (49856)
1062// Do not change this line! It is used by script to generate documentation.
1063// ----> Init object algorithms list
1064
1065/* Symmetric algorithms */
1066
1067#define ALG_DES (1)
1068#define ALG_3DES_112 (2) /* EDE */
1069#define ALG_3DES_168 (3) /* EDE */
1070#define ALG_DESX (91)
1071
1072#define ALG_AES_128 (7)
1073#define ALG_AES_192 (8)
1074#define ALG_AES_256 (9)
1075
1076#define ALG_ARC4 (10)
1077#define ALG_ARC5 (89)
1078
1079/* Asymmetric algorithms */
1080
1081#define ALG_RSA_512 (4)
1082#define ALG_RSA_1024 (5)
1083#define ALG_RSA_2048 (6)
1084#define ALG_RSA_4096 (11)
1085#define ALG_RSA_1152 (121)
1086#define ALG_RSA_1408 (122)
1087#define ALG_RSA_1536 (131)
1088#define ALG_RSA_1976 (130)
1089#define ALG_RSA_1984 (123)
1090#define ALG_RSA_8192 (124)
1091#define ALG_RSA_2304 (126)
1092#define ALG_RSA_2560 (127)
1093#define ALG_RSA_2816 (128)
1094#define ALG_RSA_3072 (129)
1095
1096#define ALG_DSA_2048 (150)
1097#define ALG_DSA_3072 (151)
1098
1099#define ALG_DH_RFC5114_2048 (152)
1100#define ALG_DH_RFC7919_2048 (153)
1101#define ALG_DH_RFC7919_3072 (154)
1102
1103#define ALG_OBJ_CSP (193)
1105#define ALG_ECX_ED25519 (201)
1106#define ALG_ECX_ED448 (202)
1107#define ALG_ECX_X25519 (203)
1108#define ALG_ECX_X448 (204)
1109
1110#define ALG_ECC_SECP112R1 (18) // SECG/WTLS curve over a 112 bit prime field
1111#define ALG_ECC_SECP112R2 (19) // SECG curve over a 112 bit prime field
1112#define ALG_ECC_SECP128R1 (20) // SECG curve over a 128 bit prime field
1113#define ALG_ECC_SECP128R2 (21) // SECG curve over a 128 bit prime field
1114#define ALG_ECC_SECP160K1 (22) // SECG curve over a 160 bit prime field
1115#define ALG_ECC_SECP160R1 (23) // SECG curve over a 160 bit prime field
1116#define ALG_ECC_SECP160R2 (24) // SECG/WTLS curve over a 160 bit prime field
1117#define ALG_ECC_SECP192K1 (25) // SECG curve over a 192 bit prime field
1118#define ALG_ECC_SECP192R1 (26) // NIST/X9.62/SECG curve over a 192 bit prime field
1119#define ALG_ECC_SECP224K1 (27) // SECG curve over a 224 bit prime field
1120#define ALG_ECC_SECP224R1 (28) // NIST/SECG curve over a 224 bit prime field
1121#define ALG_ECC_SECP256K1 (29) // SECG curve over a 256 bit prime field
1122#define ALG_ECC_SECP256R1 (30) // X9.62/SECG curve over a 256 bit prime field
1123#define ALG_ECC_SECP384R1 (31) // NIST/SECG curve over a 384 bit prime field
1124#define ALG_ECC_SECP521R1 (32) // NIST/SECG curve over a 521 bit prime field
1125#define ALG_ECC_X9_62_PRIME192V1 (ALG_ECC_SECP192R1)
1126#define ALG_ECC_X9_62_PRIME192V2 (33) // X9.62 curve over a 192 bit prime field
1127#define ALG_ECC_X9_62_PRIME192V3 (34) // X9.62 curve over a 192 bit prime field
1128#define ALG_ECC_X9_62_PRIME239V1 (35) // X9.62 curve over a 239 bit prime field
1129#define ALG_ECC_X9_62_PRIME239V2 (36) // X9.62 curve over a 239 bit prime field
1130#define ALG_ECC_X9_62_PRIME239V3 (37) // X9.62 curve over a 239 bit prime field
1131#define ALG_ECC_X9_62_PRIME256V1 (ALG_ECC_SECP256R1)
1132
1133#define ALG_ECC_BRAINPOOL_P160R1 (38) // RFC 5639 standard curves
1134#define ALG_ECC_BRAINPOOL_P160T1 (39)
1135#define ALG_ECC_BRAINPOOL_P192R1 (40)
1136#define ALG_ECC_BRAINPOOL_P192T1 (41)
1137#define ALG_ECC_BRAINPOOL_P224R1 (42)
1138#define ALG_ECC_BRAINPOOL_P224T1 (43)
1139#define ALG_ECC_BRAINPOOL_P256R1 (44)
1140#define ALG_ECC_BRAINPOOL_P256T1 (45)
1141#define ALG_ECC_BRAINPOOL_P320R1 (46)
1142#define ALG_ECC_BRAINPOOL_P320T1 (47)
1143#define ALG_ECC_BRAINPOOL_P384R1 (48)
1144#define ALG_ECC_BRAINPOOL_P384T1 (49)
1145#define ALG_ECC_BRAINPOOL_P512R1 (50)
1146#define ALG_ECC_BRAINPOOL_P512T1 (51)
1147
1148/* ECC bchain */
1149#define ALG_BLKC_BTC_MINI_KEY (1771)
1150#define ALG_BLKC_BIP32_SXPRIV (1772)
1151#define ALG_BLKC_BIP39_SXPRIV (1773)
1152#define ALG_BLKC_BIP32_XPRIV (1774)
1153#define ALG_BLKC_BIP32_ED25519_XPRIV (1775)
1154#define ALG_BLKC_BIP32_P256_XPRIV (1776)
1155
1156
1157#define ALG_ALT_BN128 (2771)
1158
1159/* PQC */
1160#define ALG_ML_DSA_44 (500)
1161#define ALG_ML_DSA_65 (501)
1162#define ALG_ML_DSA_87 (502)
1163
1164#define ALG_ML_KEM_512 (503)
1165#define ALG_ML_KEM_768 (504)
1166#define ALG_ML_KEM_1024 (505)
1167
1168#define ALG_SLH_DSA_SHA2_128S (506)
1169#define ALG_SLH_DSA_SHAKE_128S (507)
1170#define ALG_SLH_DSA_SHA2_128F (508)
1171#define ALG_SLH_DSA_SHAKE_128F (509)
1172#define ALG_SLH_DSA_SHA2_192S (510)
1173#define ALG_SLH_DSA_SHAKE_192S (511)
1174#define ALG_SLH_DSA_SHA2_192F (512)
1175#define ALG_SLH_DSA_SHAKE_192F (513)
1176#define ALG_SLH_DSA_SHA2_256S (514)
1177#define ALG_SLH_DSA_SHAKE_256S (515)
1178#define ALG_SLH_DSA_SHA2_256F (516)
1179#define ALG_SLH_DSA_SHAKE_256F (517)
1180
1181/* blobs */
1182#define ALG_OBJ_BLOB (12)
1183#define ALG_OBJ_BLOB_X509 (13)
1184#define ALG_OBJ_BLOB_PKCS7 (14)
1185#define ALG_OBJ_BLOB_CRL (15)
1186#define ALG_OBJ_BLOB_HOTP (16)
1187#define ALG_OBJ_BLOB_DPGO3 (17) /* TAC-PASS (Vasco Digipass GO3 Compatible) */
1188#define ALG_OBJ_MAP (90)
1189#define ALG_OBJ_EXT_MAP_2_OBJ (125)
1190
1191
1192/* Public key objects */
1193
1194#define ALG_OBJ_PUBKEY_BLOB (350)
1195#define ALG_OBJ_PUBKEY_RSA_BLOB (351) // pkcs1/oem
1196#define ALG_OBJ_PUBKEY_ECC_BLOB (352) // SubjectPublicKeyInfo
1197#define ALG_OBJ_PUBKEY_SPKI_RSA_BLOB (353) // SubjectPublicKeyInfo
1198#define ALG_OBJ_PUBKEY_ECC_Ed_BLOB (354) // SubjectPublicKeyInfo
1199#define ALG_OBJ_PUBKEY_ECC_X_BLOB (355) // SubjectPublicKeyInfo
1200#define ALG_OBJ_PUBKEY_DSA_BLOB (356) // SubjectPublicKeyInfo
1201#define ALG_OBJ_PUBKEY_DH_BLOB (357) // SubjectPublicKeyInfo
1202#define ALG_OBJ_PUBKEY_ML_DSA_BLOB (358) // SubjectPublicKeyInfo
1203#define ALG_OBJ_PUBKEY_ML_KEM_BLOB (359) // SubjectPublicKeyInfo
1204#define ALG_OBJ_PUBKEY_SLH_DSA_BLOB (360) // SubjectPublicKeyInfo
1205
1206/* HMAC objects */
1207
1208#define ALG_HMAC_MD5 (92)
1209#define ALG_HMAC_SHA1 (93)
1210#define ALG_HMAC_SHA2_256 (94)
1211#define ALG_HMAC_SHA2_384 (95)
1212#define ALG_HMAC_SHA2_512 (96)
1213#define ALG_HMAC_SHA2_224 (97)
1214#define ALG_HMAC_SHA3_224 (98)
1215#define ALG_HMAC_SHA3_256 (99)
1216#define ALG_HMAC_SHA3_384 (100)
1217#define ALG_HMAC_SHA3_512 (101)
1218
1219/* CMAC algorithms - DCreateHash Only */
1220
1221#define ALG_CMAC_AES (250)
1222#define ALG_CMAC_DES (251)
1223
1224
1225/* PKCS11 objects */
1226
1227#define ALG_PKCS11_MAP (120) // pkcs11 shell obj
1228
1229/* Public keys -> most significant bit of the DWORD must be set. */
1230
1231#define ALG_RSA_512_PUB (ALG_RSA_512 | 1 << 31)
1232#define ALG_RSA_1024_PUB (ALG_RSA_1024 | 1 << 31)
1233#define ALG_RSA_2048_PUB (ALG_RSA_2048 | 1 << 31)
1234#define ALG_RSA_4096_PUB (ALG_RSA_4096 | 1 << 31)
1235#define ALG_RSA_1152_PUB (ALG_RSA_1152 | 1 << 31)
1236#define ALG_RSA_1408_PUB (ALG_RSA_1408 | 1 << 31)
1237#define ALG_RSA_1536_PUB (ALG_RSA_1536 | 1 << 31)
1238#define ALG_RSA_1976_PUB (ALG_RSA_1976 | 1 << 31)
1239#define ALG_RSA_1984_PUB (ALG_RSA_1984 | 1 << 31)
1240#define ALG_RSA_8192_PUB (ALG_RSA_8192 | 1 << 31)
1241#define ALG_RSA_2304_PUB (ALG_RSA_2304 | 1 << 31)
1242#define ALG_RSA_2560_PUB (ALG_RSA_2560 | 1 << 31)
1243#define ALG_RSA_2816_PUB (ALG_RSA_2816 | 1 << 31)
1244#define ALG_RSA_3072_PUB (ALG_RSA_3072 | 1 << 31)
1245
1246#define ALG_ECX_ED25519_PUB (ALG_ECX_ED25519 | 1 << 31)
1247#define ALG_ECX_ED448_PUB (ALG_ECX_ED448 | 1 << 31)
1248#define ALG_ECX_X25519_PUB (ALG_ECX_X25519 | 1 << 31)
1249#define ALG_ECX_X448_PUB (ALG_ECX_X448 | 1 << 31)
1250
1251#define ALG_ECC_SECP112R1_PUB (ALG_ECC_SECP112R1 | (1 << 31))
1252#define ALG_ECC_SECP112R2_PUB (ALG_ECC_SECP112R2 | (1 << 31))
1253#define ALG_ECC_SECP128R1_PUB (ALG_ECC_SECP128R1 | (1 << 31))
1254#define ALG_ECC_SECP128R2_PUB (ALG_ECC_SECP128R2 | (1 << 31))
1255#define ALG_ECC_SECP160K1_PUB (ALG_ECC_SECP160K1 | (1 << 31))
1256#define ALG_ECC_SECP160R1_PUB (ALG_ECC_SECP160R1 | (1 << 31))
1257#define ALG_ECC_SECP160R2_PUB (ALG_ECC_SECP160R2 | (1 << 31))
1258#define ALG_ECC_SECP192K1_PUB (ALG_ECC_SECP192K1 | (1 << 31))
1259#define ALG_ECC_SECP192R1_PUB (ALG_ECC_SECP192R1 | (1 << 31))
1260#define ALG_ECC_SECP224K1_PUB (ALG_ECC_SECP224K1 | (1 << 31))
1261#define ALG_ECC_SECP224R1_PUB (ALG_ECC_SECP224R1 | (1 << 31))
1262#define ALG_ECC_SECP256K1_PUB (ALG_ECC_SECP256K1 | (1 << 31))
1263#define ALG_ECC_SECP256R1_PUB (ALG_ECC_SECP256R1 | (1 << 31))
1264#define ALG_ECC_SECP384R1_PUB (ALG_ECC_SECP384R1 | (1 << 31))
1265#define ALG_ECC_SECP521R1_PUB (ALG_ECC_SECP521R1 | (1 << 31))
1266#define ALG_ECC_X9_62_PRIME192V1_PUB (ALG_ECC_SECP192R1_PUB)
1267#define ALG_ECC_X9_62_PRIME192V2_PUB (ALG_ECC_X9_62_PRIME192V2 | (1 << 31))
1268#define ALG_ECC_X9_62_PRIME192V3_PUB (ALG_ECC_X9_62_PRIME192V3 | (1 << 31))
1269#define ALG_ECC_X9_62_PRIME239V1_PUB (ALG_ECC_X9_62_PRIME239V1 | (1 << 31))
1270#define ALG_ECC_X9_62_PRIME239V2_PUB (ALG_ECC_X9_62_PRIME239V2 | (1 << 31))
1271#define ALG_ECC_X9_62_PRIME239V3_PUB (ALG_ECC_X9_62_PRIME239V3 | (1 << 31))
1272#define ALG_ECC_X9_62_PRIME256V1_PUB (ALG_ECC_SECP256R1_PUB)
1273
1274#define ALG_ECC_BRAINPOOL_P160R1_PUB (ALG_ECC_BRAINPOOL_P160R1 | (1 << 31))
1275#define ALG_ECC_BRAINPOOL_P160T1_PUB (ALG_ECC_BRAINPOOL_P160T1 | (1 << 31))
1276#define ALG_ECC_BRAINPOOL_P192R1_PUB (ALG_ECC_BRAINPOOL_P192R1 | (1 << 31))
1277#define ALG_ECC_BRAINPOOL_P192T1_PUB (ALG_ECC_BRAINPOOL_P192T1 | (1 << 31))
1278#define ALG_ECC_BRAINPOOL_P224R1_PUB (ALG_ECC_BRAINPOOL_P224R1 | (1 << 31))
1279#define ALG_ECC_BRAINPOOL_P224T1_PUB (ALG_ECC_BRAINPOOL_P224T1 | (1 << 31))
1280#define ALG_ECC_BRAINPOOL_P256R1_PUB (ALG_ECC_BRAINPOOL_P256R1 | (1 << 31))
1281#define ALG_ECC_BRAINPOOL_P256T1_PUB (ALG_ECC_BRAINPOOL_P256T1 | (1 << 31))
1282#define ALG_ECC_BRAINPOOL_P320R1_PUB (ALG_ECC_BRAINPOOL_P320R1 | (1 << 31))
1283#define ALG_ECC_BRAINPOOL_P320T1_PUB (ALG_ECC_BRAINPOOL_P320T1 | (1 << 31))
1284#define ALG_ECC_BRAINPOOL_P384R1_PUB (ALG_ECC_BRAINPOOL_P384R1 | (1 << 31))
1285#define ALG_ECC_BRAINPOOL_P384T1_PUB (ALG_ECC_BRAINPOOL_P384T1 | (1 << 31))
1286#define ALG_ECC_BRAINPOOL_P512R1_PUB (ALG_ECC_BRAINPOOL_P512R1 | (1 << 31))
1287#define ALG_ECC_BRAINPOOL_P512T1_PUB (ALG_ECC_BRAINPOOL_P512T1 | (1 << 31))
1288
1289#define ALG_ML_DSA_44_PUB (ALG_ML_DSA_44 | (1 << 31))
1290#define ALG_ML_DSA_65_PUB (ALG_ML_DSA_65 | (1 << 31))
1291#define ALG_ML_DSA_87_PUB (ALG_ML_DSA_87 | (1 << 31))
1292
1293#define ALG_ML_KEM_512_PUB (ALG_ML_KEM_512 | (1 << 31))
1294#define ALG_ML_KEM_768_PUB (ALG_ML_KEM_768 | (1 << 31))
1295#define ALG_ML_KEM_1024_PUB (ALG_ML_KEM_1024 | (1 << 31))
1296
1297#define ALG_SLH_DSA_SHA2_128S_PUB (ALG_SLH_DSA_SHA2_128S | (1 << 31))
1298#define ALG_SLH_DSA_SHAKE_128S_PUB (ALG_SLH_DSA_SHAKE_128S | (1 << 31))
1299#define ALG_SLH_DSA_SHA2_128F_PUB (ALG_SLH_DSA_SHA2_128F | (1 << 31))
1300#define ALG_SLH_DSA_SHAKE_128F_PUB (ALG_SLH_DSA_SHAKE_128F | (1 << 31))
1301#define ALG_SLH_DSA_SHA2_192S_PUB (ALG_SLH_DSA_SHA2_192S | (1 << 31))
1302#define ALG_SLH_DSA_SHAKE_192S_PUB (ALG_SLH_DSA_SHAKE_192S | (1 << 31))
1303#define ALG_SLH_DSA_SHA2_192F_PUB (ALG_SLH_DSA_SHA2_192F | (1 << 31))
1304#define ALG_SLH_DSA_SHAKE_192F_PUB (ALG_SLH_DSA_SHAKE_192F | (1 << 31))
1305#define ALG_SLH_DSA_SHA2_256S_PUB (ALG_SLH_DSA_SHA2_256S | (1 << 31))
1306#define ALG_SLH_DSA_SHAKE_256S_PUB (ALG_SLH_DSA_SHAKE_256S | (1 << 31))
1307#define ALG_SLH_DSA_SHA2_256F_PUB (ALG_SLH_DSA_SHA2_256F | (1 << 31))
1308#define ALG_SLH_DSA_SHAKE_256F_PUB (ALG_SLH_DSA_SHAKE_256F | (1 << 31))
1309
1310/* Binary objects */
1311
1312#define ALG_OBJ_INVALID_TYPE (0)
1313#define ALG_OBJ_NULL (ALG_OBJ_INVALID_TYPE)
1314#define ALG_OBJ (12)
1315
1316// Do not change this line! It is used by script to generate documentation.
1317// <---- End object algorithms list
1318
1319
1320/* Symmetric key sizes (bytes) */
1321
1322#define ALG_DES_LEN (8)
1323#define ALG_DES3_112_LEN (16)
1324#define ALG_DES3_168_LEN (24)
1325
1326//Deprecated
1327#define DES_LEN (ALG_DES_LEN)
1328#define DES3_112_LEN (ALG_DES3_112_LEN)
1329#define DES3_168_LEN (ALG_DES3_168_LEN)
1330
1331#define ALG_DESX_LEN (24)
1332
1333#define ALG_AES_128_LEN (16)
1334#define ALG_AES_192_LEN (24)
1335#define ALG_AES_256_LEN (32)
1336
1337#define ALG_ARC4_LEN (16)
1338#define ALG_ARC5_LEN (16)
1339
1340/* Block sizes */
1341
1342#define DES_BLOCK (8)
1343#define DES3_BLOCK (8)
1344#define DESX_BLOCK (8)
1345#define AES_BLOCK (16)
1346#define AES_128_BLOCK (16)
1347#define AES_192_BLOCK (16)
1348#define AES_256_BLOCK (16)
1349#define ARC5_BLOCK (8)
1350
1351#define DN_GCM_MODE_TAG_LEN (16)
1352
1353/* Operation modes */
1354
1355#define MODE_DEFAULT (0xFFFFFFFF)
1356#define MODE_NONE (0)
1357#define MODE_ECB (1 << 0)
1358#define MODE_CBC (1 << 1)
1359#define MODE_KWP (1 << 2)
1360#define MODE_OFB (1 << 3)
1361#define MODE_CTR (1 << 4)
1362#define MODE_GCM (1 << 5)
1363#define MODE_KW (1 << 6)
1365/* Operation directions */
1366
1367#define D_ENCRYPT (0 << 7)
1368#define D_DECRYPT (1 << 7)
1369
1370/* RSA module sizes */
1371#define RSA_512_LEN (64)
1372#define RSA_1024_LEN (128)
1373#define RSA_2048_LEN (256)
1374#define RSA_4096_LEN (512)
1375#define RSA_1152_LEN (144)
1376#define RSA_1408_LEN (176)
1377#define RSA_1536_LEN (192)
1378#define RSA_1976_LEN (247)
1379#define RSA_1984_LEN (248)
1380#define RSA_8192_LEN (1024)
1381#define RSA_2304_LEN (288)
1382#define RSA_2560_LEN (320)
1383#define RSA_2816_LEN (352)
1384#define RSA_3072_LEN (384)
1385
1386#define RSA_512_PUB_LEN (RSA_512_LEN * 2)
1387#define RSA_1024_PUB_LEN (RSA_1024_LEN * 2)
1388#define RSA_2048_PUB_LEN (RSA_2048_LEN * 2)
1389#define RSA_4096_PUB_LEN (RSA_4096_LEN * 2)
1390#define RSA_1152_PUB_LEN (RSA_1152_LEN * 2)
1391#define RSA_1408_PUB_LEN (RSA_1408_LEN * 2)
1392#define RSA_1536_PUB_LEN (RSA_1536_LEN * 2)
1393#define RSA_1976_PUB_LEN (RSA_1976_LEN * 2)
1394#define RSA_1984_PUB_LEN (RSA_1984_LEN * 2)
1395#define RSA_8192_PUB_LEN (RSA_8192_LEN * 2)
1396#define RSA_2304_PUB_LEN (RSA_2304_LEN * 2)
1397#define RSA_2560_PUB_LEN (RSA_2560_LEN * 2)
1398#define RSA_2816_PUB_LEN (RSA_2816_LEN * 2)
1399#define RSA_3072_PUB_LEN (RSA_3072_LEN * 2)
1400
1401#define MAX_RSA_PUB_LEN RSA_8192_PUB_LEN
1402#define MAX_RSA_LEN RSA_8192_LEN
1403
1404
1405/* ECC key sizes (bits) */
1406#define ECC_SECP112R1_LEN (112)
1407#define ECC_SECP112R2_LEN (112)
1408#define ECC_SECP128R1_LEN (128)
1409#define ECC_SECP128R2_LEN (128)
1410#define ECC_SECP160K1_LEN (160)
1411#define ECC_SECP160R1_LEN (160)
1412#define ECC_SECP160R2_LEN (160)
1413#define ECC_SECP192K1_LEN (192)
1414#define ECC_SECP192R1_LEN (192)
1415#define ECC_SECP224K1_LEN (224)
1416#define ECC_SECP224R1_LEN (224)
1417#define ECC_SECP256K1_LEN (256)
1418#define ECC_SECP256R1_LEN (256)
1419#define ECC_SECP384R1_LEN (384)
1420#define ECC_SECP521R1_LEN (521)
1421#define ECC_X9_62_PRIME192V1_LEN (ECC_SECP192R1_LEN)
1422#define ECC_X9_62_PRIME192V2_LEN (192)
1423#define ECC_X9_62_PRIME192V3_LEN (192)
1424#define ECC_X9_62_PRIME239V1_LEN (239)
1425#define ECC_X9_62_PRIME239V2_LEN (239)
1426#define ECC_X9_62_PRIME239V3_LEN (239)
1427#define ECC_X9_62_PRIME256V1_LEN (ECC_SECP256R1_LEN)
1428
1429#define ECC_BRAINPOOL_P160R1_LEN (160) // RFC 5639 standard curves
1430#define ECC_BRAINPOOL_P160T1_LEN (160)
1431#define ECC_BRAINPOOL_P192R1_LEN (192)
1432#define ECC_BRAINPOOL_P192T1_LEN (192)
1433#define ECC_BRAINPOOL_P224R1_LEN (224)
1434#define ECC_BRAINPOOL_P224T1_LEN (224)
1435#define ECC_BRAINPOOL_P256R1_LEN (256)
1436#define ECC_BRAINPOOL_P256T1_LEN (256)
1437#define ECC_BRAINPOOL_P320R1_LEN (320)
1438#define ECC_BRAINPOOL_P320T1_LEN (320)
1439#define ECC_BRAINPOOL_P384R1_LEN (384)
1440#define ECC_BRAINPOOL_P384T1_LEN (384)
1441#define ECC_BRAINPOOL_P512R1_LEN (512)
1442#define ECC_BRAINPOOL_P512T1_LEN (512)
1443
1444#define ECC_Ed25519_LEN (256)
1445#define ECC_Ed448_LEN (448)
1446#define ECC_X25519_LEN (256)
1447#define ECC_X448_LEN (448)
1448
1449/* Initialization vector sizes */
1450
1451#define DES_IV_LEN (DES_BLOCK)
1452#define AES_IV_LEN (AES_BLOCK)
1453#define AES_GCM_MIN_IV_LEN (12)
1454#define AES_GCM_MAX_IV_LEN (16)
1455#define AES_GCM_DEFAULT_IV_LEN (AES_GCM_MIN_IV_LEN)
1457#define MAX_IV_LEN (64)
1459/* Padding */
1460
1461#define D_DEFAULT_PADDING (0xFFFFFFFF) // Placeholder for default padding
1462#define D_NO_PADDING (0)
1463#define D_PKCS5_PADDING (1)
1464#define D_ZERO_PADDING (2)
1465#define D_OAEP_PADDING (3)
1466#define D_OAEP_SHA1_PADDING (D_OAEP_PADDING)
1467#define D_PKCS1_PADDING (4)
1468#define D_PSS_PADDING (5)
1469#define D_X931_PADDING (6)
1470#define D_PSS_SALT_LEN_MD_PADDING (7)
1471#define D_OAEP_SHA2_256_PADDING (8)
1472
1473
1474/* Key Blobs */
1475
1476#define PRIVATEKEY_BLOB (1)
1477#define PUBLICKEY_BLOB (2)
1478#define SIMPLE_BLOB (3)
1479#define PLAINTEXTKEY_BLOB (4)
1480#define RAW_BLOB (5) //Deprecated
1481#define HOTP_BLOB (6)
1482#define SIMPLE_BLOB_OAEP (7)
1483#define SIMPLE_BLOB_PKCS1 (SIMPLE_BLOB)
1484#define PUBLICKEY_BLOB_X509 (8)
1485#define SYM_WRAPPED_KEY_BLOB (9)
1486#define OPAQUE_BLOB (10)
1487#define PUBLICKEY_BLOB_HSM (11)
1488#define PUBLICKEY_RSA_PARTS_HSM (12)
1489#define PRIVATEKEY_BLOB_P8 (13)
1490#define PRIVATEKEY_BLOB_STRICT (14)
1491#define SYM_WRAPPED_KEY_BLOB_P11 (15)//Importkey only
1492#define WRAPPED_KEY_BLOB (16)
1493#define PRIVATE_RSA_KEY_INFO (17)
1494#define WRAPPED_KEY_BLOB_P8 (18)
1495#define WRAPPED_KEY_KMIP (19)
1496#define PUBLICKEY_BLOB_KMIP (20)
1497
1498
1499
1500/* Pkcs11 Blobs */
1501#define P11_BLOB (1)
1502
1503/* Pkcs11 Update Flags */
1504
1505#define UPDATE_P11_target ( 1 << 0 )
1506#define UPDATE_P11_associate ( 1 << 1 )
1507#define UPDATE_P11_Class ( 1 << 2 )
1508#define UPDATE_P11_App ( 1 << 3 )
1509#define UPDATE_P11_Id ( 1 << 4 )
1510#define UPDATE_P11_Label ( 1 << 5 )
1511#define UPDATE_P11_Trusted ( 1 << 6 )
1512#define UPDATE_P11_WrapWithTrusted ( 1 << 7 )
1513#define UPDATE_P11_Local ( 1 << 8 )
1514#define UPDATE_P11_CertificateCategory ( 1 << 9 )
1515#define UPDATE_P11_JavaMidpSecDomain ( 1 << 10 )
1516#define UPDATE_P11_KeyGenMechanism ( 1 << 11 )
1517
1518/* Key types */
1519
1520/* DGenerateKey DImportKey and related */
1521/* Flags */
1522#define EXPORTABLE_KEY (0x00000001) // Mark the key as exportable.
1523#define NO_CRYPTO (0x00000002) // The key will not be encrypted inside the HSM. Deprecated in newer versions.
1524#define TEMPORARY_KEY (0x00000004) // Mark key as temporary. Key will exist while the session exists. (default in ImportKey).
1525#define PERMANENT_KEY (0x00000008) // The key will be persistent in the HSM. (default in GenerateKey and ImportKeyPart).
1526#define RSA_PUB_EXP3 (0x00000800) // Use exponent 0x03 when generating a RSA key pair
1527#define MOD_SPB_RELATED (0x00001000) // Mark as mod_SPB related object
1528#define TSP_KEY (0x00002000) // TSP keys: don't replicate, export, backup, etc;
1529#define BCHAIN_KEY (0x00004000) // BChain keys: PBKs are handled specially, etc;
1530#define HSM_LOCAL_GEN (0x00008000) // set on HSM generated keys;
1531
1532// Attribute Usage-profile
1533#define AUP_DIG_SIG (0x01000000)
1534#define AUP_DATA_CRYPTO (0x02000000)
1535#define AUP_KeK (0x03000000)
1536#define AUP_MAC (0x04000000)
1537#define AUP_KDF (0x05000000)
1538#define AUP_CRYPTOGRAM (0x06000000)
1539#define AUP_KEY_TRANSLATE (0x07000000)
1540#define AUP_EFT_CVK (0x08000000)
1541#define AUP_EFT_VISA_PVK (0x09000000)
1542#define AUP_EFT_IBM_3624 (0x0a000000)
1543#define AUP_EFT_PEK (0x0b000000)
1544#define AUP_EFT_BDK (0x0c000000)
1545#define AUP_EFT_IPEK (0x0d000000)
1546#define AUP_EMV_IMK (0x0e000000)
1547#define AUP_EMV_IMKDAC (0x0f000000)
1548#define AUP_EMV_IMKENC (0x10000000)
1549#define AUP_EMV_IMKMAC (0x11000000)
1550#define AUP_EMV_KeK (0x12000000)
1551#define AUP_EMV_IMKKDF (0x13000000)
1552#define AUP_EMV_IMKACRYPTO (0x14000000)
1553#define AUP_EFT_KeK (0x15000000)
1554#define AUP_EMV_DIG_SIG (0x16000000)
1555#define AUP_EFT_TR31_KBPK (0x17000000)
1556#define AUP_EFT_TR34_PK (0x18000000)
1557#define AUP_SPB_PK (0x19000000)
1558#define AUP_EFT_X9_24_PART (0x1a000000)
1561#define AUP_RESERVED_MASK (0xFF000000) // Mask of reserved Usage profile bits.
1562
1563/* DRemoveKey */
1564#define REMOVE_FROM_HSM (0x00000020) // Erase a key from the HSM and destroys it's handle.
1565#define REMOVE_FROM_HCM (REMOVE_FROM_HSM) // DEPRECATED. use REMOVE_FROM_HSM
1566
1567/* SetKeyParam/GetKeyParam */
1568
1569#define DKP_ALGID (1)
1570#define DKP_IV (2)
1571#define DKP_PADDING (3)
1572#define DKP_MODE (4)
1573#define DKP_OWNER (5)
1574#define DKP_USER (6)
1575#define DKP_READ_LOCK (7)
1576#define DKP_ENCRYPTED (8)
1577#define DKP_KEYLEN (9)
1578#define DKP_TEMPORARY_KEY (10)
1579#define DKP_MAP_VALUE (11)
1580#define DKP_BLOCKED (12)
1581#define DKP_CERT_X509_INFO (13)
1582#define DKP_SESSION (14)
1583#define DKP_KEY_ID (15)
1584#define DKP_PUB_KEY_EXP (16)
1585#define DKP_SP80057_INFO (17)
1586#define DKP_KEY_INFO (18)
1587#define DKP_BLOCK_SIZE (19)
1588#define DKP_OBJ_ATTRIBUTES (20)
1589#define DKP_OBJ_STATS (21)
1590#define DKP_PQC_SIG_DET (22)
1591#define DKP_PQC_SIG_PH (23)
1592#define DKP_PQC_CTX (24)
1593#define DKP_IV_AUTO_GEN (25)
1595//Flags
1596#define REMOVE_ATTRIBUTE (0x00000040)
1597
1598/* SetHashParam/GetHashParam */
1599
1600#define DHP_ALGID (1) /* Hash algorithm. */
1601#define DHP_HASH_VALUE (2) /* Hash value. */
1602#define DHP_HASH_SIZE (4) /* Hash size (bytes). */
1603#define DHP_RESET (5) /* Reset hash state. */
1604
1605/* HashSessionKey */
1606
1607#define DHS_LITTLE_ENDIAN (1)
1608
1609/* DSetObjParam */
1610#define OP_OBJ_BLOCKED (1) /* User blocked */
1611#define OP_OBJ_UNBLOCKED (2) /* Used unblocked */
1612
1613/* LogParam */
1614
1615#define LP_LOG_PATH (0x00000001) /* Log file full path. */
1616#define LP_LOG_LEVEL (0x00000002) /* Log level. */
1617
1618#define LOG_ERROR_LEVEL (0)
1619#define LOG_DEBUG_LEVEL (3)
1620
1621#define LOG_DISABLED_LEVEL (1000)
1622
1623/*
1624 DGetHSMLogInit
1625 Remote log start and offset options
1626*/
1627
1628#define GET_LOG_START_FULL (0x00000000) //Deprecated - Use RLOG_GET_LOG_START_FULL instead.
1629#define GET_LOG_END_FULL (0x00000000) //Deprecated - Use RLOG_GET_LOG_END_FULL instead.
1630
1631#define RLOG_GET_LOG_START_FULL (0x00000000)
1632#define RLOG_GET_LOG_END_FULL (0x00000000)
1633
1634#define RLOG_GET_ZLOG_START_FULL (RLOG_GET_LOG_START_FULL)
1635#define RLOG_GET_ZLOG_END_FULL (0xFFFFFFFF)
1636
1637// Set both to get full compressed OEM log (pkzip format).
1638#define RLOG_GET_OEM_ZLOG_START_FULL (RLOG_GET_LOG_START_FULL)
1639#define RLOG_GET_OEM_ZLOG_END_FULL (RLOG_GET_ZLOG_END_FULL -1)
1640
1641
1642/* Permissions */
1643
1644#define ACL_NOP (0x00000000) // "may the Force be with ya'!"
1645#define ACL_OBJ_DEL (ACL_NOP + 1) // delete objects
1646#define ACL_OBJ_READ (ACL_OBJ_DEL << 1) // read obj content
1647#define ACL_OBJ_LIST (ACL_OBJ_READ) // list usr objs
1648#define ACL_OBJ_CREATE (ACL_OBJ_DEL << 2) // create obj
1649#define ACL_OBJ_UPDATE (ACL_OBJ_DEL << 3) // update obj (hdr and alike)
1650#define ACL_OBJ_WRITE (ACL_OBJ_UPDATE) // update obj
1651#define ACL_USR_CREATE (ACL_OBJ_DEL << 4) // create usr
1652#define ACL_USR_DELETE (ACL_USR_CREATE) // makes no sense only to create
1653#define ACL_USR_REMOTE_INFO (ACL_OBJ_DEL << 5) // can usr use remote log/info?
1654#define ACL_USR_LIST (ACL_OBJ_DEL << 6) // can usr get user-list?
1655#define ACL_SYS_OPERATOR (ACL_OBJ_DEL << 7) // operate as master (adm mode)
1656#define ACL_SYS_BACKUP (ACL_OBJ_DEL << 8) // extract full appliance backup
1657#define ACL_SYS_RESTORE (ACL_SYS_BACKUP) // restore full appliance backup
1658#define ACL_SYS_UDATE_HSM (ACL_OBJ_DEL << 9) // firmware and stuff like that
1659#define ACL_NS_AUTHORIZATION (ACL_OBJ_DEL << 10) // user must be authorized with "m of n"
1660#define ACL_LOCAL_CRYPTO (ACL_OBJ_DEL << 11) // user keys crypto ops must be done locally
1661#define ACL_VIRTUAL_X509_AUTH (ACL_OBJ_DEL << 28) // presence means SA (user must use 2F PKI)
1662#define ACL_VIRTUAL_OTP_AUTH (ACL_OBJ_DEL << 29) // presence means SA (user must use 2-F OTP)
1663#define ACL_CHANGE_PWD_NEXT_TIME (ACL_OBJ_DEL << 30) // can force usrs to change pwd on next login
1664
1665// Deprecated use ACL_USR_REMOTE_INFO
1666#define ACL_USR_REMOTE_LOG ACL_USR_REMOTE_INFO
1667
1668#define ACL_DEFAULT_OWNER (ACL_OBJ_DEL | ACL_OBJ_READ | ACL_OBJ_CREATE | \
1669 ACL_OBJ_UPDATE)
1670
1671#define ACL_SYS_PERMISSIONS (ACL_USR_CREATE | ACL_USR_REMOTE_INFO | ACL_USR_LIST | \
1672 ACL_SYS_OPERATOR | ACL_SYS_BACKUP | \
1673 ACL_SYS_UDATE_HSM)
1674
1675#define ACL_CREATION_TIME_ONLY (ACL_NS_AUTHORIZATION | ACL_LOCAL_CRYPTO)
1676
1677// DNSAuthSetState
1678
1679//
1680// NSAuth specific ACLs; NSAuth always grants ACL_OBJ_READ by default;
1681//
1682#define NSAUTH_ACL_NOP (ACL_NOP)
1683#define NSAUTH_ACL_OBJ_OPEN (ACL_OBJ_READ)
1684#define NSAUTH_ACL_OBJ_EXPORT (ACL_OBJ_CREATE)
1685#define NSAUTH_ACL_OBJ_DEL (ACL_OBJ_DEL)
1686#define NSAUTH_ACL_OBJ_BLOCK (ACL_OBJ_UPDATE)
1687#define NSAUTH_ACL_NS_DEL (ACL_USR_DELETE)
1688
1689/* DGenerateCVV/DVerifyCVV */
1690
1691#define MIN_CVV_LEN (3 + 1)
1692#define MAX_PAN_LEN (24 + 1)
1693#define MAX_EXP_DATE_LEN (4 + 1)
1694#define MAX_SVC_LEN (3 + 1)
1695
1696/* DEFTExportTR31 */
1697
1698// A.5.1, Table 6, inverted (little-endian);
1699#define EFT_ME_TR31_EXP_USAGE_AUTO (0x0000)
1700#define EFT_ME_TR31_EXP_USAGE_B0 (0x3042)
1701#define EFT_ME_TR31_EXP_USAGE_B1 (0x3142)
1702#define EFT_ME_TR31_EXP_USAGE_B2 (0x3242)
1703#define EFT_ME_TR31_EXP_USAGE_C0 (0x3043)
1704#define EFT_ME_TR31_EXP_USAGE_D0 (0x3044)
1705#define EFT_ME_TR31_EXP_USAGE_D1 (0x3144)
1706#define EFT_ME_TR31_EXP_USAGE_D2 (0x3244)
1707#define EFT_ME_TR31_EXP_USAGE_E0 (0x3045)
1708#define EFT_ME_TR31_EXP_USAGE_E1 (0x3145)
1709#define EFT_ME_TR31_EXP_USAGE_E2 (0x3245)
1710#define EFT_ME_TR31_EXP_USAGE_E3 (0x3345)
1711#define EFT_ME_TR31_EXP_USAGE_E4 (0x3445)
1712#define EFT_ME_TR31_EXP_USAGE_E5 (0x3545)
1713#define EFT_ME_TR31_EXP_USAGE_E6 (0x3645)
1714#define EFT_ME_TR31_EXP_USAGE_I0 (0x3049)
1715#define EFT_ME_TR31_EXP_USAGE_K0 (0x304B)
1716#define EFT_ME_TR31_EXP_USAGE_K1 (0x314B)
1717#define EFT_ME_TR31_EXP_USAGE_K2 (0x324B)
1718#define EFT_ME_TR31_EXP_USAGE_K3 (0x334B)
1719#define EFT_ME_TR31_EXP_USAGE_M0 (0x304D)
1720#define EFT_ME_TR31_EXP_USAGE_M1 (0x314D)
1721#define EFT_ME_TR31_EXP_USAGE_M2 (0x324D)
1722#define EFT_ME_TR31_EXP_USAGE_M3 (0x334D)
1723#define EFT_ME_TR31_EXP_USAGE_M4 (0x344D)
1724#define EFT_ME_TR31_EXP_USAGE_M5 (0x354D)
1725#define EFT_ME_TR31_EXP_USAGE_M6 (0x364D)
1726#define EFT_ME_TR31_EXP_USAGE_M7 (0x374D)
1727#define EFT_ME_TR31_EXP_USAGE_M8 (0x384D)
1728#define EFT_ME_TR31_EXP_USAGE_P0 (0x3050)
1729#define EFT_ME_TR31_EXP_USAGE_S0 (0x3053)
1730#define EFT_ME_TR31_EXP_USAGE_S1 (0x3153)
1731#define EFT_ME_TR31_EXP_USAGE_S2 (0x3253)
1732#define EFT_ME_TR31_EXP_USAGE_V0 (0x3056)
1733#define EFT_ME_TR31_EXP_USAGE_V1 (0x3156)
1734#define EFT_ME_TR31_EXP_USAGE_V2 (0x3256)
1735#define EFT_ME_TR31_EXP_USAGE_V3 (0x3356)
1736#define EFT_ME_TR31_EXP_USAGE_V4 (0x3456)
1737
1738// A.5.3, Table 8
1739#define EFT_ME_TR31_EXP_MODE_AUTO (0x00)
1740#define EFT_ME_TR31_EXP_MODE_B (0x42)
1741#define EFT_ME_TR31_EXP_MODE_C (0x43)
1742#define EFT_ME_TR31_EXP_MODE_D (0x44)
1743#define EFT_ME_TR31_EXP_MODE_E (0x45)
1744#define EFT_ME_TR31_EXP_MODE_G (0x47)
1745#define EFT_ME_TR31_EXP_MODE_N (0x4E)
1746#define EFT_ME_TR31_EXP_MODE_S (0x53)
1747#define EFT_ME_TR31_EXP_MODE_T (0x55)
1748#define EFT_ME_TR31_EXP_MODE_V (0x56)
1749#define EFT_ME_TR31_EXP_MODE_X (0x58)
1750#define EFT_ME_TR31_EXP_MODE_Y (0x59)
1751
1752// A.5.5, Table 10
1753#define EFT_ME_TR31_EXP_AUTO (0x00)
1754#define EFT_ME_TR31_EXP_X9_24 (0x45) // ANSI X9.24 approved kek form
1755#define EFT_ME_TR31_EXP_NON_EXPORTABLE (0x4E)
1756#define EFT_ME_TR31_EXP_KEK_EXPORTABLE (0x53)
1757
1758/* DGeneratePVV */
1759
1760#define EFT_MIN_PVKI (0x00)
1761#define EFT_MAX_PVKI (0x06)
1762#define EFT_PVV_LEN (4)
1763
1764/* DGeneratePIN */
1765
1766#define GP_DEFAULT_PIN (1)
1767#define GP_USER_DEF_PIN (2)
1768#define GP_RANDOM_PIN (3)
1769
1770/* DEFTExportKey/DEFTKeKImport */
1771
1772#define EK_EFT_KEK_EXPORT_RAW (1) // BLOB() == envelope + checksum[3];
1773#define EK_EFT_KEK_EXPORT_VISA1 (2) // Variant-1 ZCMK, BLOB() == envelope + checksum[3];
1774#define EK_EFT_KEK_EXPORT_LMK (3) // BLOB() == 3DES_CBC(SVMK, Key)
1775#define EK_EFT_KEK_EXPORT_JCB (4) // BLOB() == envelope + checksum[8];
1776
1777/* DPINBlockTranslate */
1778
1779// translate types
1780#define TP_TRANSLATE_TYPE_AUTO (0xFF)
1781#define TP_TRANSLATE_TYPE_IBM_3624 (0x36)
1782#define TP_TRANSLATE_TYPE_ISO_0 (1) // == VISA 1; HSM default
1783#define TP_TRANSLATE_TYPE_ISO_1 (2)
1784#define TP_TRANSLATE_TYPE_ISO_3 (3)
1785
1786/* Other constants */
1787
1788#define MAX_USR_PWD (16)
1789#define MAX_USR_LEN (16)
1790#define MAX_CN_LEN (256)
1791#define MAX_PATH_LEN (256)
1792#define MAX_MODULE_NAME_LEN (128)
1793#define MAX_MODULE_VERSION_LEN (32)
1794#define MAX_ADDR_LEN (128)
1795#define MAX_CHANNEL_CIPHER_NAME_LEN (128)
1796#define MIN_PIN_LEN (8)
1797#define MIN_BACKUP_OBJ_PIN_LEN (8)
1798#define MAX_BACKUP_OBJ_PIN_LEN (32)
1799#define MIN_BACKUP_PIN_LEN (8)
1800#define MAX_BACKUP_PIN_LEN (32)
1801#define MAX_OBJ_NAME_LEN (32)
1802#define MAX_PIN_LEN (6)
1803#define MAX_MODULE_NAME_VERSION_LEN (1024)
1804#define MAX_IP_LEN (15)
1805#define MAX_NET_NAME (16)
1806#define MAX_HOTP_PIN (4)
1807#define MAX_HOTP_IMEI (24)
1808#define MAX_HOTP_APP_NAME (13)
1809#define MAX_HOTP_LOGO_LEN (1632)
1810#define MAX_P11_OBJ_ID (128)
1811#define MAX_OBJ_ID_BIN_LEN (32 + 1)
1812#ifndef MAX_OBJ_ID
1813#define MAX_OBJ_ID MAX_OBJ_ID_BIN_LEN
1814#endif
1815#ifndef MAX_OBJ_ID_LEN
1816#define MAX_OBJ_ID_LEN (MAX_USR_LEN + 1 + MAX_OBJ_ID)
1817#endif
1818#ifndef MAX_OBJ_ID_FQN_LEN
1819#define MAX_OBJ_ID_FQN_LEN (MAX_OBJ_ID_LEN)
1820#endif
1821#define MAX_P11_DATE_TXT (8)
1822#define MIN_EFT_PIN_LEN (4)
1823#define MAX_EFT_PIN_LEN (12)
1824#define MIN_KSI_LEN (5)
1825#define MIN_CTR_LEN (5)
1826#define MAX_HSM_DOMAIN_NAME (32)
1827#define MAX_HSM_MODEL_NAME (32)
1828#define MAX_HSM_ID_NAME (32)
1829
1830
1831/* MOD EFT*/
1832
1833#define EFT_AES_KEY_CHECKSUM_LEN (3)
1834#define EFT_VISA_KEY_CHECKSUM_LEN (3)
1835#define EFT_JCB_KEY_CHECKSUM_LEN (8)
1836#define EFT_EXP_DATE_LEN (4)
1837
1838#define EFT_EMV_SDA_SEQ_LEN (2)
1839#define EFT_EMV_SDA_DAC_LEN (2)
1840#define EFT_EMV_ARC_LEN (2)
1841#define EFT_EMV_CSU_LEN (4)
1842#define EFT_EMV_PAD_LEN (8)
1843
1844#define EFT_EMV_IDN_LEN (2)
1845#define EFT_EMV_IDN_ATC_LEN (2)
1846#define EFT_EMV_IDN_UN_LEN (4)
1847
1848#define EFT_EMV_CSR_VISA_TRACK_NUM_LEN (3)
1849#define EFT_EMV_CSR_VISA_SERVICE_ID_LEN (4)
1850#define EFT_EMV_CSR_VISA_ISSUER_ID_LEN (4)
1851#define EFT_EMV_CSR_VISA_PUB_KEY_INDEX_LEN (3)
1852
1853#define EFT_EMV_CSR_VISA_HASH_SIZE (20)
1854#define EFT_EMV_CSR_MASTER_HASH_SIZE (28)
1855
1856
1857
1858/* DGenerateICCMK */
1859
1860#define EFT_EMV_GEN_ICC_MK_OP_CBC_EXP (0x01)
1861#define EFT_EMV_GEN_ICC_MK_OP_ECB_EXP (0x02)
1862
1863/* DMAC_ISO9797_1_Met2*/
1864
1865#define EMV_MAC_TYPE_ALG1 (1)
1866#define EMV_MAC_TYPE_ALG3 (2)
1867
1868/* DGenerateEMV_MAC/DGenerateEMV_HMAC/DCalculateARPC */
1869
1870#define EMV_OP_ISO_9797_1_M2_COMMON (0x01)
1871#define EMV_OP_ISO_9797_1_M2_MCHIP (0x02)
1872#define EMV_OP_ISO_9797_1_M2_VISA (0x03)
1873#define EMV_OP_ISO_9797_1_M2_VISA_CRYPTOGRAM (0x04)
1874#define EMV_OP_ISO_9797_1_M2_VISA_ICC_V1_4_PAN_AUTO (0x05)
1875#define EMV_OP_ISO_9797_1_M2_RAW (0x06)
1876#define EMV_OP_ISO_9797_1_M1_VISA_CRYPTOGRAM_PADD_V10 (0x7F)
1877#define EMV_OP_ISO_9797_1_M2_ELO (0x07)
1878#define EMV_OP_ISO_9797_1_M2_JCB (0x08)
1879#define EMV_OP_ISO_9797_1_M1_JCB (0x09)
1880#define EMV_OP_ISO_9797_1_M1_JCB_CRYPTOGRAM (0x0A)
1881
1882/* DGenerateDDA_ICCCert */
1883
1884#define EFT_EMV_DDA_OP_RSA_SIGN1 (0x01) // rsa + sha1
1885
1886/* DGenerateEMV_CSR */
1887
1888#define EFT_EMV_OP_CSR_VISA (0x01)
1889#define EFT_EMV_OP_CSR_MASTER (0x02)
1890#define EFT_EMV_OP_CSR_ELO (0x03)
1891#define EFT_EMV_OP_CSR_JCB (0x04)
1892
1893
1894/* DGenerateISO9796Cert2 */
1895
1896#define CORE_P_ISO_9796_USER_ID_LEN (32)
1897#define CORE_P_ISO_9796_USER_NAME_LEN (32)
1898#define CORE_P_ISO_9796_KEY_LEN (512) // 128
1899#define CORE_P_ISO_9796_MIN_KEY_LEN (64)
1900#define CORE_P_ISO_9796_EXPONENT_LEN (8)
1901#define CORE_P_ISO_9796_MIN_EXPONENT_LEN (1)
1902
1903
1904/* DGenerateEMV_PinBlock */
1905
1906#define PBC_EMV_PIN_BLOCK_OP_COMMON (EMV_OP_ISO_9797_1_M2_COMMON)
1907#define PBC_EMV_PIN_BLOCK_OP_MCHIP (EMV_OP_ISO_9797_1_M2_MCHIP)
1908#define PBC_EMV_PIN_BLOCK_OP_VISA (EMV_OP_ISO_9797_1_M2_VISA)
1909#define PBC_EMV_PIN_BLOCK_OP_VISA_CRYPTOGRAM (EMV_OP_ISO_9797_1_M2_VISA_CRYPTOGRAM)
1910#define PBC_EMV_PIN_BLOCK_OP_ELO (EMV_OP_ISO_9797_1_M2_ELO)
1911#define PBC_EMV_PIN_BLOCK_OP_JCB (EMV_OP_ISO_9797_1_M2_JCB)
1912
1913#define PBC_EMV_PIN_BLOCK_MAX_OUTPUT (64)
1914
1915
1916/* DDeriveKeyFromBuffer */
1917
1918#define EMV_DERIVE_KEY_OP_XOR (0x01)
1919#define EMV_DERIVE_KEY_OP_ECB (0x02)
1920
1921
1922/* DGeneratePKCS10CSR */
1923
1924#define CORE_P10_CSR_VERSION1 (0x00)
1925#define CORE_P10_CSR_DN_MAX_LEN (2048)
1926
1927#define P10_CSR_DER (1)
1928#define P10_CSR_PEM (2)
1929
1930#define CORE_P10_HASH_SHA1 (0x01)
1931#define CORE_P10_HASH_SHA224 (0x02)
1932#define CORE_P10_HASH_SHA256 (0x03)
1933#define CORE_P10_HASH_SHA384 (0x04)
1934#define CORE_P10_HASH_SHA512 (0x05)
1935#define CORE_P10_HASH_SHA2_224 CORE_P10_HASH_SHA224
1936#define CORE_P10_HASH_SHA2_256 CORE_P10_HASH_SHA256
1937#define CORE_P10_HASH_SHA2_384 CORE_P10_HASH_SHA384
1938#define CORE_P10_HASH_SHA2_512 CORE_P10_HASH_SHA512
1939#define CORE_P10_HASH_SHA3_224 (0x06)
1940#define CORE_P10_HASH_SHA3_256 (0x07)
1941#define CORE_P10_HASH_SHA3_384 (0x08)
1942#define CORE_P10_HASH_SHA3_512 (0x09)
1943
1944/* DPKCS8ExportKey */
1945
1946// ASCII
1947#define CORE_P8_EXPORT_PWD_LEN (16)
1948#define ND_MIN_P8_PWD_LEN (8)
1949#define ND_MAX_P8_PWD_LEN (CORE_P8_EXPORT_PWD_LEN)
1950
1951/* DImportPKCS12Buffer */
1952
1953#define DN_MAX_P12_PWD_LEN (CORE_P8_EXPORT_PWD_LEN)
1954
1955/* DExportPKCS12 */
1956
1957#define DN_EXPORT_P12_LEGACY (1)
1958
1959/* SPB */
1960
1961#define DN_SPB_MSG_HEADER_V2_LEN (588)
1962#define ND_SPB_MSG_HEADER_V2_LEN DN_SPB_MSG_HEADER_V2_LEN
1963#define DN_SPB_MSG_HEADER_V3_LEN ND_SPB_MSG_HEADER_V2_LEN
1964#define DN_SPB_MAX_NOTIFY_DATA_SEG (32 * 1024)
1965#define ND_SPB_MAX_NOTIFY_DATA_SEG DN_SPB_MAX_NOTIFY_DATA_SEG
1966#define DN_SPB_V3_TAG_LEN (16)
1967#define DN_SPB_MAX_RCV_NOTIFY_DATA_SEG (ND_SPB_MAX_NOTIFY_DATA_SEG + DN_SPB_V3_TAG_LEN)
1968
1969//dwFlags
1970#define ND_SPB_USE_CIP1 (0x80000000)
1971#define ND_SPB_USE_ANY (0x40000000)
1972#define ND_SPB_RAW (0x20000000)
1973
1974/* DSPBEncode */
1975
1976//dwFlags
1977#define ND_SPB_ENCODE_GEN_01 (0x01)
1978#define ND_SPB_ENCODE_HEADER_V3 (0x02)
1979
1980/* DSPBDecode */
1981
1982//dwFlags
1983#define ND_SPB_OUT_NO_PADDING (0x01)
1984#define ND_SPB_OUT_WITH_PADDING (0x02)
1985
1986#define ND_SPB_ISPB_LEN (8)
1987#define ND_SPB_CA_LEN (2)
1988#define ND_SPB_DOMAIN_MAX_LEN (5)
1989#define ND_SPB_SN_MAX_LEN (32)
1990#define ND_SPB_ID_MAX_LEN (ND_SPB_SN_MAX_LEN + 1 + ND_SPB_CA_LEN + 1)
1991#define ND_SPB_ID_MAX_FQN_LEN (MAX_USR_LEN + 1 + ND_SPB_SN_MAX_LEN + 1 + ND_SPB_CA_LEN + 1)
1992#define ND_SPB_MAX_SUBJECT (1024)
1993#define ND_SPB_MAX_ISSUER (1024)
1994#define ND_SPB_MAX_ALG_ID (256)
1995
1996
1997//strong auth
1998#define SA_TP_MAX_DES_LEN (16 + 1)
1999#define SA_TP_MAX_OFFSET_LEN (6 + 1)
2000#define SA_TP_MAX_SERIAL_LEN (10 + 1)
2001#define SA_TP_MAX_MKEY_LEN (32 + 1)
2002#define SA_TP_MAX_OTP_LEN (6 + 1)
2003
2004#define SA_HOTP_CHAP_LEN (10)
2005
2006/* Module OATH */
2007
2008/* DOATHIssueHOTPBlob */
2009#define ISSUE_OATH_MIN_OTP_LEN (6)
2010#define ISSUE_OATH_MAX_OTP_LEN (16)
2011#define ISSUE_OATH_MAX_OTP_RETRY (129)
2012
2013//bSeedLen
2014#define ISSUE_OATH_SHA1_LEN (20)
2015#define ISSUE_OATH_SHA256_LEN (32)
2016#define ISSUE_OATH_SHA512_LEN (64)
2017
2018//bTruncationOffset
2019#define ISSUE_OATH_DYN_TRUNC (OATH_SA_v1_HOTP_DYN_TRUNC_OFF)
2020
2021//wTimeStep
2022#define ISSUE_OATH_DEFAULT_TIME_STEP (OATH_SA_v2_default_TIME_STEP)
2023#define ISSUE_OATH_HOTP_TS (0)
2024
2025//otT0
2026#define ISSUE_OATH_HOTP_T0 (OATH_SA_v2_default_T0_Epoch)
2027
2028//otMovingFactor
2029#define ISSUE_OATH_INIT_MF (0)
2030
2031#define ISSUE_OATH_OUTPUT_BLOB_V1_LEN (160)
2032#define ISSUE_OATH_OUTPUT_BLOB_V2_LEN (180)
2033#define ISSUE_OATH_OUTPUT_BLOB_LEN (ISSUE_OATH_OUTPUT_BLOB_V1_LEN)
2034#define ISSUE_OATH_OUTPUT_MAX_BLOB_LEN (ISSUE_OATH_OUTPUT_BLOB_V2_LEN)
2035
2036#define OATH_MAX_PSK_LEN (255)
2037
2038#define ISSUE_OATH_GENERATE_HOTP (1)
2039#define ISSUE_OATH_GENERATE_TOTP (2)
2040#define ISSUE_OATH_IMPORT_HOTP (3)
2041#define ISSUE_OATH_IMPORT_TOTP (4)
2042
2043
2044#define OATH_UPDATE_BLOB (0x80000000)
2045
2046/* DOATHOcraGen */
2047#define DN_OATH_OCRA_USE_CTR (1 << 0)
2048#define DN_OATH_OCRA_USE_PH20 (1 << 1)
2049#define DN_OATH_OCRA_USE_PH32 (1 << 2)
2050#define DN_OATH_OCRA_USE_PH64 (1 << 3)
2051#define DN_OATH_OCRA_USE_TS (1 << 4)
2053#define DN_OATH_OCRA_MAX_SUITE_LEN (128)
2054#define DN_OATH_OCRA_CTR_LEN (8)
2055#define DN_OATH_OCRA_MAX_Q_LEN (128)
2056#define DN_OATH_OCRA_CSESS_MAX_LEN (512)
2057#define DN_OATH_OCRA_TIME_STEPS_LEN (8)
2059#define ISSUE_OATH_BLOB_V2_IV_LEN (AES_BLOCK)
2060#define ISSUE_OATH_BLOB_V2_TAG_LEN (AES_BLOCK)
2061
2062/* DOATHCheckOTP */
2063
2064#define MAX_OTP_LOOK_AHEAD_INTERVAL (255)
2065
2066
2067#define DEFAULT_PORT (4433)
2068
2069
2070/* DListObjsFilter */
2071
2072#define LST_NO_FILTER (1)
2073#define LST_FILTER (2)
2074
2075/* DSPBCalculateObjectId */
2076
2077#define SPB_GENERATE_KEY_NAME (1)
2078#define SPB_GENERATE_CER_NAME (2)
2079
2080
2081/* DIPFilterOperation */
2082
2083#define D_IPF_ENABLE (1)
2084#define D_IPF_DISABLE (2)
2085#define D_IPF_LIST (33)
2086#define D_IPF_ADD (44)
2087#define D_IPF_DEL (55)
2088
2089
2090/* DCert2CertInfo */
2091
2092#define P2C_SPB_CERT_INFO (1)
2093#define P2C_CERT_BASIC_INFO (2)
2094
2095//CERT_X509_BASIC_INFO
2096#define DN_MAX_SUBJECT (1024)
2097#define DN_MAX_ISSUER (1024)
2098#define DN_MAX_SN (1024)
2099#define DN_MAX_EMAIL (1024)
2100#define DN_MAX_ALG_ID (256)
2101
2102
2103/* DGenerateDUKPT */
2104
2105// flags/modes; duk, pek, and mek are mutually exclusive;
2106#define NEW_DUKPT_MODE_DUK (0x00000000)
2107#define NEW_DUKPT_MODE_EXP (1 << 31)
2108#define NEW_DUKPT_MODE_DE (1 << 30)
2109#define NEW_DUKPT_MODE_PEK (1 << 29)
2110#define NEW_DUKPT_MODE_MEK (1 << 28)
2111#define NEW_DUKPT_MODE_TMP (1 << 27)
2112#define NEW_DUKPT_MODE_IPEK (1 << 26)
2113
2114
2115/* DGetNetInfo */
2116
2117#define NET_INFO_MAX_SROUTE_COUNT (48)
2118#define NET_INFO_MAX_SROUTE_LEN (52)
2119#define NET_INFO_MAX_SNMP_T_COUNT (16)
2120#define NET_INFO_MAX_SNMP_SC_STR (255)
2121#define NET_INFO_MAX_SNMP_SL_STR (255)
2122#define NET_INFO_MAX_SNMP_C_STR (64)
2123
2124//Flags
2125#define NET_INFO_INFO_0 (0)
2126#define NET_INFO_INFO_1 (1)
2127
2128/* Bond mode - comes in bond gateway info. */
2129#define NET_INFO_BOND_HOT_STANDBY "hot standby"
2130#define NET_INFO_BOND_BALANCE "balance"
2131#define NET_INFO_BOND_AGGREGATION "aggregation"
2132
2133
2134
2135/* DCertEncodingConvert and DGetHSMTLSCert*/
2136
2137#define CERT_OUT_DER 1
2138#define CERT_OUT_PEM 2
2139
2140
2141
2142/* DGenEcdhKey - dwOP*/
2143
2144#define DN_GEN_KEY_KDF_RAW_SECRET (0x01)
2145#define DN_GEN_KEY_X9_63_SHA256 (0x02)
2146
2147
2148#define DN_ECDH_GEN_KEY_MAX_DATA (1024)
2149#define DN_GEN_ECDH_MAX_SHARED_LEN (128)
2150
2151/* DCreateHash */
2152
2153#define DN_HASH_OFFLINE (1)
2154
2155/* DFindHSM */
2156
2157//Service Type
2158#define DN_FIND_SRVC_TYPE_IP (1)
2159#define DN_FIND_SRVC_TYPE_AAP (2)
2160#define DN_FIND_SRVC_TYPE_ALL (3)
2161
2162//Filter
2163#define DN_FIND_FILTER_TYPE_POCKET (0x01)
2164#define DN_FIND_FILTER_TYPE_XP (0x02) //Not implemented
2165#define DN_FIND_FILTER_TYPE_ST (0x04) //Not implemented
2166#define DN_FIND_FILTER_TYPE_LEGACY (0x08) //Not implemented
2167#define DN_FIND_FILTER_TYPE_UNKNOWN (0x10) //Not implemented
2168#define DN_FIND_FILTER_TYPE_HSM (0x40000000)
2169#define DN_FIND_FILTER_TYPE_ALL (0x80000000)
2170
2171#define DN_SLP_POCKET_ID "$pocket"
2172#define DN_SLP_HSM_MODEL_POCKET "DMP"
2173#define DN_SLP_HSM_MODEL_XP "DXP"
2174#define DN_SLP_HSM_MODEL_ST "DST"
2175#define DN_SLP_HSM_MODEL_LEGACY "lhM"
2176#define DN_SLP_HSM_MODEL_UNKNOWN "DHSM"
2177
2178
2179/* DManageAToken */
2180
2181#define DN_USR_A_TOKEN_KLEN (16)
2182#define DN_RND_CHAP_LEN (16)
2183
2184#define DN_A_TOKEN_OP_ISSUE (1)
2185#define DN_A_TOKEN_OP_REVOKE (2)
2186#define DN_A_TOKEN_OP_LIST (3)
2187#define DN_A_TOKEN_OP_L_ISSUE (4)
2188#define DN_A_TOKEN_OP_L_REVOKE (5)
2189
2190#define DN_A_TOKEN_INFINITE (~0)
2191
2192
2193/* DBatchSign */
2194
2195#define DN_BATCH_SIGN_BLOCK_HEADER ((DWORD *2) + MAX_OBJ_ID_FQN_LEN)
2196
2197
2198/* DSetLBList and DGetLBList */
2199
2200#define DN_LB_LIST (1)
2201#define DN_MAX_LB_HSM_COUNT (16)
2202#define DN_MAX_LB_SETS (16)
2203
2204/* DGetUserKey */
2205
2206#define D_GET_USR_KEY_OFFLINE (1)
2207#define D_GET_USR_KEY_NO_PUB (2)
2208
2209/* DSVaultGenToken and DSVaultGetData */
2210
2211#define D_SVAULT_MIN_TL (6)
2212#define D_SVAULT_MAX_TL (256)
2213
2214#define D_SVAULT_T_TKR2 (1)
2215
2216#define D_SVAULT_F_MASK_TOKEN (1)
2217#define D_SVAULT_F_MASK_SECRET (2)
2218
2219#define D_SVAULT_CKS_NULL (0)
2220#define D_SVAULT_CKS_CPF (1)
2221#define D_SVAULT_CKS_CNPJ (2)
2222#define D_SVAULT_CKS_PAN (3)
2223#define D_SVAULT_CKS_IEL (4)
2224
2225#define D_SVAULT_BASE10 (10)
2226#define D_SVAULT_BASE16 (16)
2227#define D_SVAULT_BASE26 (26)
2228#define D_SVAULT_BASE52 (52)
2229#define D_SVAULT_BASE62 (62)
2230
2231#define D_SVAULT_TOKEN_BLOB_LEN (805)
2232
2233/* DSVaultGetData */
2234
2235#define D_SVAULT_GET_OP_SECRET (1)
2236#define D_SVAULT_GET_OP_TOKEN (2)
2237
2238/* DBchainCreateBip32Ckd */
2239
2240#define DN_BCHAIN_SECURE_BIP32_INDEX_BASE 0x80000000
2242/* DBchainGetAddress */
2243
2244#define DN_BCHAIN_MAX_ADDR_LEN (128)
2245#define DN_BCHAIN_MAX_HRP (64)
2247// Type
2248#define DN_BCHAIN_AT_BTC_P2PKH (1)
2249#define DN_BCHAIN_AT_BTC_P2SH (2)
2250#define DN_BCHAIN_AT_BTC_P2WPKH (3)
2251#define DN_BCHAIN_AT_BTC_P2WSH (4)
2252#define DN_BCHAIN_AT_BTC_B32_PKH (DN_BCHAIN_AT_BTC_P2WPKH)
2253#define DN_BCHAIN_AT_BTC_B32_SH (DN_BCHAIN_AT_BTC_P2WSH)
2254#define DN_BCHAIN_AT_ETH_EOA (5)
2255#define DN_BCHAIN_AT_ETH_EOA_MC_CKS (6)
2256#define DN_BCHAIN_AT_ETH_EOA_ICAP (7)
2257#define DN_BCHAIN_AT_ALGORAND (8)
2258#define DN_BCHAIN_AT_TRON_HEX (9)
2259#define DN_BCHAIN_AT_TRON_B58 (10)
2260#define DN_BCHAIN_AT_XRP (11)
2261#define DN_BCHAIN_AT_SOL (12)
2262#define DN_BCHAIN_AT_XLM (13)
2263#define DN_BCHAIN_AT_ADA_PKH (14)
2264#define DN_BCHAIN_AT_ADA_SH (15)
2265#define DN_BCHAIN_AT_LUNC (16)
2266#define DN_BCHAIN_AT_SS58 (17)
2267#define DN_BCHAIN_AT_XTZ (18)
2268#define DN_BCHAIN_AT_TON (19)
2269#define DN_BCHAIN_AT_TON_SH (20)
2270#define DN_BCHAIN_AT_ATOM (21)
2271#define DN_BCHAIN_AT_BTC_P2TR (22)
2273#define DN_BCHAIN_AT_LTC_P2PKH (DN_BCHAIN_AT_BTC_P2PKH)
2274#define DN_BCHAIN_AT_LTC_P2SH (DN_BCHAIN_AT_BTC_P2SH)
2275#define DN_BCHAIN_AT_LTC_P2WPKH (DN_BCHAIN_AT_BTC_P2WPKH)
2276#define DN_BCHAIN_AT_LTC_P2WSH (DN_BCHAIN_AT_BTC_P2WSH)
2277#define DN_BCHAIN_AT_LTC_P2TR (DN_BCHAIN_AT_BTC_P2TR)
2279// Version
2280#define DN_BCHAIN_VER_UNUSED (0x00)
2281#define DN_BCHAIN_VER_BTC_A1_MAIN_NET (0x00)
2282#define DN_BCHAIN_VER_BTC_AMN_TEST_NET (0x6F)
2283#define DN_BCHAIN_VER_BTC_A3_MAIN_NET (0x05)
2284#define DN_BCHAIN_VER_BTC_B32_WITVER (0x00)
2285#define DN_BCHAIN_VER_BTC_SEGWIT0 (0x00)
2286#define DN_BCHAIN_VER_BTC_SEGWIT1 (0x01)
2287#define DN_BCHAIN_VER_HTR_MAINNET (0x28)
2288#define DN_BCHAIN_VER_HTR_TESTNET (0x49)
2289#define DN_BCHAIN_VER_HTR_P2SH_MAINNET (0x64)
2290#define DN_BCHAIN_VER_HTR_P2SH_TESTNET (0x87)
2291#define DN_BCHAIN_VER_XRP_CLASSIC (0x00)
2292#define DN_BCHAIN_VER_LTC_SEGWIT0 (0x00)
2293#define DN_BCHAIN_VER_LTC_SEGWIT1 (0x01)
2294#define DN_BCHAIN_VER_LTC_AL_MAINNET (0x30)
2295#define DN_BCHAIN_VER_LTC_Amn_TESTNET (0x6F)
2296#define DN_BCHAIN_VER_LTC_AM_MAINNET (0x32)
2297#define DN_BCHAIN_VER_LTC_AQ_TESTNET (0x3A)
2298#define DN_BCHAIN_VER_ADA_MAINNET (0x01)
2299#define DN_BCHAIN_VER_ADA_TESTNET (0x00)
2300#define DN_BCHAIN_VER_SS58_POLKADOT (0x00)
2301#define DN_BCHAIN_VER_SS58_GEN_SUBST (0x2A)
2302#define DN_BCHAIN_VER_TON_MN_BWORK (0x01)
2303#define DN_BCHAIN_VER_TON_MN_MCHAIN (0x02)
2304#define DN_BCHAIN_VER_TON_TN_BWORK (0x03)
2305#define DN_BCHAIN_VER_TON_TN_MCHAIN (0x04)
2307// HRP
2308#define DN_BCHAIN_HRP_UNUSED ""
2309#define DN_BCHAIN_HRP_BTC_MAIN_NET "bc"
2310#define DN_BCHAIN_HRP_BTC_TEST_NET "tb"
2311#define DN_BCHAIN_HRP_LTC_MAINNET "ltc"
2312#define DN_BCHAIN_HRP_LTC_TESTNET "tltc"
2313#define DN_BCHAIN_HRP_TON_BNCBLE "bounceable"
2314#define DN_BCHAIN_HRP_TON_NBNCBLE "non-bounceable"
2316/* DBchainSignHash */
2317
2318#define DN_BCHAIN_MAX_SIG_LEN (128)
2320// Type
2321#define DN_BCHAIN_SIG_DER_ECDSA (1)
2322#define DN_BCHAIN_SIG_RAW_ECDSA (2)
2323#define DN_BCHAIN_SIG_BIP340 (3)
2324#define DN_BCHAIN_DER_RFC_6979_ECDSA (4)
2325#define DN_BCHAIN_RAW_RFC_6979_ECDSA (5)
2327#define DN_BCHAIN_SIG_RAW_ECDSA_R_LEN (32)
2328#define DN_BCHAIN_SIG_RAW_ECDSA_S_LEN (32)
2329#define DN_BCHAIN_SIG_RAW_ECDSA_V_LEN (1)
2331#define DN_BCHAIN_SIG_RAW_ECDSA_R_LEN (32)
2332#define DN_BCHAIN_SIG_RAW_ECDSA_S_LEN (32)
2333#define DN_BCHAIN_SIG_RAW_ECDSA_V_LEN (1)
2335// Hash mode
2336#define DN_BCHAIN_HASH_BTC_H160 (1)
2337#define DN_BCHAIN_HASH_RIPEMD160 (2)
2338#define DN_BCHAIN_HASH_SHA256 (3)
2339#define DN_BCHAIN_HASH_BTC_SHA256_2X (4)
2340#define DN_BCHAIN_HASH_KECCAK256 (5)
2341#define DN_BCHAIN_HASH_BLAKE2B224 (6)
2342#define DN_BCHAIN_HASH_BLAKE2B256 (7)
2344// Hash length
2345#define DN_BCHAIN_HASH_BTC_H160_LEN (20)
2346#define DN_BCHAIN_HASH_RIPEMD160_LEN (20)
2347#define DN_BCHAIN_HASH_SHA256_LEN (32)
2348#define DN_BCHAIN_HASH_BTC_SHA256_2X_LEN (32)
2349#define DN_BCHAIN_HASH_KECCAK256_LEN (32)
2350#define DN_BCHAIN_HASH_BLAKE2B224_LEN (28)
2351#define DN_BCHAIN_HASH_BLAKE2B256_LEN (32)
2353#define DN_BCHAIN_MAX_HASH_LEN (DN_BCHAIN_HASH_KECCAK256_LEN)
2355/* DBchainEdDsaSign and DBchainEdDsaVerify */
2356
2357#define DN_BCHAIN_EDDSA_MAX_CSTRL (255)
2358#define DN_BCHAIN_EDDSA_CSTR_UNUSED ""
2359#define DN_BCHAIN_EDDSA_MAX_DATA_LEN (4 * 1024 * 1024)
2361#define DN_BCHAIN_EDDSA_SIG_PURE (254)
2362#define DN_BCHAIN_EDDSA_SIG_ALGORAND (253)
2363#define DN_BCHAIN_EDDSA_SIG_XRP (252)
2364#define DN_BCHAIN_EDDSA_SIG_SOL (251)
2365#define DN_BCHAIN_EdDSA_SIG_XLM (250)
2366#define DN_BCHAIN_EdDSA_SIG_ADA (249)
2367#define DN_BCHAIN_EdDSA_SIG_DOT (248)
2368#define DN_BCHAIN_EdDSA_SIG_XTZ (247)
2369#define DN_BCHAIN_EdDSA_SIG_XTZ_PH (246)
2371/* DBchainPkImport and DBchainPkExport */
2372#define DN_BCHAIN_KEY_WIF (1)
2373#define DN_BCHAIN_KEY_MINI (2)
2374#define DN_BCHAIN_KEY_HEX (3)
2375#define DN_BCHAIN_KEY_SEC1 (4)
2376#define DN_BCHAIN_KEY_XPRIV (5)
2377#define DN_BCHAIN_KEY_ED25519_B64 (6)
2378#define DN_BCHAIN_KEY_ED25519_XPRIV (7)
2379#define DN_BCHAIN_KEY_Ed25519_SKPK (8)
2380#define DN_BCHAIN_KEY_Ed25519_SK (9)
2381#define DN_BCHAIN_KEY_Ed25519_XTZ (10)
2382#define DN_BCHAIN_KEY_P256_XPRIV (11)
2384// Version
2385#define DN_BCHAIN_VER_WIF_MAIN_NET (0x80)
2386#define DN_BCHAIN_VER_WIF_TEST_NET (0xEF)
2387#define DN_BCHAIN_VER_WIF_LTC_MAINNET (0xB0)
2390/* DBchainGetPubKey and DBchainVerify */
2391#define DN_BCHAIN_PBK_SEC1_UNCOMP (1)
2392#define DN_BCHAIN_PBK_SEC1_COMP (2)
2393#define DN_BCHAIN_PBK_BIP340 (3)
2394#define DN_BCHAIN_PBK_ED25519 (4)
2395#define DN_BCHAIN_PBK_AT_ALGORAND (5)
2396#define DN_BCHAIN_PBK_BIP32_XPUB (6)
2397#define DN_BCHAIN_PBK_AT_SOL (7)
2398#define DN_BCHAIN_PBK_AT_XLM (8)
2399#define DN_BCHAIN_PBK_ADA_VK (9)
2400#define DN_BCHAIN_PBK_AT_SS58 (10)
2401#define DN_BCHAIN_PBK_TON (11)
2402#define DN_BCHAIN_PBK_E_UNCOMP (12)
2404#define DN_BCHAIN_X_LEN (32)
2405#define DN_BCHAIN_Y_LEN (32)
2406#define DN_BCHAIN_MAX_PBK_LEN (128)
2409/* DBchainHashData */
2410
2411#define DN_BCHAIN_MAX_HDATA_LEN (2 * 1024 * 1024)
2413/*
2414 *
2415 * Unaligned structures
2416 *
2417 */
2418
2422typedef struct tag_SVAULT_GEN_TOKEN
2423{
2454 char szSecret[D_SVAULT_MAX_TL + 1];
2457
2462typedef struct tag_HSM_ADDR
2463{
2464 char szAddr[MAX_ADDR_LEN];
2465 int nPort;
2466 time_t tmNow;
2467 int nqtdcache; /* Amount of sessions in cache.*/
2468}HSM_ADDR;
2469
2474typedef struct tag_LOAD_BALANCE_LIST
2475{
2479
2485typedef struct tag_SLP_SRVR_INFO
2486{
2487 int nPort;
2488 char szIP[MAX_IP_LEN + 1];
2489 char szId[MAX_HSM_ID_NAME + 1];
2490 char szModel[MAX_HSM_MODEL_NAME + 1];
2492
2497typedef struct tag_DBLOB
2498{
2499 void *pvData;
2501} DBLOB;
2502
2503/* DCert2CertInfo */
2504
2505typedef struct tag_SPB_CERT_X509_INFO
2506{
2508
2509 char szAlgId[ND_SPB_MAX_ALG_ID];
2510
2511 char szISPB[ND_SPB_ISPB_LEN+1];
2512 char szCA[ND_SPB_CA_LEN+1];
2513 char szSN[ND_SPB_SN_MAX_LEN+1];
2514
2515 char szSubject[ND_SPB_MAX_SUBJECT];
2516 char szIssuer[ND_SPB_MAX_ISSUER];
2517
2518 struct tm tmNotBefore;
2519 struct tm tmNotAfter;
2520
2523
2524typedef struct tag_CERT_X509_BASIC_INFO
2525{
2527
2528 char szAlgId[DN_MAX_ALG_ID];
2529
2530 char szSubject[DN_MAX_SUBJECT];
2531 char szIssuer[DN_MAX_ISSUER];
2532 char szSN[DN_MAX_SN];
2533
2534 struct tm tmNotBefore;
2535 struct tm tmNotAfter;
2536
2539 char szEmail[DN_MAX_EMAIL];
2541
2542
2543typedef struct tag_IP_FILTER_INFO
2544{
2545 char szUser[MAX_USR_LEN + 1];
2546 char szIp[MAX_IP_LEN + 1];
2548
2549
2550/* DECPrivateKey2Info and DECPublicKey2Info */
2551
2552#define DN_EC_MAX_BIG_NUM (1024)
2553
2554//Field type definitions
2555#define DN_EC_KEY_FIELD_TYPE_NOT_DEFINED (0)
2556#define DN_EC_KEY_FIELD_TYPE_PRIME_FIELD (1)
2557#define DN_EC_KEY_FIELD_TYPE_BINARY_FIELD (2)
2558
2559//Out format options
2560#define DN_BN_2_ARRAY_OUT_BIN (1)
2561#define DN_BN_2_ARRAY_OUT_HEX (2)
2562#define DN_EC_KEY_PUB_X962_EC_POINT (3)
2563#define DN_EC_KEY_OUT_SPKI (4)
2564
2565//In format options
2566#define DN_EC_KEY_IN_FORMAT_DER (1)
2567#define DN_EC_KEY_IN_FORMAT_RAW_OCTET (2)
2568#define DN_EC_KEY_IN_FORMAT_EC_PUB_KEY_PARTS (3)
2569
2570typedef struct tag_DN_EC_BIG_NUMBER
2571{
2575
2576typedef struct tag_DN_EC_POINT_INFO
2577{
2578 DN_EC_BIG_NUMBER bnX;//Point's x-coordinate
2579 DN_EC_BIG_NUMBER bnY;//Point's y-coordinate
2581
2582typedef struct tag_DN_EC_GROUP_INFO
2583{
2584 int nFieldType; //See definitions above
2585
2586 DN_EC_BIG_NUMBER bnP;//In Fp fields this is p for F2M fields it's m
2587
2588 DN_EC_BIG_NUMBER bnA;//Parameter a of the equation
2589 DN_EC_BIG_NUMBER bnB;//Parameter b of the equation
2590
2592
2593 DN_EC_BIG_NUMBER bnOrder;//Order n of the generator g
2594 DN_EC_POINT_INFO stGeneratorPoint;//Generator g / base point
2596
2597typedef struct tag_DN_EC_PUB_KEY_INFO
2598{
2602
2603typedef struct tag_DN_EC_PRIV_KEY_INFO
2604{
2608
2620
2624typedef struct tag_RSA_PUB_KEY_PARTS
2625{
2629
2633typedef struct tag_EC_PUB_KEY_PARTS
2634{
2638
2642typedef struct tag_DN_RSA_BIG_NUMBER
2643{
2647
2656
2657#define DN_USER_INFO_CERT_OP_ASSOCIATE (1)
2658#define DN_USER_INFO_CERT_OP_UNASSOCIATE (2)
2659
2663typedef struct tag_USER_INFO_CERT
2664{
2665 char szUserId[MAX_USR_LEN + 1];
2673
2677typedef struct tag_TLS_BUNDLE_INFO
2678{
2680 char szCERT[MAX_OBJ_ID_FQN_LEN];
2682
2686typedef struct tag_DN_EFTD_CONF
2687{
2692
2697typedef struct tag_DN_EFTD_KEY_ALIAS
2698{
2700 char szAlias[DN_EFTD_MAX_KEY_ALIAS_LEN + 1];
2702
2718
2722typedef struct tag_GET_USR_KEY_OFFLINE
2723{
2724 char szKeyId[MAX_OBJ_ID_LEN];
2731
2759
2764typedef struct tag_DN_OBJ_COUNT
2765{
2768} DN_OBJ_COUNT;
2769
2774typedef struct tag_DN_USER_OBJ_COUNT
2775{
2776 char szUserId[MAX_OBJ_ID_FQN_LEN];
2780
2781#define DN_MAX_PRIVATE_KEY_ATTR_LEN (RSA_8192_LEN + 1)
2782
2802
2803
2804#define DN_SC_MAX_ATR_LEN (255)
2805#define DN_SC_MAX_CARD_FAMILY_LEN (128)
2806#define DN_SC_MAX_CARD_PRODUCT_NAME_LEN (128)
2807#define DN_SC_MAX_CARD_OS_VERSION_LEN (64)
2837
2838#ifdef _WIN32
2839 #pragma pack(push, 1) /* Align by 1 for portability issues.*/
2840#else
2841 #pragma pack(1)
2842#endif
2843
2844/* Aligned structures */
2845
2850typedef struct tag_DN_LIC_INFO
2851{
2856 char szLicName[DN_LIC_MAX_NAME + 1];
2857} DN_LIC_INFO;
2858
2859typedef struct tag_OBJ_HDR_V1
2860{
2865} OBJ_HDR_V1;
2866
2867/*
2868 Estrutura contendo os atributos SP80057 de um objeto do HSM.
2869*/
2885
2886
2887/*
2888 Estados de objetos KMIP/SP.800-57.
2889*/
2890#define DN_SL_SP80057_STATE_UNKNOWN (0)
2891#define DN_SL_SP80057_STATE_PRE_ACTIVE (1)
2892#define DN_SL_SP80057_STATE_ACTIVE (2)
2893#define DN_SL_SP80057_STATE_DEACTIVATED (3)
2894#define DN_SL_SP80057_STATE_COMPROMISED (4)
2895#define DN_SL_SP80057_STATE_DESTROYED (5)
2896#define DN_SL_SP80057_STATE_DESTROYED_C (6)
2897
2898/*
2899 Máscara de uso de objetos SP.800-57.
2900*/
2901#define DN_SP80057_UM_SIGN (0x00000001)
2902#define DN_SP80057_UM_VERIFY (0x00000002)
2903#define DN_SP80057_UM_ENCRYPT (0x00000004)
2904#define DN_SP80057_UM_DECRYPT (0x00000008)
2905#define DN_SP80057_UM_WRAP_KEY (0x00000010)
2906#define DN_SP80057_UM_UNWRAP_KEY (0x00000020)
2907#define DN_SP80057_UM_EXPORT (0x00000040)
2908#define DN_SP80057_UM_MAC_GENERATE (0x00000080)
2909#define DN_SP80057_UM_MAC_VERIFY (0x00000100)
2910#define DN_SP80057_UM_DERIVE_KEY (0x00000200)
2911#define DN_SP80057_UM_CONTENT_COMMITMENT (0x00000400)
2912#define DN_SP80057_UM_KEY_AGREEMENT (0x00000800)
2913#define DN_SP80057_UM_CERTIFICATE_SIGN (0x00001000)
2914#define DN_SP80057_UM_CRL_SIGN (0x00002000)
2915#define DN_SP80057_UM_GENERATE_CRYPTOGRAM (0x00004000)
2916#define DN_SP80057_UM_VALIDATE_CRYPTOGRAM (0x00008000)
2917#define DN_SP80057_UM_TRANSLATE_ENCRYPT (0x00010000)
2918#define DN_SP80057_UM_TRANSLATE_DECRYPT (0x00020000)
2919#define DN_SP80057_UM_TRANSLATE_WRAP (0x00040000)
2920#define DN_SP80057_UM_TRANSLATE_UNWRAP (0x00080000)
2921
2922
2923/* DListObjsFilter */
2924
2925typedef struct tag_OBJ_LIST_FILTER
2926{
2930
2931#define OBJ_LIST_VERB_VERSION ( 1 << 0 )
2932#define OBJ_LIST_VERB_TYPE ( 1 << 1 )
2933#define OBJ_LIST_VERB_ATTRIB ( 1 << 2 )
2934#define OBJ_LIST_OBJS_OR ( 1 << 31 )
2935
2950
2985
3020
3051
3055typedef struct tag_ISSUE_OATH_BLOB_t_v1
3056{
3058 DWORD pad_cks_tag[3];
3060
3064typedef struct tag_ISSUE_OATH_BLOB_t_v2
3065{
3070
3074typedef struct tag_OATH_PSKC_TRANSLATE_OUTPUT
3075{
3077 char szKeyId[OATH_MAX_PSK_LEN+1];
3079
3096
3097typedef struct tag_MOD_OATH_SA_v2
3098{
3108} OATH_SA_v2;
3109
3110
3111typedef struct tag_STAT_CLUSTER_IP
3112{
3113 char szIp[MAX_IP_LEN + 1];
3115
3116
3117//GMT
3118typedef struct tag_P11_DATE{
3119 char year[4]; /* the year ("1900" - "9999") */
3120 char month[2]; /* the month ("01" - "12") */
3121 char day[2]; /* the day ("01" - "31") */
3122} P11_DATE;
3123
3135
3136typedef struct tag_HOTP_INFO_EX
3137{
3138 DWORD dwStructId; //Structure identifier -> SA_ST_ID_HOTP_INFO_EX
3139 char szObjId[MAX_OBJ_NAME_LEN + 1]; //HSM HOTP object name
3140 DWORD dwObjAttr; //HSM object attributes
3141 DWORD dwObjHotpFlags; //SoftToken type -> SA_ATTR_OATH_USE_IMEI, SA_ATTR_OATH_USE_TIME ...
3142 char szStPin[MAX_HOTP_PIN + 1]; //SoftToken PIN
3143 char szStIMEI[MAX_HOTP_IMEI + 1]; //SoftToken related device's serial number
3144 char szStAppName[MAX_HOTP_APP_NAME + 1]; //SoftToken application name
3145 DBLOB *pdbStLogoImage; //SoftToken logo image
3146}HOTP_INFO_EX; //DESCONTINUADO!
3147
3148
3149//DGetNetInfo
3150typedef struct tag_SYS_NET_INFO
3151{
3152 BYTE pbMac[6];
3153 char szIp[MAX_IP_LEN + 1];
3154 char szMask[MAX_IP_LEN + 1];
3155 char szDefGateway[MAX_IP_LEN + 1];
3158 char szName[MAX_NET_NAME + 1];
3159} SYS_NET_INFO;
3160
3161typedef struct tag_SYS_NET_INFO_1
3162{
3165
3167 char szCommunity[NET_INFO_MAX_SNMP_C_STR + 1];
3168 char szSysContact[NET_INFO_MAX_SNMP_SC_STR + 1];
3169 char szSyaLocation[NET_INFO_MAX_SNMP_SL_STR + 1];
3172
3177typedef struct tag_SYS_HEALTH
3178{
3181}SYS_HEALTH;
3182
3189
3204
3217
3218
3219#define DN_MAX_HSM_ALIAS (128)
3220#define DN_UPACK_MAX_DESCRIPTION (255 + 1)
3221
3226typedef struct tag_SYS_PENDING_INFO
3227{
3229 char szPendingUpackDescription[DN_UPACK_MAX_DESCRIPTION];
3230 char szHsmAlias[DN_MAX_HSM_ALIAS+1];
3232
3233
3234typedef struct tag_SYS_HW_STR_INFO
3235{
3236 char szSerialNumber[GET_INFO_MAX_SN_LEN + 1];
3237 char szHardwareString[GET_INFO_MAX_HW_STR_LEN + 1];
3238 char szTpKey[GET_INFO_MAX_TPKEY_LEN + 1];
3240
3241typedef struct tag_SYS_NTP_SVR_INFO
3242{
3243 char szAddr[MAX_IP_LEN + 1];
3244 char szNtpqInfo[GET_INFO_MAX_NTPQ_LEN + 1];
3247 char szKeyType[GET_INFO_MAX_NTP_KT_LEN + 1];
3248 char szKeyMat[GET_INFO_MAX_NTP_KM_LEN + 1];
3250
3251typedef struct tag_SYS_NTP_INFO
3252{
3256
3257
3258
3259typedef struct tag_SYS_REPL_INFO
3260{
3267 DWORD dwaPeers[GET_INFO_MAX_REPL_NODES + 1]; //Zero terminated IPv4 array. Last item == 0x00000000
3268 DWORD dwaPendingAcks[GET_INFO_MAX_REPL_NODES + 1]; //Zero terminated IPv4 array. Last item == 0x00000000
3275 DWORD dwaNodes[GET_INFO_MAX_REPL_NODES + 1]; //Zero terminated IPv4 array. Last item == 0x00000000
3277
3278
3296
3297
3298typedef struct tag_REPL_NODE_MSG
3299{
3300 BYTE bOP; //RNM_PROBE, RNM_DOWN...
3303
3304
3305typedef struct tag_HOTP_CHAP
3306{
3307 DWORD dwStructId; //Structure Id -> SA_ST_ID_HOTP_CHAP
3308 char szChallenge[SA_HOTP_CHAP_LEN + 1]; //Server created challenge
3309}HOTP_CHAP;//DEPRECATED!
3310
3311typedef struct tag_HOTP_SYNC
3312{
3313 DWORD dwStructId; //Structure Id -> SA_ST_ID_HOTP_SYNC
3314 char szObjId[MAX_OBJ_NAME_LEN + 1]; //HOTPToken to synchronize
3315 char szOTP1[SA_TP_MAX_OTP_LEN]; //Expected response from HOTPToken
3316 char szOTP2[SA_TP_MAX_OTP_LEN]; //Server Counter Response
3317}HOTP_SYNC;
3318
3319typedef struct tag_HIP_PARAM
3320{
3324}HIP_PARAM; //DEPRECATED!
3325
3326typedef struct tag_HIP_OUTPUT
3327{
3328 char szHipChallenge[1];
3330 BYTE pbImage[1];
3331}HIP_OUTPUT; //DEPRECATED!
3332
3336typedef struct tag_USER_BLOCK
3337{
3338 char szUserId[MAX_USR_LEN+1];
3341}USER_BLOCK;
3342
3346typedef struct tag_DN_A_TOKEN
3347{
3348 char pcUserName[MAX_USR_LEN];
3350}DN_A_TOKEN;
3351
3356typedef struct tag_DN_A_TOKEN_FULL
3357{
3361
3373
3392
3393/* HTTP session parameters */
3394
3395#define MAX_HTTP_ADDR_LEN (2048)
3396#define MAX_HTTP_API_TOKEN_LEN (128)
3397
3407
3412typedef struct tag_AUTH_ATOKEN
3413{
3414 char szAddr[MAX_ADDR_LEN];
3415 int nPort;
3418
3423typedef struct tag_AUTH_WIN_CREDENTIAL
3424{
3425 char szAddr[MAX_ADDR_LEN];
3426 int nPort;
3428
3440
3450
3451/*
3452 Estados de autorização de partição do usuário.
3453*/
3454
3455#define ND_PA_ACL_OBJ_OPEN (ACL_OBJ_READ)
3456#define ND_PA_ACL_OBJ_EXPORT (ACL_OBJ_CREATE)
3457#define ND_PA_ACL_OBJ_DEL (ACL_OBJ_DEL)
3458#define ND_PA_ACL_OBJ_BLOCK (ACL_OBJ_UPDATE)
3459#define ND_PA_ACL_NS_DEL (ACL_USR_DELETE)
3460
3461#define NSAUTH_ACL_FULL (~0)
3462
3463/*
3464 Estados de autorização de partição do usuário.
3465*/
3466#define ND_PA_STATE_Unknown (0)
3467#define ND_PA_STATE_Absent (1)
3468#define ND_PA_STATE_Null (2)
3469#define ND_PA_STATE_Associated (3)
3470#define ND_PA_STATE_Authorized (4)
3471
3475typedef struct tag_USER_PA_INFO
3476{
3477 char szUserId[MAX_USR_LEN + 1];
3496
3504
3505typedef struct tab_EXT_MAP_2_OBJ_INFO
3506{
3508 char szObjId1[MAX_OBJ_ID_FQN_LEN];
3510 char szObjId2[MAX_OBJ_ID_FQN_LEN];
3512
3513
3519
3520typedef struct tag_PKCS11_OBJ_MAP
3521{
3524
3525 DWORD Class; // CKO_DATA, etc;
3526
3530
3531 //The three BYTEs below are overloaded
3532 //must use the MACROs to set the desired parameters.
3533 //Macros defined below.
3534
3535 BYTE Trusted; // boolean/overloaded
3536 BYTE WrapWithTrusted; // boolean/overloaded
3537 BYTE Local; // boolean/overloaded
3538
3543
3544//Trusted -> CKA_TRUSTED, CKA_DERIVE, CKA_ENCRYPT,
3545//CKA_DECRYPT, CKA_WRAP, CKA_UNWRAP
3546#define PKCS11_SET_FLAG(x, p) ((x) |= (1 << (p)))
3547#define PKCS11_UNSET_FLAG(x, p) ((x) &= ~(1 << (p)))
3548#define PKCS11_GET_FLAG(x, p) ((x) & (1 << (p)))
3549
3550//Enable driven option. Disabled by default.
3551#define PKCS11_SET_OBJ_MAP_CKA_TRUSTED(x) PKCS11_SET_FLAG(x, 7)
3552#define PKCS11_UNSET_OBJ_MAP_CKA_TRUSTED(x) PKCS11_UNSET_FLAG(x, 7)
3553#define PKCS11_GET_OBJ_MAP_CKA_TRUSTED(x) PKCS11_GET_FLAG(x, 7)
3554
3555//Disable driven option. Enabled by default.
3556#define PKCS11_SET_OBJ_MAP_CKA_DERIVE(x) PKCS11_UNSET_FLAG(x, 6)
3557#define PKCS11_UNSET_OBJ_MAP_CKA_DERIVE(x) PKCS11_SET_FLAG(x, 6)
3558#define PKCS11_GET_OBJ_MAP_CKA_DERIVE(x) (!PKCS11_GET_FLAG(x, 6))
3559
3560#define PKCS11_SET_OBJ_MAP_CKA_ENCRYPT(x) PKCS11_UNSET_FLAG(x, 5)
3561#define PKCS11_UNSET_OBJ_MAP_CKA_ENCRYPT(x) PKCS11_SET_FLAG(x, 5)
3562#define PKCS11_GET_OBJ_MAP_CKA_ENCRYPT(x) (!PKCS11_GET_FLAG(x, 5))
3563
3564#define PKCS11_SET_OBJ_MAP_CKA_DECRYPT(x) PKCS11_UNSET_FLAG(x, 4)
3565#define PKCS11_UNSET_OBJ_MAP_CKA_DECRYPT(x) PKCS11_SET_FLAG(x, 4)
3566#define PKCS11_GET_OBJ_MAP_CKA_DECRYPT(x) (!PKCS11_GET_FLAG(x, 4))
3567
3568#define PKCS11_SET_OBJ_MAP_CKA_WRAP(x) PKCS11_UNSET_FLAG(x, 3)
3569#define PKCS11_UNSET_OBJ_MAP_CKA_WRAP(x) PKCS11_SET_FLAG(x, 3)
3570#define PKCS11_GET_OBJ_MAP_CKA_WRAP(x) (!PKCS11_GET_FLAG(x, 3))
3571
3572#define PKCS11_SET_OBJ_MAP_CKA_UNWRAP(x) PKCS11_UNSET_FLAG(x, 2)
3573#define PKCS11_UNSET_OBJ_MAP_CKA_UNWRAP(x) PKCS11_SET_FLAG(x, 2)
3574#define PKCS11_GET_OBJ_MAP_CKA_UNWRAP(x) (!PKCS11_GET_FLAG(x, 2))
3575
3576//WrapWithTrusted
3577
3578//Enable driven option. Disabled by default.
3579#define PKCS11_SET_OBJ_MAP_CKA_WRAP_WITH_TRUSTED(x) PKCS11_SET_FLAG(x, 7)
3580#define PKCS11_UNSET_OBJ_MAP_CKA_WRAP_WITH_TRUSTED(x) PKCS11_UNSET_FLAG(x, 7)
3581#define PKCS11_GET_OBJ_MAP_CKA_WRAP_WITH_TRUSTED(x) PKCS11_GET_FLAG(x, 7)
3582
3583//Local
3584//Enable driven option. Disabled by default.
3585#define PKCS11_SET_OBJ_MAP_CKA_LOCAL(x) PKCS11_SET_FLAG(x, 7)
3586#define PKCS11_UNSET_OBJ_MAP_CKA_LOCAL(x) PKCS11_UNSET_FLAG(x, 7)
3587#define PKCS11_GET_OBJ_MAP_CKA_LOCAL(x) PKCS11_GET_FLAG(x, 7)
3588
3589//DAdmOperation options - AO_SET_PWD_SEC_POLICY/AO_GET_PWD_SEC_POLICY
3590
3591#define PWD_SEC_POLICY_USE_MIN_PWD_LEN (8)
3592#define PWD_SEC_POLICY_USE_MAX_PWD_LEN (16)
3594typedef struct tag_PWD_SEC_POLICY
3595{
3596 //USE
3597 BYTE bMaxInvalidLogins; //Number of attempts. 0 == sets to HSM internal default.
3598 BYTE bExpiration; //Number of days. 0 == disable policy.
3599 BYTE bHistory; //Number of passwords to track. 0 == disable policy.
3600 //FORMAT
3601 BYTE bMinLength; //Minimal number of chars (ASCII).
3602 BYTE bMinSpecial; //Minimal number of non-alpha chars.
3603 BYTE bUpper; //Minimal number of upper-case chars.
3604 BYTE bLower; //Minimal number of lower-case chars.
3606
3610typedef struct tag_EFT_VISA_KEY_PARTS
3611{
3612 BYTE pbKeyPart1[3 * DES_BLOCK];
3613 BYTE pbKeyPart1Checksum[EFT_VISA_KEY_CHECKSUM_LEN];
3614 BYTE pbKeyPart2[3 * DES_BLOCK];
3615 BYTE pbKeyPart2Checksum[EFT_VISA_KEY_CHECKSUM_LEN];
3616 BYTE pbKeyPart3[3 * DES_BLOCK];
3617 BYTE pbKeyPart3Checksum[EFT_VISA_KEY_CHECKSUM_LEN];
3620
3624typedef struct tag_EFT_AES_KEY_PARTS
3625{
3626 BYTE pbKeyPart1[ALG_AES_256_LEN];
3627 BYTE pbKeyPart2[ALG_AES_256_LEN];
3628 BYTE pbKeyPart3[ALG_AES_256_LEN];
3631
3635typedef struct tag_EFT_AES_KEY_PARTS_DATA
3636{
3640
3644typedef struct tag_EFT_FULL_CKS_KEY_PARTS
3645{
3646 BYTE pbKeyPart1[3 * DES_BLOCK];
3647 BYTE pbKeyPart1Checksum[DES_BLOCK];
3648 BYTE pbKeyPart2[3 * DES_BLOCK];
3649 BYTE pbKeyPart2Checksum[DES_BLOCK];
3650 BYTE pbKeyPart3[3 * DES_BLOCK];
3651 BYTE pbKeyPart3Checksum[DES_BLOCK];
3652 BYTE pbMKCheckSum[DES_BLOCK];
3654
3659typedef struct tag_DN_CALC_ARPC_EMV_METHOD_1
3660{
3661 char szIssuerMK[MAX_OBJ_ID_BIN_LEN];
3662 char szPAN[MAX_PAN_LEN];
3664 BYTE pbARQC[DES_BLOCK];
3666 BYTE pbNONCE[DES_BLOCK];
3669
3670typedef struct tag_DN_CALC_ARPC_EMV_METHOD_2
3671{
3672 char szIssuerMK[MAX_OBJ_ID_BIN_LEN];
3673 char szPAN[MAX_PAN_LEN];
3675 BYTE pbNONCE[DES_BLOCK];
3678 BYTE pbARQC[DES_BLOCK];
3684
3685
3699
3705typedef struct tag_DS_BIND_INFO
3706{
3709 char szHSM[D_MAX_DS_BIND_B62_ID + 1];
3712 char szAccount[D_MAX_DS_BIND_B62_ID + 1];
3717 char szURL[D_MAX_DS_BIND_URL + 1];
3719} DS_BIND_INFO;
3720
3721#define DN_RCC_MAX_NODE_COUNT (16)
3722#define DN_RCC_MAX_REPL_MC_VER (256)
3723
3728typedef struct tag_CROSS_CHECK_NODE
3729{
3734 char szVersion[DN_RCC_MAX_REPL_MC_VER];
3736
3737/*
3738 Blockchain module
3739*/
3740
3741/* DBchainCreateCkd */
3742
3743// Key Derivation Types
3744#define DN_BCHAIN_BIP32_Ed_KDT_SLIP10 (1)
3745#define DN_BCHAIN_BIP32_Ed_KDT_FPRV1 (2)
3747#define DN_BCHAIN_BIP32_P256_KDT_SLIP10 (1)
3749/* DBchainCreateXPrv */
3750
3751// Types
3752#define DN_BCHAIN_BTC_MINIKEY (1)
3753#define DN_BCHAIN_BIP32_SEED_XPRV (2)
3754#define DN_BCHAIN_BIP39_SEED_XPRV (3)
3755#define DN_BCHAIN_BIP32_XPRV (4)
3756#define DN_BCHAIN_BIP32_ED25519_XPRV (5)
3757#define DN_BCHAIN_BIP32_P256_XPRV (6)
3759// Version
3760#define DN_BCHAIN_VER_BIP32_MAINNET (DN_BCHAIN_VER_WIF_MAIN_NET)
3761#define DN_BCHAIN_VER_BIP32_TESTNET (DN_BCHAIN_VER_WIF_TEST_NET)
3762#define DN_BCHAIN_VER_BIP32_HTR_MAINNET (1)
3763#define DN_BCHAIN_VER_BIP32_HTR_TESTNET (2)
3764#define DN_BCHAIN_VER_BIP32_FPRV1 (3)
3767#define DN_BCHAIN_BIP32_SEED_LEN_MAX (765)
3771typedef struct tag_DN_BCHAIN_BIP32_SEED_XPRV_DATA
3772{
3777
3778#define DN_BCHAIN_BIP39_SEED_LEN_MAX (765)
3779#define DN_BCHAIN_BIP39_PWD_LEN_MAX (255)
3784typedef struct tag_DN_BCHAIN_BIP39_SEED_XPRV_DATA
3785{
3790
3791#define DN_BCHAIN_KEY_INFO_ST_SL (0)
3792#define DN_BCHAIN_KEY_INFO_ST_BLKC (1)
3794/* DBchainCreateBip32Ckd */
3795
3799typedef struct tag_DN_BCHAIN_KEY_INFO
3800{
3803 BYTE pbBip32Ver[4];
3805 BYTE pbParentFingerprint[4];
3806 BYTE pbChildNumber[4];
3808
3809/* DBchainVerify */
3810
3814typedef struct tag_DN_BCHAIN_PBK
3815{
3820
3821/*
3822 DMofNSplit
3823*/
3824
3825#define DN_M_OF_N_S_LEN (24)
3826#define DN_M_OF_N_ES_LEN (32)
3827#define DN_M_OF_N_S_MIN (2)
3828#define DN_M_OF_N_S_MAX (16)
3829#define DN_M_OF_N_PART_LEN (3 + DN_M_OF_N_S_LEN)
3834typedef struct tag_DN_M_OF_N_PART_DETAILS
3835{
3841
3845typedef struct tag_DN_M_OF_N_PART
3846{
3849
3853typedef struct tag_DN_M_OF_N_SPLIT_INFO
3854{
3860
3871
3875typedef struct tag_DN_OBJ_STATS
3876{
3879} DN_OBJ_STATS;
3880
3886#define DN_GLOBAL_OBJ_STATS_COUNT (39)
3888#define DN_GLOBAL_OBJ_STATS_INDEX_RSA (0)
3889#define DN_GLOBAL_OBJ_STATS_INDEX_DSA (1)
3890#define DN_GLOBAL_OBJ_STATS_INDEX_ECC (2)
3891#define DN_GLOBAL_OBJ_STATS_INDEX_ECX (3)
3892#define DN_GLOBAL_OBJ_STATS_INDEX_AES (4)
3893#define DN_GLOBAL_OBJ_STATS_INDEX_DES (5)
3894#define DN_GLOBAL_OBJ_STATS_INDEX_CSP (6)
3895#define DN_GLOBAL_OBJ_STATS_INDEX_BCHAIN (7)
3896#define DN_GLOBAL_OBJ_STATS_INDEX_X509 (8)
3897#define DN_GLOBAL_OBJ_STATS_INDEX_PKCS7 (9)
3898#define DN_GLOBAL_OBJ_STATS_INDEX_ML_DSA (10)
3899#define DN_GLOBAL_OBJ_STATS_INDEX_ML_KEM (11)
3900#define DN_GLOBAL_OBJ_STATS_INDEX_SLH_DSA (12)
3905typedef struct tag_DN_GLOBAL_OBJ_STATS
3906{
3910
3911/* DSKeepProbeSecret */
3912
3916typedef struct tag_SKeepProbeInfo
3917{
3921
3922/* DSKeepSplitSecret e outros */
3923#define DN_SKEEP_M_OF_N_S_MIN (2)
3924#define DN_SKEEP_M_OF_N_S_MAX (16)
3925#define DN_SKEEP_M_OF_N_S_LEN (64)
3930typedef struct tag_SKeepRecoverInfo
3931{
3933 char szSecret[DN_SKEEP_M_OF_N_S_LEN + 1];
3935
3939typedef struct tag_SKeepShare
3940{
3941 char szShare[DN_SKEEP_M_OF_N_S_LEN + 1];
3942} SKeepShare;
3943
3944// DSCReadShadow
3945#define DN_SC_M_OF_N_SHADOW_MATERIAL_V1_LEN (24)
3946#define DN_SC_M_OF_N_SHADOW_MATERIAL_V2_LEN (56)
3947#define DN_SC_M_OF_N_SHADOW_EXTRA_DATA_LEN (3)
3949#define DN_SC_M_OF_N_SHADOW_V1_MAX_LEN (DN_SC_M_OF_N_SHADOW_MATERIAL_V1_LEN + DN_SC_M_OF_N_SHADOW_EXTRA_DATA_LEN)
3950#define DN_SC_M_OF_N_SHADOW_V2_MAX_LEN (DN_SC_M_OF_N_SHADOW_MATERIAL_V2_LEN + DN_SC_M_OF_N_SHADOW_EXTRA_DATA_LEN)
3952#define DN_SC_M_OF_N_SHADOW_MATERIAL_MAX_LEN (DN_SC_M_OF_N_SHADOW_MATERIAL_V2_LEN)
3953#define DN_SC_M_OF_N_SHADOW_MAX_LEN (DN_SC_M_OF_N_SHADOW_V2_MAX_LEN)
3955#define DN_SC_MAX_PIN_LEN (8)
3957#define DN_SC_M_OF_N_SHADOW_V1_TYPE (1)
3958#define DN_SC_M_OF_N_SHADOW_V2_TYPE (2)
3963typedef struct tag_DN_SC_M_OF_N_SHADOW_DETAILS
3964{
3970
3974typedef struct tag_DN_SC_M_OF_N_SHADOW
3975{
3979
3989
3990/* DKemEncaps/DKemDecaps */
3991
3992#define DN_KEM_D_ML_KEM_SS_LEN (32)
3993#define DN_KEM_D_MAX_CTX_LEN (255)
3994#define DN_KEM_MAX_C_LEN (8192)
3995#define DN_KEM_MAX_SS_LEN (64)
3997#define DN_KEM_OP_SHARED_SECRET (1)
3998#define DN_KEM_OP_DIRECT_KEY (2)
3999#define DN_KEM_OP_X9_63_SHA256 (3)
4020
4021#define DN_ML_KEM_512_C_LEN (768)
4022#define DN_ML_KEM_768_C_LEN (1088)
4023#define DN_ML_KEM_1024_C_LEN (1568)
4029typedef struct tag_DN_KEM_ENCAPS_RESULT
4030{
4031 BYTE pbSharedSecret[DN_KEM_MAX_SS_LEN];
4032 BYTE pbCiphertext[DN_KEM_MAX_C_LEN];
4036
4041typedef struct tab_DN_KEM_DECAPS_RESULT
4042{
4043 BYTE pbSharedSecret[DN_KEM_MAX_SS_LEN];
4046
4051typedef struct DN_BCHAIN_BIP32_CKD_IN_INFO_tag
4052{
4067
4072typedef struct DN_BCHAIN_BIP32_ED25519_CKD_IN_INFO_tag
4073{
4081
4086typedef struct DN_BCHAIN_BIP32_P256_CKD_IN_INFO_tag
4087{
4094
4095#ifdef _WIN32
4096 #pragma pack(pop)
4097#else
4098 #pragma pack()
4099#endif
4100
4101/* Library exported functions */
4102
4103#ifdef __cplusplus
4104extern "C" {
4105#endif /* __cplusplus */
4106
4112#define DN_INIT_PARAM_CONF_FAST_FAIL (128)
4124 DWORD dwReserved
4125);
4126
4143 void *pvList,
4144 DWORD dwListCount,
4145 DWORD dwReserved);
4146
4162 void *pvList,
4163 DWORD *pdwListCount,
4164 DWORD dwReserved);
4165
4202 HSESSIONCTX * phSession,
4203 DWORD dwParam,
4204 BYTE * pbData,
4205 DWORD dwDataLen,
4206 DWORD dwFlags
4207);
4208
4226 HSESSIONCTX hSession,
4227 DWORD dwParam,
4228 BYTE * pbData,
4229 DWORD dwDataLen,
4230 DWORD dwFlags
4231);
4232
4253 HSESSIONCTX hSession,
4254 DWORD dwParam,
4255 BYTE* pbData,
4256 DWORD* pdwDataLen,
4257 DWORD dwFlags
4258);
4259
4274 HSESSIONCTX * phSession,
4275 DWORD dwFlags
4276);
4277
4286
4302typedef int (AAP_API * funcListKeyCallback)(char *szKeyName, void *pParam, BOOL bFinal);
4303
4308 HSESSIONCTX hSession,
4309 funcListKeyCallback fncallback,
4310 void *pParam
4315);
4316
4321 HSESSIONCTX hSession,
4322 funcListKeyCallback fncallback,
4323 void *pParam
4328);
4329
4352 HSESSIONCTX hSession,
4353 char * szBackupFile,
4354 char * szPin,
4355 int nDirection
4356);
4357
4385 DWORD dwOP,
4386 char *szObjectId,
4387 char *szPin,
4388 BYTE *pbData,
4389 DWORD *pdwDataLen,
4390 DWORD dwReserved );
4391
4399typedef int (AAP_API * funcLogEventCallback)(char *szEvent, void *pParam, BOOL bFinal);
4400
4413 HSESSIONCTX hSession,
4414 funcLogEventCallback fncallback,
4415 void *pParam
4416);
4417
4467 HSESSIONCTX hSession,
4468 DWORD dwParam,
4469 BYTE * pbData,
4470 DWORD dwDataLen,
4471 DWORD dwFlags
4472);
4473
4490int AAP_API DGetHSMTLSCert(char *szAddress,
4491 int nPort,
4492 DWORD dwOutFormat,
4493 BYTE **ppbOutCert,
4494 DWORD *pdwOutCertLen,
4495 DWORD dwFlags);
4496
4497#define DN_NT_MAX_TARGET_LEN (255)
4498#define DN_NTOOL_PING (1)
4499#define DN_NTOOL_TRACERT (2)
4500#define DN_NTOOL_CROSS_CHECK (100)
4501
4520 DWORD dwOption,
4521 const char *szTarget,
4522 void **pvResult,
4523 DWORD *pdwResultLen,
4524 DWORD dwFlags);
4525
4526#define DN_WRITE_FILE_OPT_CERT_CHAIN (1)
4527#define DN_WRITE_FILE_OPT_NO_CONVERSION (2)
4528
4553 const char *szFileId,
4554 BYTE *pbFile,
4555 DWORD dwFileSize,
4556 DWORD dwOptions);
4557
4568typedef int (AAP_API * funcReadLocalFileCallback)(BYTE *pbData, DWORD * pdwDataLen, void *pParam, BOOL *pbFinal);
4569
4592 HSESSIONCTX hSession,
4593 char * szFileId,
4594 DWORD dwFileSize,
4595 funcReadLocalFileCallback fncallback,
4596 void *pParam
4597);
4598
4609typedef int (AAP_API * funcWriteLocalFileCallback)(BYTE *pbData, DWORD dwDataLen, void *pParam, BOOL bFinal);
4610
4624 HSESSIONCTX hSession,
4625 char * szFileId,
4626 funcWriteLocalFileCallback fncallback,
4627 void *pParam
4628);
4629
4644 const char *szFileId,
4645 BYTE **ppbData,
4646 DWORD *pdwDataLen,
4647 DWORD dwReserved);
4648
4658 HSESSIONCTX hSession,
4659 char *szObjId);
4660
4675 HSESSIONCTX hSession,
4676 DWORD dwStart,
4677 DWORD dwOffset,
4678 DWORD *pdwLogSize,
4679 BYTE **ppbLog
4680);
4681
4692 HSESSIONCTX hSession
4693);
4694
4719int AAP_API DFindHSM( DWORD dwServiceType,
4720 DWORD dwFilter,
4721 void **ppvOutputData,
4722 DWORD *pdwOutputDataLen,
4723 DWORD dwFlags );
4724
4733typedef int (AAP_API * funcListAKeysCallback)(void *pvToken, void *pParam, BOOL bFinal);
4734
4782 BYTE bOP,
4783 DN_A_TOKEN_FULL *pstATokenFull,
4784 funcListAKeysCallback fnCallBack,
4785 void *pvCallbackParam,
4786 DWORD dwParam);
4787
4788#define DN_ATOKEN_CACHE_GET_COUNT (0)
4789#define DN_ATOKEN_CACHE_GC (1)
4790
4817 DWORD dwOP,
4818 void *pOutData,
4819 DWORD dwParam);
4820
4830 const char *szBindKey,
4831 DWORD dwReserved);
4840 DWORD dwReserved);
4841
4850int AAP_API DSCReadShadow(const char *szPin, DN_SC_M_OF_N_SHADOW *pstShadow, DWORD dwReserved);
4851
4852
4860int AAP_API DSCGetInfo(DN_SC_INFO *pstInfo, DWORD dwReserved);
4861
4869
4879int AAP_API DSCChangePIN(const char *szCurrentPIN, const char *szNewPIN, DWORD dwReserved);
4880
4891int AAP_API DSCWriteShadow(DN_SC_M_OF_N_SHADOW *pstShadow, const char *szPIN,
4892 BOOL bOverwrite, DWORD dwReserved);
4893
4901int AAP_API DSCErase(const char *szPIN, DWORD dwReserved);
4902
4903#define DN_SC_MAX_LABEL_LEN (32)
4914int AAP_API DSCSetLabel(const char *pin, const char *label, DWORD reserved);
4915
4925int AAP_API DSCGetLabel(const char *pin, char *label, DWORD reserved);
4926
4927// DNSAuthSetState
4928#define DN_S_NSAUTH_ASSOC (1)
4929#define DN_S_NSAUTH_RESET (2)
4930#define DN_S_NSAUTH_AUTH (3)
4931#define DN_S_NSAUTH_eAUTH (4)
4932#define DN_S_NSAUTH_CHECK (5)
4962int AAP_API DNSAuthSetState(HSESSIONCTX hSession, DWORD dwAcl, BYTE bState,
4963 DN_SC_M_OF_N_SHADOW *pstShadows, DWORD dwShadowsCount,
4964 DWORD dwReserved);
4965
4966/* Error codes */
4967
4971int AAP_API DGetErrorString(int nErrorValue,
4972 char *szErrorCode,
4973 char *szErrorDesc);
4974
4978typedef enum tag_RetCodeMsgType
4979{
4981 DESC_MSG
4983
4997const char *AAP_API DGetReturnCodeString(int nErrorValue,
4998 RetCodeMsgType eErrorType);
4999
5003 BYTE bOP,
5004 char *szUser,
5005 char *szIP,
5006 int(AAP_API *ListIpFilterCallback)(void *pInData, DWORD dwInDataLen, void *pParam, BOOL bFinal),
5007 void *pParam,
5008 DWORD *pdwStatus,
5009 DWORD dwReserved);
5010
5012 char *szOldObjName,
5013 char *szNewObjName,
5014 DWORD dwFlags);
5015
5016int AAP_API DUPackPush(HSESSIONCTX hSession, DWORD dwPackSize,
5017 BYTE *pbPack);
5018
5019int AAP_API DUPackInfo(DWORD dwPackSize, BYTE *pbPack,
5020 DWORD *pdwUPackVersion, BYTE **ppbUPackDescr,
5021 BYTE **ppbUPackSignature);
5022
5023int AAP_API DGetObjInfo(const HSESSIONCTX hSession, const char *szObjId,
5024 const int nAlgId, const BYTE *pbData,
5025 DWORD *pdwDataLen);
5026
5027int AAP_API DGenerateMapObj(const HSESSIONCTX hSession, const char *szMapId,
5028 const char *szObj1Id, const int nObj1AlgId,
5029 const char *szObj2Id, const int nObj2AlgId);
5030
5031int AAP_API DRemoveMapObj(const HSESSIONCTX hSession, const char *szMapObjId);
5032
5034 int(AAP_API *ListUserSessionsCallback)(DWORD dwStartTime, char *szInfo, void *pParam, BOOL bFinal),
5035 void *pParam);
5036
5038 DWORD dwFilterType,
5039 void *pvFilter,
5040 int(AAP_API *ListObjCallback)(void *pvIN, void *pParam, BOOL bFinal),
5041 void *pParam);
5042
5044 int(AAP_API *ListLoadedModulesCallback)(char *szModuleInfo,
5045 void *pParam,
5046 BOOL bFinal),
5047 void *pParam);
5048
5079 HSESSIONCTX hSession,
5080 struct USER_INFO userInfo);
5081
5095 HSESSIONCTX hSession,
5096 char *szUserId);
5097
5121 HSESSIONCTX hSession,
5122 DWORD dwParam,
5123 BYTE *pbData,
5124 DWORD dwDataLen,
5125 DWORD dwFlags);
5126
5145 HSESSIONCTX hSession,
5146 DWORD dwParam,
5147 BYTE *pbData,
5148 DWORD *pdwDataLen,
5149 DWORD dwFlags);
5150
5160typedef int(AAP_API *funcListUsersCallback)(char *szUserName, void *pParam, BOOL bFinal);
5161
5172 HSESSIONCTX hSession,
5173 funcListUsersCallback fncallback,
5174 void *pParam);
5175
5176// OATH SA
5177
5198 const char *szUserId,
5199 const DWORD dwParam,
5200 BYTE *pbData,
5201 const DWORD dwDataLen);
5202
5216 const DWORD dwParam,
5217 const char *szUserId);
5218
5232 char *szUser,
5233 char *szOTP1,
5234 char *szOTP2,
5235 DWORD dwParam);
5236
5239/* PKCS#11 */
5240
5241int AAP_API DGeneratePkcs11Map(HSESSIONCTX hSession, char *szP11MapId,
5242 BYTE bTemporary, DWORD dwBlobType,
5243 DWORD dwFlags, BYTE *pbData,
5244 DWORD dwDataLen);
5245
5246int AAP_API DUpdatePkcs11Map(HSESSIONCTX hSession, char *szP11MapId,
5247 DWORD dwBlobType, DWORD dwFlags,
5248 DWORD dwUpdateMask, BYTE *pbData,
5249 DWORD dwDataLen);
5250
5251int AAP_API DGetPkcs11Map(HSESSIONCTX hSession, char *szP11MapId,
5252 DWORD dwBlobType, DWORD dwFlags,
5253 BYTE **ppbData, DWORD *pdwDataLen);
5254
5256 int(AAP_API *ListKeyCallback)(char *szKeyName,
5257 void *pParam,
5258 BOOL bFinal),
5259 void *pParam);
5260
5261
5262#define MNG_OBJ_META_A_KEY_TYPE (1)
5263#define MNG_OBJ_META_A_CLASS (2)
5264#define MNG_OBJ_META_A_EXTRACTABLE (3)
5265#define MNG_OBJ_META_A_SENSITIVE (4)
5266#define MNG_OBJ_META_A_N_EXTRACTABLE (5)
5267#define MNG_OBJ_META_A_LOCAL (6)
5268#define MNG_OBJ_META_A_CERT_TYPE (7)
5269#define MNG_OBJ_META_A_RSA_MODULUS (8)
5270#define MNG_OBJ_META_A_RSA_PUB_EXP (9)
5271#define MNG_OBJ_META_A_PUB_KEY_INFO (10)
5272#define MNG_OBJ_META_A_EC_PARAMS (11)
5273#define MNG_OBJ_META_A_SUBJECT (12)
5274#define MNG_OBJ_META_A_ISSUER (13)
5275#define MNG_OBJ_META_A_SN (14)
5276#define MNG_OBJ_META_A_TOKEN (15)
5277#define MNG_OBJ_META_A_MODIFIABLE (16)
5278#define MNG_OBJ_META_A_DERIVE (17)
5279#define MNG_OBJ_META_A_WRAP (18)
5280#define MNG_OBJ_META_A_UNWRAP (19)
5281#define MNG_OBJ_META_A_SIGN (20)
5282#define MNG_OBJ_META_A_VERIFY (21)
5283#define MNG_OBJ_META_A_ENCRYPT (22)
5284#define MNG_OBJ_META_A_DECRYPT (23)
5285#define MNG_OBJ_META_A_OBJ_ID (24)
5286#define MNG_OBJ_META_A_MODULUS_BITS (25)
5287#define MNG_OBJ_META_A_PRIVATE (26)
5288#define MNG_OBJ_META_A_LABEL (27)
5289#define MNG_OBJ_META_A_ID (28)
5290#define MNG_OBJ_META_A_APPLICATION (29)
5291#define MNG_OBJ_META_A_TRUSTED (30)
5292#define MNG_OBJ_META_A_JMIDP_SEC_DOMAIN (31)
5293#define MNG_OBJ_META_A_CERT_CATEGORY (32)
5294#define MNG_OBJ_META_A_KEY_GEN_MECHANISM (33)
5295#define MNG_OBJ_META_A_WRAP_WITH_TRUSTED (34)
5296#define MNG_OBJ_META_A_HSM_ASSOCIATE (35)
5297#define MNG_OBJ_META_A_SIGN_RECOVER (36)
5298#define MNG_OBJ_META_A_VERIFY_RECOVER (37)
5299
5300#define MNG_OBJ_META_A_HSM_OBJ_VERSION (502)
5301#define MNG_OBJ_META_A_HSM_OBJ_TYPE (503)
5302#define MNG_OBJ_META_A_HSM_OBJ_ATTR (504)
5303#define MNG_OBJ_META_A_HSM_OBJ_LEN (505)
5304#define MNG_OBJ_META_A_HSM_OBJ_ID (506)
5305#define MNG_OBJ_META_A_HSM_OBJ_PVALUE (507)
5306#define MNG_OBJ_META_A_HSM_OBJ_CNG_UTF8_ID (508) // Client side attribute
5307
5308#define MNG_OBJ_META_READ_ONLY_ATTR(a) ((MNG_OBJ_META_A_KEY_TYPE == (a)) || \
5309 (MNG_OBJ_META_A_CLASS == (a)) || \
5310 (MNG_OBJ_META_A_EXTRACTABLE == (a)) || \
5311 (MNG_OBJ_META_A_SENSITIVE == (a)) || \
5312 (MNG_OBJ_META_A_N_EXTRACTABLE == (a)) || \
5313 (MNG_OBJ_META_A_LOCAL == (a)) || \
5314 (MNG_OBJ_META_A_CERT_TYPE == (a)) || \
5315 (MNG_OBJ_META_A_RSA_MODULUS == (a)) || \
5316 (MNG_OBJ_META_A_RSA_PUB_EXP == (a)) || \
5317 (MNG_OBJ_META_A_PUB_KEY_INFO == (a)) || \
5318 (MNG_OBJ_META_A_EC_PARAMS == (a)) || \
5319 (MNG_OBJ_META_A_ISSUER == (a)) || \
5320 (MNG_OBJ_META_A_SN == (a)) || \
5321 (MNG_OBJ_META_A_TOKEN == (a)) || \
5322 (MNG_OBJ_META_A_MODIFIABLE == (a)) || \
5323 (MNG_OBJ_META_A_MODULUS_BITS == (a)) || \
5324 (MNG_OBJ_META_A_PRIVATE == (a)) || \
5325 (MNG_OBJ_META_A_HSM_OBJ_VERSION == (a)) || \
5326 (MNG_OBJ_META_A_HSM_OBJ_TYPE == (a)) || \
5327 (MNG_OBJ_META_A_HSM_OBJ_ATTR == (a)) || \
5328 (MNG_OBJ_META_A_HSM_OBJ_LEN == (a)) || \
5329 (MNG_OBJ_META_A_HSM_OBJ_ID == (a)) || \
5330 (MNG_OBJ_META_A_HSM_OBJ_PVALUE == (a)) || \
5331 (MNG_OBJ_META_A_DERIVE == (a)) || \
5332 (MNG_OBJ_META_A_WRAP == (a)) || \
5333 (MNG_OBJ_META_A_UNWRAP == (a)) || \
5334 (MNG_OBJ_META_A_SIGN == (a)) || \
5335 (MNG_OBJ_META_A_VERIFY == (a)) || \
5336 (MNG_OBJ_META_A_ENCRYPT == (a)) || \
5337 (MNG_OBJ_META_A_DECRYPT == (a)) || \
5338 (MNG_OBJ_META_A_SIGN_RECOVER == (a)) || \
5339 (MNG_OBJ_META_A_VERIFY_RECOVER == (a)))
5340
5341/* DManageObjMetadata */
5342
5343#define MNG_OBJ_META_GET (1)
5344#define MNG_OBJ_META_UPDATE (3)
5345#define MNG_OBJ_META_DEL (4)
5346
5347
5349 DWORD dwParam );
5350
5352 DWORD dwParam );
5353
5355 DWORD dwOption,
5356 void *pvOptionData,
5357 DWORD dwOptionDataLen,
5358 DWORD dwParam );
5359
5361 DWORD dwOption,
5362 DWORD dwParam );
5363
5365 DWORD dwOption,
5366 void *pvOptionData,
5367 DWORD *pdwOptionDataLen,
5368 DWORD dwParam );
5369
5371 char *szData,
5372 DWORD dwDataLen,
5373 DWORD dwParam);
5374
5376 char *szData,
5377 DWORD *pdwDataLen,
5378 DWORD dwParam);
5379
5381 BYTE bOP,
5382 char *szObjName,
5383 HOBJMETACTX hInMeta,
5384 HOBJMETACTX *phOutMeta,
5385 DWORD dwParam );
5386
5388 HOBJMETACTX hInMeta,
5389 HOBJMETASEARCHCTX *phMetaSearchCtx,
5390 DWORD dwParam );
5391
5393 HOBJMETACTX *phOutMeta,
5394 DWORD dwOutMetaMaxCount,
5395 DWORD *pdwOutMetaDataCount,
5396 DWORD dwParam );
5397
5399 DWORD dwParam );
5400
5401#define MNG_OBJ_META_TYPE_ULONG (1)
5402#define MNG_OBJ_META_TYPE_STR (2)
5403#define MNG_OBJ_META_TYPE_BOOL (3)
5404#define MNG_OBJ_META_TYPE_INT_BOOL (4)
5405
5406typedef struct tag_OBJ_MET_ATTR
5407{
5409 const char *pszString;
5412
5414 void *pvData,
5415 DWORD *pdwDataLen,
5416 DWORD dwReserved );
5417
5419
5420
5421#define DN_MAX_OBJ_JSON_STRING (15 * 1024)
5423#define DN_JSON_OUT_TYPE_PRETTY (0)
5424#define DN_JSON_OUT_TYPE_RAW (1)
5425#define DN_JSON_OUT_TYPE_COMPACT (2)
5444 const char *szId,
5445 DWORD dwOutType,
5446 char **pszOutJson,
5447 DWORD *pdwOutJsonLen);
5448
5461 const char *szId,
5462 const char *szJson,
5463 DWORD dwJsonLen,
5464 DWORD dwReserved);
5465/* P11 HSM Info */
5466
5468 HP11ATTRCTX *phOutMeta,
5469 DWORD dwParam );
5470
5471#define MNG_HSM_P11_INFO_SLOT_DESC (1)
5472#define MNG_HSM_P11_INFO_MANUFACTURER_ID (2)
5473#define MNG_HSM_P11_INFO_SLOT_FLAGS (3)
5474#define MNG_HSM_P11_INFO_HDW_VERSION (4)
5475#define MNG_HSM_P11_INFO_FMW_VERSION (5)
5476#define MNG_HSM_P11_INFO_LABEL (6)
5477#define MNG_HSM_P11_INFO_MODEL (7)
5478#define MNG_HSM_P11_INFO_SERIAL_NUMBER (8)
5479#define MNG_HSM_P11_INFO_TOKEN_FLAGS (9)
5480#define MNG_HSM_P11_INFO_UTC_TIME (10)
5481#define MNG_HSM_P11_INFO_MAX_SESSION_COUNT (11)
5482#define MNG_HSM_P11_INFO_SESSION_COUNT (12)
5483#define MNG_HSM_P11_INFO_MAX_RW_SESS_COUNT (13)
5484#define MNG_HSM_P11_INFO_RW_SESS_COUNT (14)
5485#define MNG_HSM_P11_INFO_MAX_PIN_LEN (15)
5486#define MNG_HSM_P11_INFO_MIN_PIN_LEN (16)
5487#define MNG_HSM_P11_INFO_TOTAL_PUB_MEMORY (17)
5488#define MNG_HSM_P11_INFO_FREE_PUB_MEMORY (18)
5489#define MNG_HSM_P11_INFO_TOTAL_PRIV_MEMORY (19)
5490#define MNG_HSM_P11_INFO_FREE_PRIV_MEMORY (20)
5491#define MNG_HSM_P11_INFO_SVMK_FINGERPRINT (21)
5492#define MNG_HSM_INFO_TAMPERED_HSM (22)
5493#define MNG_HSM_INFO_OP_MODE (23)
5494#define MNG_HSM_INFO_DS_BOUND (24)
5495#define MNG_HSM_INFO_DS_HSM (25)
5496#define MNG_HSM_INFO_DS_ACCOUNT (26)
5497#define MNG_HSM_INFO_DS_URL (27)
5498#define MNG_HSM_INFO_DNS1 (28)
5499#define MNG_HSM_INFO_DNS2 (29)
5500#define MNG_HSM_INFO_REMOOT (30)
5501#define MNG_HSM_INFO_SCREADER (31)
5502#define MNG_HSM_INFO_TPOEM (32)
5503#define MNG_HSM_INFO_UNLSH (33)
5504#define MNG_HSM_INFO_KB_PLUGGED (34)
5505#define MNG_HSM_INFO_SC_READER_ON (35)
5506#define MNG_HSM_INFO_ALIAS (36)
5507
5509 DWORD dwOption,
5510 void *pvOptionData,
5511 DWORD *pdwOptionDataLen,
5512 DWORD dwParam );
5513
5515 DWORD dwParam );
5516
5518
5519
5520
5521/* Users */
5522
5523
5524int AAP_API DGetUserAcl ( HSESSIONCTX hSession, char *szUser,
5525 DWORD *pdwUserAcl );
5526
5527int AAP_API DListUserTrusts(HSESSIONCTX hSession, char *szUserId,
5528 BYTE bType,
5529 int (AAP_API * ListUserTrustCallback)(char *szUserName,
5530 DWORD dwACL,
5531 void *pParam,
5532 BOOL bFinal),
5533 void *pParam);
5534
5535
5536/* Statistics */
5537
5538int AAP_API DGetHsmInfo(HSESSIONCTX hSession, BOOL *pbFinal,
5539 DWORD dwParam, BYTE * pbData,
5540 DWORD* pdwDataLen, DWORD dwFlags);
5541
5542
5543/* Local operations */
5544
5546 BYTE * pbData, DWORD dwDataLen,
5547 DWORD dwFlags);
5548
5550 BYTE * pbData, DWORD *pdwDataLen,
5551 DWORD dwFlags);
5552
5553int AAP_API DGetLibVersion(HSESSIONCTX hSession, char * szVersion,
5554 DWORD *pdwVersionLen, DWORD dwFlags);
5555
5556
5557/* Key management */
5558
5559int AAP_API DECParam2AlgId(BYTE *pbECParam, DWORD dwECParamLen,
5560 int *pnAlgId, DWORD dwFlags);
5561
5562int AAP_API DECPubKeyDER2AlgId( BYTE *pbECPubKeyDER,
5563 DWORD dwECPubKeyDERLen,
5564 int *pnAlgId,
5565 DWORD dwFlags );
5566
5567int AAP_API DECPrivKeyDER2AlgId(const BYTE *pbDER, DWORD dwDERLen, int *pnAlgId,
5568 DWORD dwFlags);
5569
5773 HSESSIONCTX hSession,
5774 char *szKeyId,
5775 int nAlgId,
5776 DWORD dwFlags,
5777 HKEYCTX * phKey
5778);
5779
5793 int nAlgId,
5794 BYTE *pbData,
5795 DWORD *pdwDataLen,
5796 DWORD dwReserved);
5797
5816 HSESSIONCTX hSession,
5817 char *szKeyId,
5818 DWORD dwFlags,
5819 HKEYCTX * phKey
5820);
5821
5822
5823
5824#define D_IMPORT_ALG_PRIV_KEY_RSA (0xFFFFFFE1) /* Importa uma chave privada RSA. */
5825#define D_IMPORT_ALG_PRIV_KEY_ECC (0xFFFFFFE0) /* Importa uma chave privada ECC(Curvas Elípticas com exceção de ECX). */
5826#define D_IMPORT_ALG_PRIV_KEY_P8 (0xFFFFFFDF) /* Importa uma chave no formato P8 */
5827#define D_IMPORT_ALG_PRIV_KEY_ECX (0xFFFFFFDE) /* Importa uma chave privada ECX */
5828#define D_IMPORT_ALG_PRIV_KEY_DSA (0xFFFFFFDD) /* Importa uma chave privada DSA */
5829#define D_IMPORT_ALG_PRIV_KEY_DH (0xFFFFFFDC) /* Importa uma chave privada DH */
5830#define D_IMPORT_ALG_PRIV_KEY_ML_DSA (0xFFFFFFDA) /* Importa uma chave privada ML-DSA */
5831#define D_IMPORT_ALG_PRIV_KEY_ML_KEM (0xFFFFFFD9) /* Importa uma chave privada ML-KEM */
5832#define D_IMPORT_ALG_PRIV_KEY_SLH_DSA (0xFFFFFFD8) /* Importa uma chave privada SLH-DSA */
5833
5834
5923 HSESSIONCTX hSession,
5924 char *szKeyId,
5925 HKEYCTX hKEKey,
5926 DWORD dwBlobType,
5927 int nAlgId,
5928 DWORD dwFlags,
5929 BYTE * pbData,
5930 DWORD dwDataLen,
5931 HKEYCTX * phKey
5932);
5933
5949 HKEYCTX hKey,
5950 HKEYCTX hKEKey,
5951 DWORD dwBlobType,
5952 DWORD dwFlags,
5953 BYTE * pbData,
5954 DWORD * pdwDataLen
5955);
5956
5990 HSESSIONCTX hSession,
5991 char *szKeyId,
5992 char *szSecret,
5993 DWORD dwKeyAlg,
5994 DWORD dwAttrib,
5995 BYTE *pbKeyEnvelope,
5996 DWORD dwKeyEnvelopeLen
5997);
5998
6012 HSESSIONCTX hSession,
6013 char *szKeyId,
6014 char *szSecret,
6015 BYTE **ppbKeyEnvelope,
6016 DWORD *pdwKeyEnvelopeLen
6017);
6018
6044 HKEYCTX hKey,
6045 DWORD dwParam,
6046 BYTE * pbData,
6047 DWORD dwDataLen,
6048 DWORD dwFlags
6049);
6050
6075 HKEYCTX hKey,
6076 DWORD dwParam,
6077 BYTE * pbData,
6078 DWORD *pdwDataLen,
6079 DWORD dwFlags
6080);
6081
6094 HHASHCTX hHash,
6095 char * szKeyId,
6096 int nAlgId,
6097 DWORD dwFlags,
6098 HKEYCTX * phKey
6099);
6100
6113 HKEYCTX hKey,
6114 DWORD dwFlags,
6115 HKEYCTX * phKey
6116);
6117
6130 HKEYCTX hKey,
6131 HHASHCTX hHash,
6132 DWORD dwFlags
6133);
6134
6147 HKEYCTX * phKey,
6148 DWORD dwFlags
6149);
6150
6192 char *szPrivateKeyName,
6193 BYTE bVersion,
6194 char *szDN,
6195 DWORD dwOutType,
6196 DWORD *pdwCSRLen,
6197 BYTE **ppbCSR,
6198 DWORD dwParam);
6199
6224 char *szPriKey,
6225 char *szPubKey,
6226 char *szCert,
6227 void *pvReserved,
6228 DWORD dwReserved);
6229
6252 const char *szPkcs12Pwd,
6253 const char *szKeyId,
6254 const char *szCertId,
6255 const char *szReserved,
6256 BYTE **ppbPkcs12,
6257 DWORD *pdwPkcs12Len,
6258 DWORD dwFlags);
6259
6278 BYTE *pbPkcs12,
6279 DWORD dwPkcs12Len,
6280 const char *szPkcs12Pwd,
6281 const char *szKeyId,
6282 DWORD dwKeyAttr,
6283 const char *szCertId,
6284 const char *szPubKeyId,
6285 DWORD dwFlags);
6286
6302 const char *szPkcs12File,
6303 const char *szPkcs12Pwd,
6304 const char *szKeyId,
6305 const DWORD dwKeyAttr,
6306 const char *szCertId);
6307
6308#define DN_FORM_DER (1)
6325int AAP_API DRSAPublicKey2Info(BYTE *pbKey, DWORD dwKeyLen, DWORD dwInForm,
6326 void *pvPubKeyInfo, DWORD dwReserved);
6327
6344int AAP_API DRSAPrivateKey2Info(const BYTE *pbRsa, DWORD dwRsaLen, DWORD dwInForm,
6345 DN_RSA_PRIVATE_KEY_INFO *stRsaInfo, DWORD dwReserved);
6346
6348typedef struct tag_DN_EXPORT_BYOK_AZURE{
6349 char *szKeKKid;
6353
6354#define DN_BYOK_TYPE_AZURE (1)
6355#define DN_BYOK_TYPE_AWS (2)
6375int AAP_API DByokExport(HSESSIONCTX hSession, const char *cszKeyId,
6376 const char *cszKekId, DWORD dwType,
6377 const void *pvData, BYTE **ppbOutData,
6378 DWORD *pdwOutDataLen, DWORD dwReserved);
6379
6403 DWORD dwOp,
6404 BYTE *pbInData,
6405 BYTE *pbTokenBlob,
6406 DWORD *pdwTokenBlobLen,
6407 char *szToken,
6408 DWORD dwReserved);
6409
6455 DWORD dwOp,
6456 const char *szMK,
6457 const char *szMask,
6458 BYTE *pbTokenBlob,
6459 DWORD dwTokenBlobLen,
6460 char *szData,
6461 DWORD *pdwDataLen,
6462 DWORD dwReserved);
6463
6466int AAP_API DRemoveKey(HSESSIONCTX hSession, char *szKeyId);
6467
6469 DWORD dwCertLen,
6470 DWORD dwOutType,
6471 void *pvCertInfo,
6472 DWORD dwFlags );
6473
6474/* Symmetric/Asymmetric operations */
6475
6505 HKEYCTX hKey,
6506 HHASHCTX hHash,
6507 BOOL bFinal,
6508 DWORD dwFlags,
6509 BYTE* pbData,
6510 DWORD* pdwDataLen,
6511 DWORD dwBufLen
6512);
6513
6535 HKEYCTX hKey,
6536 HHASHCTX hHash,
6537 BOOL bFinal,
6538 DWORD dwFlags,
6539 BYTE* pbData,
6540 DWORD* pdwDataLen
6541);
6542
6576 HSESSIONCTX hSession,
6577 int nAlgId,
6578 HKEYCTX hKey,
6579 DWORD dwFlags,
6580 HHASHCTX *hHash
6581);
6582
6594 HHASHCTX hHash,
6595 BYTE* pbData,
6596 DWORD dwDataLen,
6597 DWORD dwFlags
6598);
6599
6616 HHASHCTX hHash,
6617 DWORD dwParam,
6618 BYTE * pbData,
6619 DWORD dwDataLen,
6620 DWORD dwFlags
6621);
6622
6640 HHASHCTX hHash,
6641 DWORD dwParam,
6642 BYTE* pbData,
6643 DWORD* pdwDataLen,
6644 DWORD dwFlags
6645);
6646
6679 HHASHCTX hHash,
6680 HKEYCTX hKey,
6681 DWORD dwFlags,
6682 BYTE* pbSignature,
6683 DWORD* pdwSigLen
6684);
6685
6686
6695 HHASHCTX * phHash
6696);
6697
6720 HHASHCTX hHash,
6721 BYTE* pbSignature,
6722 DWORD dwSigLen,
6723 HKEYCTX hPubKey,
6724 DWORD dwFlags
6725);
6726
6739 HHASHCTX hHash,
6740 DWORD dwFlag,
6741 HHASHCTX * phHash
6742);
6743
6754 HSESSIONCTX hSession,
6755 BYTE *pbData,
6756 DWORD dwDataLen
6757);
6758
6778 HSESSIONCTX hSession,
6779 DWORD dwOP,
6780 char *szPriKey,
6781 void *pvInData,
6782 DWORD dwInDataLen,
6783 BYTE *pbOutData,
6784 DWORD *pdwOutDataLen,
6785 DWORD dwFlags
6786);
6787
6800 char *szCRL,
6801 char *szCertId,
6802 char *szCertOrChain);
6803
6822 BYTE bM,
6823 BYTE bN,
6824 BYTE *pbSecret,
6825 DWORD dwSecretLen,
6826 DN_M_OF_N_SPLIT_INFO *pstSplitInfo,
6827 DWORD dwReserved);
6828
6845 DN_M_OF_N_PART *pstParts,
6846 DWORD dwPartsCount,
6847 BYTE *pbSecret,
6848 DWORD dwReserved);
6849
6868int AAP_API DGenerateSVMK(HSESSIONCTX hSession, int nVersion, const BYTE *pbKey,
6869 BYTE bM, BYTE bN, DN_SC_M_OF_N_SHADOW *pstShadows,
6870 DWORD dwReserved);
6871
6888 BYTE bShadowsCount, BYTE *pbKey, DWORD dwReserved);
6889
6890#define DN_KEM_ENCAPS_OPT_ML_KEM (1)
6891#define DN_KEM_MAX_PUB_LEN (8192)
6911int AAP_API DKemEncaps(HSESSIONCTX hSession, DWORD dwOpt, const void *pvDataIn,
6912 const BYTE *pbEncapsKey, DWORD dwEncapsKeyLen,
6913 void *pvDataOut, DWORD dwReserved);
6914
6915#define DN_KEM_DECAPS_OPT_ML_KEM (1)
6940int AAP_API DKemDecaps(HSESSIONCTX hSession, DWORD dwOpt, const void *pvDataIn,
6941 const char *szDecapsKey, const BYTE *pbCiphertext,
6942 DWORD dwCiphertextLen, void *pvDataOut, DWORD dwReserved);
6943
6946/* PIN - CVV */
6947
6977 HSESSIONCTX hSession,
6978 char *szSrcPEK,
6979 char *szDstPEK,
6980 BYTE bTransBlockType,
6981 char *szPAN,
6982 BYTE *pbInPinBlock,
6983 BYTE *pbOutPinBlock,
6984 DWORD dwParam);
6985
7004 HSESSIONCTX hSession,
7005 char *szKeyId,
7006 char *szPAN,
7007 char *szExpirationDate,
7008 char *szServiceCode,
7009 char *szCVV,
7010 DWORD dwParam
7011);
7012
7027 HSESSIONCTX hSession,
7028 char *szKeyId,
7029 char *szPAN,
7030 char *szExpirationDate,
7031 char *szServiceCode,
7032 char *szCVV,
7033 DWORD dwParam
7034);
7035
7057 HSESSIONCTX hSession,
7058 char *szPGK,
7059 char *szPAN,
7060 DWORD dwOperation,
7061 int nPinLen,
7062 char *szInPin,
7063 char *szOffset,
7064 char *szOutPin,
7065 DWORD dwParam
7066);
7067
7082 HSESSIONCTX hSession,
7083 char *szPTK,
7084 char *szPGK,
7085 char *szPAN,
7086 char *szOffset,
7087 BYTE *pbInPinBlock,
7088 DWORD dwParam
7089);
7090
7103 int nKeyAlgId,
7104 EFT_VISA_KEY_PARTS *pstKeyParts,
7105 DWORD dwParam
7106);
7107
7129 HSESSIONCTX hSession,
7130 BYTE *pbKSI,
7131 BYTE *pbDID_CTR,
7132 char *szDUKPT,
7133 DWORD dwParam
7134);
7135
7146 BYTE *pbKSI,
7147 char *szBDKName,
7148 DWORD dwParam
7149);
7150
7162 BYTE *pbKSI,
7163 BYTE *pbDID_CTR,
7164 char *szDUKPTName,
7165 DWORD dwParam
7166);
7167
7182 HSESSIONCTX hSession,
7183 char *szPGK,
7184 BYTE bPVKI,
7185 char *szPAN,
7186 char *szPIN,
7187 char *szPVV,
7188 DWORD dwParam
7189);
7190
7204 HSESSIONCTX hSession,
7205 char *szIMKDAC,
7206 char *szPAN,
7207 BYTE *pbSEQ,
7208 BYTE *pbDAC,
7209 DWORD dwParam
7210);
7211
7225 HSESSIONCTX hSession,
7226 char *szIMKDAC,
7227 char *szPAN,
7228 BYTE *pbSEQ,
7229 BYTE *pbDAC,
7230 DWORD dwParam
7231);
7232
7248 HSESSIONCTX hSession,
7249 char *szIK,
7250 BYTE *pbDAC,
7251 DWORD dwSDA_DATALen,
7252 BYTE *pbSDA_DATA,
7253 DWORD *pdwSigLen,
7254 BYTE *pbSig,
7255 DWORD dwParam
7256);
7257
7277 HSESSIONCTX hSession,
7278 BYTE bOP,
7279 char *szIK,
7280 char *szPAN,
7281 DWORD dwDDA_DATALen,
7282 BYTE *pbDDA_DATA,
7283 DWORD *pdwSigLen,
7284 BYTE *pbSig,
7285 DWORD dwParam
7286);
7287
7308 HSESSIONCTX hSession,
7309 BYTE bOP,
7310 char *szIK,
7311 char *szKeK,
7312 char *szPAN,
7313 BYTE *pbSEQ,
7314 DWORD *pdwEnvelopeLen,
7315 BYTE *pbEnvelope,
7316 DWORD dwParam
7317);
7318
7324 HSESSIONCTX hSession,
7325 BYTE bOP,
7326 char *szIK,
7327 char *szPAN,
7328 BYTE *pbSEQ,
7329 BYTE *pbNONCE,
7330 DWORD dwDataLen,
7331 BYTE *pbData,
7332 BYTE *pbMAC,
7333 DWORD dwParam
7334);
7335
7378 HSESSIONCTX hSession,
7379 BYTE bOP,
7380 char *szIK,
7381 char *szPAN,
7382 BYTE *pbSEQ,
7383 BYTE *pbNONCE,
7384 DWORD dwDataLen,
7385 BYTE *pbData,
7386 BYTE *pbMAC,
7387 DWORD dwParam
7388);
7389
7405 HSESSIONCTX hSession,
7406 char *szIK,
7407 char *szPAN,
7408 BYTE *pbSEQ,
7409 BYTE *pbATC,
7410 BYTE *pbUN,
7411 BYTE *pbIDN,
7412 DWORD dwParam
7413);
7414
7453 HSESSIONCTX hSession,
7454 BYTE bEncOP,
7455 char *szEncIK,
7456 BYTE *pbEncNONCE,
7457 BYTE bMacOP,
7458 char *szMacIK,
7459 BYTE *pbMacNONCE,
7460 char *szPAN,
7461 BYTE *pbSEQ,
7462 DWORD dwDataLen,
7463 BYTE *pbData,
7464 DWORD *pdwEncDataLen,
7465 BYTE *pbEncData,
7466 BYTE *pbMAC,
7467 DWORD dwParam
7468);
7469
7494 HSESSIONCTX hSession,
7495 BYTE bOP,
7496 char *szIK,
7497 BYTE *pbTrackNum,
7498 BYTE *pbServiceID,
7499 BYTE *pbIssuerID,
7500 BYTE *pbExpDate,
7501 DWORD *pdwCSRLen,
7502 BYTE *pbCSR,
7503 DWORD dwParam
7504);
7505
7529 HSESSIONCTX hSession,
7530 BYTE bOP,
7531 char *szIK,
7532 BYTE *pbTrackNum,
7533 BYTE *pbServiceID,
7534 BYTE *pbIssuerID,
7535 BYTE *pbExpDate,
7536 DBLOB *pdbCSR,
7537 BYTE *pbHash,
7538 DWORD dwParam
7539);
7540
7581 HSESSIONCTX hSession,
7582 BYTE bOP,
7583 BYTE *pbNONCE,
7584 char *szTransportKey,
7585 char *szISSUER_MK,
7586 char *szISSUER_SMC_MK,
7587 char *szPAN,
7588 BYTE *pbSEQ,
7589 BYTE *pbOLD_PB,
7590 BYTE *pbNEW_PB,
7591 BYTE *pbOutBlock,
7592 DWORD *pdwOutBlockLen,
7593 DWORD dwParam
7594);
7595
7601 HSESSIONCTX hSession,
7602 char *szSrcKey,
7603 WORD wBufferLen,
7604 BYTE *pbBuffer,
7605 BYTE bOP,
7606 DWORD dwAttrib,
7607 char *szDstKey,
7608 HKEYCTX *phKey,
7609 DWORD dwParam
7610);
7611
7629 HSESSIONCTX hSession,
7630 char *szIssuerMK,
7631 char *szPAN,
7632 BYTE *pbSEQ,
7633 BYTE *pbARQC,
7634 BYTE *pbARC,
7635 BYTE *pbARPC,
7636 DWORD dwParam
7637);
7638
7639
7640#define DN_CALC_ARPC_EMV_4_2_M1_ICC (1)
7641#define DN_CALC_ARPC_EMV_4_2_M1_SK (2)
7642#define DN_CALC_ARPC_EMV_4_2_M2 (3)
7643
7663 DWORD dwOp,
7664 void *pvInData,
7665 BYTE *pbARPC,
7666 DWORD dwParam );
7667
7681 DWORD dwType,
7682 BYTE *pbKey,
7683 DWORD dwAlg,
7684 const BYTE *pbMsg,
7685 DWORD dwMsgLen,
7686 BYTE *pbMAC
7687);
7688
7689#define DN_EFT_AES_KCV_TYPE_CMAC (1)
7713int AAP_API DEFTImportKey(HSESSIONCTX hSession, char *szKeyId,
7714 int nKeyAlgId, void *pstKeyParts,
7715 DWORD dwParam);
7716
7733#define DN_EFT_GET_KCV_TYPE_X9_24 (1)
7734#define DN_EFT_GET_KCV_TYPE_CMAC (2)
7737 const char *szKeyId, void *pvKeyParts,
7738 DWORD dwReserved);
7739
7740int AAP_API DEFTExportKey(HSESSIONCTX hSession, BYTE bExportMode,
7741 char *szKEKId, char *szKeyId,
7742 BYTE *pbEncryptedBlock, DWORD *pdwEncryptedBlockLen,
7743 BYTE *pbKeyCheckValue, DWORD dwParam);
7744
7745int AAP_API DEFTKeKImport( HSESSIONCTX hSession, BYTE bOP, DWORD dwAlgId,
7746 char *szKeKName, char *szKeyName, DWORD dwAttr,
7747 BYTE *pbKCV1, BYTE *pbKCV2, BYTE *pbKCV3,
7748 BYTE *pbKCVFinal, BYTE *pbBlob, DWORD dwFlags );
7749
7750/* DEFTExportZPK */
7751
7752#define DN_EXP_ZPK_FLAG_FULL_CKS (1)
7772int AAP_API DEFTExportZPK(HSESSIONCTX hSession, char *szKeyId,
7773 int *pnKeyAlg, int *pnKeySize,
7774 EFT_VISA_KEY_PARTS *pstKeyParts, DWORD dwParam);
7775
7776#define DN_EFT_GET_KCV_MAX_LEN (3)
7791int AAP_API DEFTGetKcv(HSESSIONCTX hSession, BYTE bType, const char *szKeyId,
7792 BYTE *pbKcv, DWORD *pdwKcvLen, DWORD dwReserved);
7793
7794
7795#define DN_EFT_GEN_OFFLINE_KCV_TYPE_X9_24 (1)
7796#define DN_EFT_GEN_OFFLINE_KCV_TYPE_CMAC (2)
7798#define DN_EFT_KCV_TYPE_X9_24_LEN (3)
7799#define DN_EFT_KCV_TYPE_CMAC_LEN (3)
7801#define DN_EFTD_MAX_KEK_LEN (159)
7820int AAP_API DEFTGenKCVOffline(DWORD dwType, int nAlgId, const BYTE *pbKey,
7821 DWORD dwKeyLen, BYTE *pbKCV, DWORD *pdwKCVLen,
7822 DWORD reserved);
7907 const char *szKBPK,
7908 const char *szKey,
7909 void *pvReserved,
7910 WORD wUsage,
7911 BYTE bMode,
7912 BYTE bExport,
7913 BYTE *pbOutBlock,
7914 DWORD *pdwOutBlockLen,
7915 DWORD dwParam);
7916
7937 const char *szKBPK,
7938 const char *szKey,
7939 DWORD dwKeyAttributes,
7940 BYTE *pbKeyBlock,
7941 DWORD dwKeyBlockLen,
7942 DWORD dwParam);
7967 const char *szDestKey,
7968 DWORD dwAttributes,
7969 const char *szPart1,
7970 const char *szPart2,
7971 const char *szPart3,
7972 const BYTE *pbExpectedKcv,
7973 DWORD dwKcvLen,
7974 DWORD dwReserved);
7975
7995 const char *szLmk,
7996 BYTE bVariant,
7997 const char *szKey,
7998 BYTE bKs,
7999 char *szOut,
8000 DWORD *pdwOutLen,
8001 DWORD dwParam);
8002
8005/* Digital signature */
8006
8007int AAP_API DPowerSignHash(HSESSIONCTX hSession, char *szKeyId,
8008 int nHashAlgId, DWORD dwDataLen,
8009 BYTE *pbDataBuffer, DWORD *pdwSignLen,
8010 BYTE **ppbSignData);
8011
8046 HSESSIONCTX hSession,
8047 const char *szKeyName,
8048 const char *szKeyCert,
8049 const char *szCerts,
8050 DWORD dwAttrib,
8051 BYTE *pbContent,
8052 DWORD dwContentLen,
8053 DWORD *pdwSignatureLen,
8054 BYTE **ppbSignature,
8055 DWORD dwParam
8056);
8057
8061/* (CNS) Social Connectivity */
8063 char *szKeyID, char *szUsrID, char *szUsrName,
8064 WORD wModulusLen, BYTE *pbModulus,
8065 BYTE bExponentLen, BYTE *pbExponent,
8066 DWORD *pdwCertLen, BYTE *pbCert, DWORD dwParam );
8067
8068/* Hash */
8069int AAP_API DSignHashedData( HKEYCTX hKey, BYTE *pbData, DWORD dwDataLen,
8070 int nHashId, DWORD dwFlags, BYTE* pbSignature,
8071 DWORD* pdwSigLen );
8072
8074 DWORD dwPadding,
8075 BYTE*pbBlock,
8076 BYTE *pbData,
8077 DWORD* pdwDataLen,
8078 DWORD dwBlockSize,
8079 DWORD dwFlag );
8080
8082 BYTE *pbBlock,
8083 DWORD dwBlockCount,
8084 DWORD dwFlags );
8085
8086/* Base64 */
8087
8089 DWORD dwDataLen,
8090 char *szBase64,
8091 DWORD *pdwBase64Len,
8092 BOOL bNoNewLines );
8093
8095 DWORD dwBase64Len,
8096 BYTE *pbData,
8097 DWORD *pdwDataLen);
8098
8099
8134 HKEYCTX hKey,
8135 HHASHCTX hHash,
8136 char *szCertId,
8137 DWORD dwSizeUnsignedXml,
8138 BYTE *pbUnsignedXml,
8139 DWORD dwFilterLen,
8140 BYTE *pbFilter,
8141 DWORD *pdwSizeSignedXml,
8142 BYTE **ppbSignedXml
8143);
8144
8205 BYTE bHashMode,
8206 DWORD dwFlags,
8207 const char *szKeyId,
8208 const char *szCertId,
8209 DWORD dwSizeUnsignedXml,
8210 BYTE *pbUnsignedXml,
8211 DWORD dwFilterLen,
8212 BYTE *pbFilter,
8213 DWORD *pdwSizeSignedXml,
8214 BYTE **ppbSignedXml);
8215
8221int AAP_API DVerifySignedXml ( HSESSIONCTX hSession, char *szCertsId,
8222 DWORD dwSizeSignedXml, BYTE *pbSignedXml,
8223 DWORD dwFilterLen, BYTE *pbFilter);
8224
8245 HSESSIONCTX hSession,
8246 char *szCertsId,
8247 DWORD dwSizeSignedXml,
8248 BYTE *pbSignedXml,
8249 DWORD dwFilterLen,
8250 BYTE *pbFilter,
8251 char *szCRL
8252);
8253
8289 const char *szKeyId,
8290 const char *szCertId,
8291 DWORD dwFlags,
8292 DWORD dwSizeUnsignedPIXEnvelope,
8293 BYTE *pbUnsignedPIXEnvelope,
8294 DWORD *pdwSizeSignedPIXEnvelope,
8295 BYTE **ppbSignedPIXEnvelope);
8296
8297
8312 const char *szChainId,
8313 const char *szCRL,
8314 DWORD dwFlags,
8315 DWORD dwSizeSignedPIXEnvelope,
8316 BYTE* pbSignedPIXEnvelope);
8317
8338 const char *szKeyId,
8339 const char *szCertId,
8340 DWORD dwFlags,
8341 DWORD dwSizeUnsignedDictEnvelope,
8342 BYTE *pbUnsignedDictEnvelope,
8343 DWORD *pdwSizeSignedDictEnvelope,
8344 BYTE **ppbSignedDictEnvelope);
8345
8346
8361 const char *szChainId,
8362 const char *szCRL,
8363 DWORD dwFlags,
8364 DWORD dwSizeSignedDictEnvelope,
8365 BYTE* pbSignedDictEnvelope);
8366
8400 const char *szKeyId,
8401 DWORD dwFlags,
8402 DWORD dwHeaderLen,
8403 BYTE *pbHeader,
8404 DWORD dwPayloadLen,
8405 BYTE *pbPayload,
8406 DWORD *pdwJWSLen,
8407 BYTE *pbJWS);
8408
8427 const char *szChain,
8428 const char *szCRL,
8429 DWORD dwJWSLen,
8430 BYTE *pbJWS,
8431 DWORD dwFlags,
8432 DWORD *pdwHeaderLen,
8433 BYTE *pbHeader,
8434 DWORD *pdwPayloadLen,
8435 BYTE *pbPayload);
8436
8476 const char * szKeyId,
8477 const char * szCertId,
8478 const char * szPIXCertChainId,
8479 const char * szURL,
8480 DWORD dwCountRequestHeaderList,
8481 const char * pszRequestHeaderList[],
8482 DWORD dwSizeRequestData,
8483 BYTE* pbRequestData,
8484 DWORD dwTimeOut,
8485 DWORD * pdwSizeResponseHeaders,
8486 BYTE ** ppbResponseHeaders,
8487 DWORD * pdwSizeResponseBody,
8488 BYTE ** ppbResponseBody,
8489 DWORD dwParam);
8490
8491
8531 const char * szKeyId,
8532 const char * szCertId,
8533 const char * szPIXCertChainId,
8534 const char * szURL,
8535 DWORD dwCountRequestHeaderList,
8536 const char * pszRequestHeaderList[],
8537 DWORD dwSizeRequestData,
8538 BYTE* pbRequestData,
8539 DWORD dwTimeOut,
8540 DWORD * pdwSizeResponseHeaders,
8541 BYTE ** ppbResponseHeaders,
8542 DWORD * pdwSizeResponseBody,
8543 BYTE ** ppbResponseBody,
8544 DWORD dwParam);
8545
8582 const char * szKeyId,
8583 const char * szCertId,
8584 const char * szPIXCertChainId,
8585 const char * szURL,
8586 DWORD dwCountRequestHeaderList,
8587 const char * pszRequestHeaderList[],
8588 DWORD dwTimeOut,
8589 DWORD * pdwSizeResponseHeaders,
8590 BYTE ** ppbResponseHeaders,
8591 DWORD * pdwSizeResponseBody,
8592 BYTE ** ppbResponseBody,
8593 DWORD dwParam);
8594
8631 const char * szKeyId,
8632 const char * szCertId,
8633 const char * szPIXCertChainId,
8634 const char * szURL,
8635 DWORD dwCountRequestHeaderList,
8636 const char * pszRequestHeaderList[],
8637 DWORD dwTimeOut,
8638 DWORD * pdwSizeResponseHeaders,
8639 BYTE ** ppbResponseHeaders,
8640 DWORD * pdwSizeResponseBody,
8641 BYTE ** ppbResponseBody,
8642 DWORD dwParam);
8643
8646/* Library version */
8647
8648int AAP_API DVersion ( DWORD dwType, DWORD *pdwMajor,
8649 DWORD *pdwMinor, DWORD *pdwRevision,
8650 DWORD *pdwBuild );
8651
8670 DWORD dwsize
8671);
8672
8681 void *p
8682);
8683
8686//Free and clean CERT_X509_INFO structure members
8688
8689
8690/* Logs and monitoring */
8691
8692int AAP_API DLogLineFormat ( char *szIn, char *szOut );
8693
8695 HSESSIONCTX hSession,
8696 DWORD *pdwLogLen
8697);
8698
8700 DWORD dwStart,
8701 DWORD dwOffset,
8702 HLOGCTX *phLogCtx,
8703 DWORD dwParam );
8704
8706 BYTE *pbLog,
8707 DWORD *pdwLogSize );
8708
8710
8711
8712int AAP_API DGetStatInfo ( HSESSIONCTX hSession, DWORD *pdwSessions,
8713 DWORD *pdwCPU, DWORD *pdwUnit,
8714 DWORD *pdwMemTotal, DWORD *pdwMemUsed,
8715 DWORD *pdwSwapTotal, DWORD *pdwSwapUsed );
8716
8717int AAP_API DGetNetInfo ( HSESSIONCTX hSession, BYTE **ppbNetInfo, DWORD *pdwNetInfoCount, DWORD dwFlags );
8718
8719
8720/* Digital certificate */
8721
8723 DWORD dwCertLen,
8724 DWORD dwOutFormat,
8725 BYTE **ppbOutCert,
8726 DWORD *pdwOutCertLen,
8727 DWORD dwReserved );
8728
8729
8731 DWORD dwECLen,
8732 DWORD dwInForm,
8733 void *pvPrivKeyInfo,
8734 DWORD dwOutForm,
8735 DWORD dwReserved );
8736
8737
8739 DWORD dwECLen,
8740 DWORD dwInForm,
8741 void *pvPubKeyInfo,
8742 DWORD dwOutForm,
8743 DWORD dwReserved );
8744
8771 HSESSIONCTX hSession,
8772 char *szMasterKeyId,
8773 DWORD dwParamBlobType,
8774 void *pvParamBlob,
8775 DWORD dwParamBlobLen,
8776 BYTE *pbOTPBlob,
8777 DWORD *pdwOTPBlobLen,
8778 DWORD dwFlags
8779);
8780
8781
8782
8783
8813 HSESSIONCTX hSession,
8814 char *szMasterKeyId,
8815 char *szOTP,
8816 BYTE *pbOATHBlob,
8817 DWORD *pdwOATHBlobLen,
8818 DWORD dwFlags
8819);
8820
8835 HSESSIONCTX hSession,
8836 char *szMasterKeyId,
8837 BYTE bOTPLen,
8838 BYTE *pbOATHBlob,
8839 DWORD dwOATHBlobLen,
8840 char *szOTP,
8841 DWORD dwFlags
8842);
8843
8873 HSESSIONCTX hSession,
8874 DWORD dwSetup,
8875 BYTE bOTPLen,
8876 const char *szSK,
8877 const char *szSuite,
8878 const BYTE *pbCounter,
8879 const BYTE *pbQuestion,
8880 BYTE bQuestionLen,
8881 const BYTE *pbPinHash,
8882 const char *szSession,
8883 const BYTE *pbTimestamp,
8884 char *szOTP,
8885 DWORD dwFlags
8886);
8887
8908 const HSESSIONCTX hSession,
8909 char *szMasterKey,
8910 BYTE *pbInBlob,
8911 DWORD dwInBlobLen,
8912 DWORD dwOutBlobType,
8913 BYTE *pbOutInfo,
8914 DWORD *pdwOutInfoLen,
8915 DWORD dwParam
8916);
8917
8941 HSESSIONCTX hSession,
8942 char *szMasterKeyId,
8943 char *szOTP1,
8944 char *szOTP2,
8945 BYTE *pbOATHBlob,
8946 DWORD *pdwOATHBlobLen,
8947 DWORD dwFlags
8948);
8949
8966 HSESSIONCTX hSession,
8967 char *szMasterKey,
8968 BYTE *pbPSK,
8969 BYTE bPSKLen,
8970 BYTE *pbPSKC,
8971 DWORD dwPSKCLen,
8972 void **pvBlobList,
8973 DWORD *pdwBlobListQuantity,
8974 DWORD dwParam
8975);
8976
8979//DOATHIssueHOTPBlob is DEPRECATED. Use DOATHIssueBlob instead.
8981 HSESSIONCTX hSession,
8982 char *szMasterKeyId,
8983 DWORD dwParamBlobType,
8984 void *pvParamBlob,
8985 DWORD dwParamBlobLen,
8986 BYTE *pbOTPBlob,
8987 DWORD *pdwOTPBlobLen,
8988 DWORD dwFlags
8989);
8990
8991//DOATHCheckHOTP is DEPRECATED. Use DOATHCheckOTP instead.
8993 char *szMasterKeyId,
8994 char *szOTP,
8995 BYTE *pbOATHBlob,
8996 DWORD *pdwOATHBlobLen,
8997 DWORD dwFlags );
8998
8999//Users
9001 DWORD dwSecretLen,
9002 ND_OATH_uint64_t nuiMovingFactor,
9003 int nCodeDigits,
9004 BOOL bAddChecksum,
9005 int nTruncOff,
9006 char *szResult);
9007
9008
9042 HSESSIONCTX hSession,
9043 char *szSrcISPB,
9044 char *szDstISPB,
9045 DWORD dwTotalDataLen,
9046 BYTE bErrorCode,
9047 BYTE bSpecialTreatment,
9048 HSPBCTX *hSPBCtx,
9049 DWORD dwFlags
9050);
9051
9067 HSPBCTX hSPBCtx,
9068 BYTE *pbDataIn,
9069 DWORD dwDataInLen,
9070 BYTE *pbDataOut,
9071 DWORD *pdwDataOutLen
9072);
9073
9086 HSPBCTX *hSPBCtx,
9087 BYTE *pbSPBHeader,
9088 DWORD *pdwSPBHeaderLen
9089);
9090
9131 HSESSIONCTX hSession,
9132 char *szSrcISPB,
9133 char *szDstISPB,
9134 BYTE *pbHeader,
9135 DWORD dwHeaderLen,
9136 BYTE bAcceptExpiredCert,
9137 BYTE bAutoUpdateCert,
9138 DWORD dwMessageDataLen,
9139 HSPBCTX *hSPBCtx,
9140 DWORD dwFlags
9141);
9142
9160 HSPBCTX hSPBCtx,
9161 BYTE *pbDataIn,
9162 DWORD dwDataInLen,
9163 BYTE **ppbDataOut,
9164 DWORD *pdwDataOutLen
9165);
9166
9177 HSPBCTX *hSPBCtx
9178);
9179
9194 HSESSIONCTX hSession,
9195 char *szID,
9196 char *szPrivateKeyName,
9197 DWORD dwKeyParam,
9198 DWORD dwParam
9199);
9200
9236 HSESSIONCTX hSession,
9237 char *szPrivateKeyName,
9238 BYTE bVersion,
9239 char *szSPBSubject,
9240 DWORD dwOutType,
9241 DWORD *pdwCSRLen,
9242 BYTE **ppbCSR,
9243 DWORD dwParam
9244);
9245
9271 HSESSIONCTX hSession,
9272 BYTE bActivate,
9273 const char *szUser,
9274 BYTE *pbCertificate,
9275 DWORD dwCertificateLen,
9276 const char *szDomain,
9277 DWORD dwParam);
9278
9298 BYTE bActivate,
9299 const char *szUser,
9300 const char *szPkcs12File,
9301 const char *szPkcs12Pwd,
9302 const char *szDomain,
9303 DWORD dwKeyAttr);
9304
9322 const char *szPkcs12Pwd,
9323 const char *szISPB,
9324 const char *szReserved,
9325 BYTE **ppbPkcs12,
9326 DWORD *pdwPkcs12Len,
9327 DWORD dwReserved);
9328
9342 HSESSIONCTX hSession,
9343 const char *szIdCert,
9344 const char *szDomain,
9345 DWORD dwParam
9346);
9347
9362 HSESSIONCTX hSession,
9363 const char *szIdCert,
9364 BYTE **ppbCertificate,
9365 DWORD *pdwCertificateLen,
9366 DWORD dwParam
9367);
9368
9387 char *szISPB,
9388 char *szDomain,
9389 DWORD dwKeyType,
9390 char *szOutObjName,
9391 DWORD dwParam
9392);
9393
9408 HSESSIONCTX hSession,
9409 const char *szIdCert,
9410 EXT_MAP_2_OBJ_INFO *pstExtMap,
9411 DWORD dwParam
9412);
9413
9433 HSESSIONCTX hSession,
9434 char *szISPB,
9435 char *szKeyId,
9436 char *szCertId,
9437 DWORD dwParam
9438);
9439
9442/* Esta API pertence ao grupo SPB, mas precisa da documentacao*/
9444 HSESSIONCTX hSession,
9445 char *szDomain,
9446 BOOL bActive,
9447 DBLOB **pdbList,
9448 DWORD *pdwListLen,
9449 DWORD dwParam
9450);
9451
9489int AAP_API DBchainCreateXPrv(HSESSIONCTX hSession, BYTE bType, DWORD dwAttributes,
9490 const char *szId, const BYTE *pcbData, DWORD dwDataLen,
9491 DWORD dwReserved);
9492
9515int AAP_API DBchainCreateBip32Ckd(HSESSIONCTX hSession, BYTE bVersion, DWORD dwIndex,
9516 DWORD dwAttributes, const char *cszPar,
9517 const char *cszDst, DN_BCHAIN_KEY_INFO *pKeyInfo,
9518 DWORD dwReserved);
9519
9520#define DN_BCHAIN_CKD_OPT_BIP32_XPRV (1)
9521#define DN_BCHAIN_CKD_OPT_BIP32_ED25519_XPRV (2)
9522#define DN_BCHAIN_CKD_OPT_BIP32_P256_XPRV (3)
9543int AAP_API DBchainCreateCkd(HSESSIONCTX hSession, DWORD dwOpt, const BYTE *pbIn,
9544 BYTE *pbOut, DWORD dwReserved);
9545
9632 const char *cszHrp, const char *cszPk,
9633 BYTE *pbAddress, DWORD *pdwAddressLen,
9634 DWORD dwReserved);
9635
9666int AAP_API DBchainSignHash(HSESSIONCTX hSession, BYTE bType, BYTE bHashMode,
9667 BYTE *pbHash, DWORD dwHashLen, const char *cszPk,
9668 BYTE *pbSig, DWORD *pdwSigLen, DWORD dwReserved);
9669
9708int AAP_API DBchainVerify(HSESSIONCTX hSession, BYTE bSigType, BYTE bHashMode,
9709 const BYTE *pbHash, DWORD dwHashLen, const BYTE *pbSig,
9710 DWORD dwSigLen, BYTE bInPbkType, const BYTE *pbInPbk,
9711 BYTE bInPbkLen, DWORD dwReserved);
9712
9740int AAP_API DBchainEdDsaSign(HSESSIONCTX hSession, BYTE bType, const char *cszCtxStr,
9741 BYTE *pbData, DWORD dwDataLen, const char *cszPk,
9742 BYTE *pbSig, DWORD *pdwSigLen, DWORD dwReserved);
9743
9785int AAP_API DBchainEdDsaVerify(HSESSIONCTX hSession, BYTE bType, const char *cszCtxStr,
9786 BYTE *pbData, DWORD dwDataLen, BYTE bPbkType,
9787 BYTE *pbPbk, DWORD dwPbkLen, BYTE *pbSig,
9788 DWORD dwSigLen, DWORD dwReserved);
9816int AAP_API DBchainPkImport(HSESSIONCTX hSession, BYTE bFormat, DWORD dwAttributes,
9817 const char *cszId, const BYTE *pcbData, DWORD dwDataLen,
9818 DWORD dwReserved);
9819
9854int AAP_API DBchainPkExport(HSESSIONCTX hSession, BYTE bFormat, BYTE bVersion,
9855 BYTE bCompressed, const char *cszId, BYTE **ppbData,
9856 DWORD *pdwDataLen, DWORD dwReserved);
9857
9886 const char *cszId, BYTE *pbData,
9887 DWORD *pdwDataLen, DWORD dwReserved);
9888
9918 BYTE bHashMode, const BYTE *pbHash,
9919 DWORD dwHashLen, const BYTE *pbSig,
9920 DWORD dwSigLen, DN_BCHAIN_PBK *pPbk,
9921 DWORD dwReserved);
9922
9934 const char *cszId, void *pvData,
9935 DWORD *pdwDataLen);
9936
9959int AAP_API DBchainHashData(HSESSIONCTX hSession, BYTE bMode, BYTE *pbData,
9960 DWORD dwDataLen, BYTE *pbHash, DWORD *pdwHashLen,
9961 DWORD dwReserved);
9962
9975int AAP_API DBchainEd2X(HSESSIONCTX hSession, const char *cszPk,
9976 const char *cszTo, DWORD dwAttr, DWORD dwReserved);
9977
9985/* DSKeepNewSecret e DSKeepProbeSecret */
9986// Security level
9987#define DN_SKEEP_LEVEL_UNKNOWN (0)
9988#define DN_SKEEP_SEC_LEVEL_64b (1)
9989#define DN_SKEEP_SEC_LEVEL_96b (2)
9990#define DN_SKEEP_SEC_LEVEL_112b (3)
9991#define DN_SKEEP_SEC_LEVEL_128b (4)
9992#define DN_SKEEP_SEC_LEVEL_160b (5)
9994// Type
9995#define DN_SKEEP_TYPE_NMIND (0)
9996#define DN_SKEEP_TYPE_SCRD (1)
9997#define DN_SKEEP_TYPE_2FA (2)
9998#define DN_SKEEP_TYPE_CRT (4)
10027int AAP_API DSKeepNewSecret(HSESSIONCTX hSession, const char *cszId,
10028 BYTE bSecLevel, WORD wAuthType, DWORD dwReserved);
10029
10044int AAP_API DSKeepSplitSecret(HSESSIONCTX hSession, const char *cszId,
10045 BYTE bSecLevel, WORD wAuthType, BYTE bM, BYTE bN,
10046 SKeepShare *pstShares, DWORD dwReserved);
10047
10057int AAP_API DSKeepProbeSecret(HSESSIONCTX hSession, const char *cszId,
10058 SKeepProbeInfo *pstInfo, DWORD dwReserved);
10059
10071int AAP_API DSKeepMatchSecret(HSESSIONCTX hSession, const char *cszId,
10072 const SKeepShare *cpstShares, DWORD dwSharesCount,
10073 DWORD dwReserved);
10074
10086int AAP_API DSKeepRecoverSecret(HSESSIONCTX hSession, const char *cszId,
10087 const SKeepShare *cpstShares, DWORD dwSharesCount,
10088 SKeepRecoverInfo *pstRecoverInfo, DWORD dwReserved);
10089
10100int AAP_API DSKeepRemoveSecret(HSESSIONCTX hSession, const char *cszId,
10101 BYTE bSecLevel, WORD wAuthType, DWORD dwReserved);
10102
10103#define DN_SKEEP_SHARE_CKS_LEN (4)
10105#define DN_SKEEP_GEN_SHARE_CKS (1)
10118int AAP_API DSKeepCalcShareCks(DWORD dwType, const char *cszShare, char *szCks);
10119
10122#ifdef __cplusplus
10123 }
10124#endif
10125
10126#endif /* #ifndef DINAMO_H_INCLUDED */
#define MAX_IP_LEN
Definição dinamo.h:1804
int BOOL
Definição dinamo.h:48
void * HSESSIONCTX
Definição dinamo.h:67
void * HLOGCTX
Definição dinamo.h:73
char *AAP_API DByteArray2Base64(BYTE *pbData, DWORD dwDataLen, char *szBase64, DWORD *pdwBase64Len, BOOL bNoNewLines)
void * HOBJMETASEARCHCTX
Definição dinamo.h:76
int AAP_API DSetObjMetadataJson(HOBJMETACTX hInMeta, char *szData, DWORD dwDataLen, DWORD dwParam)
const OBJ_MET_ATTR * DGetHSMP11TypeInfoList(int *pnOutLen)
#define EFT_AES_KEY_CHECKSUM_LEN
Definição dinamo.h:1833
int AAP_API DGetStatInfo(HSESSIONCTX hSession, DWORD *pdwSessions, DWORD *pdwCPU, DWORD *pdwUnit, DWORD *pdwMemTotal, DWORD *pdwMemUsed, DWORD *pdwSwapTotal, DWORD *pdwSwapUsed)
#define DN_EFTD_MAX_KEY_ALIAS_LEN
Definição dinamo.h:755
#define GET_INFO_MAX_NTP_KM_LEN
Definição dinamo.h:824
int AAP_API DSetJsonObjMetadata(HSESSIONCTX hSession, const char *szId, const char *szJson, DWORD dwJsonLen, DWORD dwReserved)
#define DN_MAX_ALG_ID
Definição dinamo.h:2100
int AAP_API DOATHIssueHOTPBlob(HSESSIONCTX hSession, char *szMasterKeyId, DWORD dwParamBlobType, void *pvParamBlob, DWORD dwParamBlobLen, BYTE *pbOTPBlob, DWORD *pdwOTPBlobLen, DWORD dwFlags)
#define NET_INFO_MAX_SROUTE_COUNT
Definição dinamo.h:2117
#define DN_SC_MAX_CARD_PRODUCT_NAME_LEN
Definição dinamo.h:2806
int AAP_API DListPkcs11Maps(HSESSIONCTX hSession, int(AAP_API *ListKeyCallback)(char *szKeyName, void *pParam, BOOL bFinal), void *pParam)
int AAP_API DListUserTrusts(HSESSIONCTX hSession, char *szUserId, BYTE bType, int(AAP_API *ListUserTrustCallback)(char *szUserName, DWORD dwACL, void *pParam, BOOL bFinal), void *pParam)
unsigned short WORD
Definição dinamo.h:47
int AAP_API DGetObjMetadataJson(HOBJMETACTX hInMeta, char *szData, DWORD *pdwDataLen, DWORD dwParam)
#define MAX_NET_NAME
Definição dinamo.h:1805
#define RSA_8192_LEN
Definição dinamo.h:1380
int AAP_API DDestroyHSMP11Info(HP11ATTRCTX *phMeta, DWORD dwParam)
#define DN_SC_MAX_CARD_FAMILY_LEN
Definição dinamo.h:2805
int AAP_API DGetUserAcl(HSESSIONCTX hSession, char *szUser, DWORD *pdwUserAcl)
#define DN_BCHAIN_MAX_PBK_LEN
Definição dinamo.h:2406
int AAP_API DRemoveMapObj(const HSESSIONCTX hSession, const char *szMapObjId)
#define DN_SC_MAX_ATR_LEN
Definição dinamo.h:2804
#define MAX_P11_OBJ_ID
Definição dinamo.h:1810
int AAP_API DGetHSMLogCont(HLOGCTX hLogCtx, BYTE *pbLog, DWORD *pdwLogSize)
int AAP_API DECPublicKey2Info(BYTE *pbEC, DWORD dwECLen, DWORD dwInForm, void *pvPubKeyInfo, DWORD dwOutForm, DWORD dwReserved)
#define D_DS_BIND_PSK_LEN
Definição dinamo.h:641
#define DN_MAX_SUBJECT
Definição dinamo.h:2096
int AAP_API DListUserSessions(HSESSIONCTX hSession, int(AAP_API *ListUserSessionsCallback)(DWORD dwStartTime, char *szInfo, void *pParam, BOOL bFinal), void *pParam)
unsigned long long ND_OATH_uint64_t
Definição dinamo.h:37
unsigned int UINT
Definição dinamo.h:49
int AAP_API DGetObjInfo(const HSESSIONCTX hSession, const char *szObjId, const int nAlgId, const BYTE *pbData, DWORD *pdwDataLen)
int DIPFilterOperation(HSESSIONCTX hSession, BYTE bOP, char *szUser, char *szIP, int(AAP_API *ListIpFilterCallback)(void *pInData, DWORD dwInDataLen, void *pParam, BOOL bFinal), void *pParam, DWORD *pdwStatus, DWORD dwReserved)
#define EFT_EMV_SDA_SEQ_LEN
Definição dinamo.h:1838
int AAP_API DGetNetInfo(HSESSIONCTX hSession, BYTE **ppbNetInfo, DWORD *pdwNetInfoCount, DWORD dwFlags)
#define DN_M_OF_N_PART_LEN
Definição dinamo.h:3829
int AAP_API DListLoadedModules(HSESSIONCTX hSession, int(AAP_API *ListLoadedModulesCallback)(char *szModuleInfo, void *pParam, BOOL bFinal), void *pParam)
#define D_SVAULT_MAX_TL
Definição dinamo.h:2212
#define DN_RCC_MAX_REPL_MC_VER
Definição dinamo.h:3722
#define SA_TP_MAX_OTP_LEN
Definição dinamo.h:2002
int AAP_API DGetHsmInfo(HSESSIONCTX hSession, BOOL *pbFinal, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
#define DN_M_OF_N_S_MAX
Definição dinamo.h:3828
#define DN_SC_M_OF_N_SHADOW_MATERIAL_MAX_LEN
Definição dinamo.h:3952
#define ND_SPB_ISPB_LEN
Definição dinamo.h:1986
int AAP_API DGetHSMP11InfoAttr(HP11ATTRCTX hInMeta, DWORD dwOption, void *pvOptionData, DWORD *pdwOptionDataLen, DWORD dwParam)
#define ND_SPB_MAX_SUBJECT
Definição dinamo.h:1992
#define GET_INFO_MAX_REPL_NODES
Definição dinamo.h:817
#define OATH_MAX_PSK_LEN
Definição dinamo.h:2036
#define NET_INFO_MAX_SROUTE_LEN
Definição dinamo.h:2118
int AAP_API DCert2CertInfo(BYTE *pbCert, DWORD dwCertLen, DWORD dwOutType, void *pvCertInfo, DWORD dwFlags)
#define DN_GLOBAL_OBJ_STATS_COUNT
Definição dinamo.h:3886
int AAP_API DOATHCheckHOTP(HSESSIONCTX hSession, char *szMasterKeyId, char *szOTP, BYTE *pbOATHBlob, DWORD *pdwOATHBlobLen, DWORD dwFlags)
int AAP_API DLogLineFormat(char *szIn, char *szOut)
void * HCHAPCTX
Definição dinamo.h:72
unsigned char BYTE
Definição dinamo.h:44
#define DN_MAX_SN
Definição dinamo.h:2098
#define ND_SPB_MAX_ALG_ID
Definição dinamo.h:1994
#define DN_KEM_MAX_SS_LEN
Definição dinamo.h:3995
#define DN_KEM_D_MAX_CTX_LEN
Definição dinamo.h:3993
#define DN_USR_A_TOKEN_KLEN
Definição dinamo.h:2181
void AAP_API DGenerateHOTPOffline(BYTE *pbSecret, DWORD dwSecretLen, ND_OATH_uint64_t nuiMovingFactor, int nCodeDigits, BOOL bAddChecksum, int nTruncOff, char *szResult)
#define DN_MAX_HSM_ALIAS
Definição dinamo.h:3219
#define MAX_OBJ_ID_LEN
Definição dinamo.h:1816
int AAP_API DUpdatePkcs11Map(HSESSIONCTX hSession, char *szP11MapId, DWORD dwBlobType, DWORD dwFlags, DWORD dwUpdateMask, BYTE *pbData, DWORD dwDataLen)
int DGetObjMetadataTypeInfo(DWORD dwOption, void *pvData, DWORD *pdwDataLen, DWORD dwReserved)
#define GET_INFO_MAX_SN_LEN
Definição dinamo.h:818
void * HOBJMETACTX
Definição dinamo.h:74
void * HP11ATTRCTX
Definição dinamo.h:75
int AAP_API DCertEncodingConvert(BYTE *pbCert, DWORD dwCertLen, DWORD dwOutFormat, BYTE **ppbOutCert, DWORD *pdwOutCertLen, DWORD dwReserved)
#define MAX_HOTP_PIN
Definição dinamo.h:1806
int AAP_API DGetHSMLogInit(HSESSIONCTX hSession, DWORD dwStart, DWORD dwOffset, HLOGCTX *phLogCtx, DWORD dwParam)
#define DN_LIC_MAX_NAME
Definição dinamo.h:728
int AAP_API DRenameObj(HSESSIONCTX hSession, char *szOldObjName, char *szNewObjName, DWORD dwFlags)
int AAP_API DGetLogParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
int AAP_API DGenerateCNSCert(HSESSIONCTX hSession, char *szKeyID, char *szUsrID, char *szUsrName, WORD wModulusLen, BYTE *pbModulus, BYTE bExponentLen, BYTE *pbExponent, DWORD *pdwCertLen, BYTE *pbCert, DWORD dwParam)
#define NET_INFO_MAX_SNMP_C_STR
Definição dinamo.h:2122
void * HCERTCTX
Definição dinamo.h:70
#define DN_SC_M_OF_N_SHADOW_MAX_LEN
Definição dinamo.h:3953
#define GET_INFO_MAX_REPL_DOMAIN_NAME
Definição dinamo.h:816
#define MAX_HSM_ID_NAME
Definição dinamo.h:1828
int AAP_API DGetHSMLogEnd(HLOGCTX *phLogCtx)
unsigned long DN_ULONG
Definição dinamo.h:65
#define DN_MAX_ISSUER
Definição dinamo.h:2097
int AAP_API DGetPkcs11Map(HSESSIONCTX hSession, char *szP11MapId, DWORD dwBlobType, DWORD dwFlags, BYTE **ppbData, DWORD *pdwDataLen)
#define GET_INFO_MAX_NTP_KT_LEN
Definição dinamo.h:823
int AAP_API DGetObjMetadata(HOBJMETACTX hInMeta, DWORD dwOption, void *pvOptionData, DWORD *pdwOptionDataLen, DWORD dwParam)
unsigned int DWORD
Definição dinamo.h:45
#define DN_BCHAIN_BIP39_SEED_LEN_MAX
Definição dinamo.h:3778
#define EFT_EMV_ARC_LEN
Definição dinamo.h:1840
#define DES_BLOCK
Definição dinamo.h:1342
#define DN_BCHAIN_BIP39_PWD_LEN_MAX
Definição dinamo.h:3779
#define MAX_OATH_HMAC_LEN
Definição dinamo.h:867
#define SA_HOTP_CHAP_LEN
Definição dinamo.h:2004
#define DN_MAX_EMAIL
Definição dinamo.h:2099
#define DN_SKEEP_M_OF_N_S_LEN
Definição dinamo.h:3925
#define DN_EC_MAX_BIG_NUM
Definição dinamo.h:2552
#define DN_M_OF_N_S_LEN
Definição dinamo.h:3825
int AAP_API DSignHashedData(HKEYCTX hKey, BYTE *pbData, DWORD dwDataLen, int nHashId, DWORD dwFlags, BYTE *pbSignature, DWORD *pdwSigLen)
void * HHASHCTX
Definição dinamo.h:68
int AAP_API DECParam2AlgId(BYTE *pbECParam, DWORD dwECParamLen, int *pnAlgId, DWORD dwFlags)
#define AAP_API
Definição dinamo.h:41
#define DN_UPACK_MAX_DESCRIPTION
Definição dinamo.h:3220
int AAP_API DSPBGetCertificateList(HSESSIONCTX hSession, char *szDomain, BOOL bActive, DBLOB **pdbList, DWORD *pdwListLen, DWORD dwParam)
unsigned long long int QWORD
Definição dinamo.h:46
int AAP_API DDestroyObjMetadata(HOBJMETACTX *phMeta, DWORD dwParam)
#define DN_M_OF_N_ES_LEN
Definição dinamo.h:3826
int AAP_API DManageObjMetadata(HSESSIONCTX hSession, BYTE bOP, char *szObjName, HOBJMETACTX hInMeta, HOBJMETACTX *phOutMeta, DWORD dwParam)
#define MAX_HTTP_ADDR_LEN
Definição dinamo.h:3395
int AAP_API DGeneratePkcs11Map(HSESSIONCTX hSession, char *szP11MapId, BYTE bTemporary, DWORD dwBlobType, DWORD dwFlags, BYTE *pbData, DWORD dwDataLen)
int AAP_API DUPackPush(HSESSIONCTX hSession, DWORD dwPackSize, BYTE *pbPack)
#define MAX_ADDR_LEN
Definição dinamo.h:1794
#define D_MAX_DS_BIND_B62_ID
Definição dinamo.h:643
#define GET_INFO_MAX_NTPQ_LEN
Definição dinamo.h:822
int AAP_API DGetJsonObjMetadata(HSESSIONCTX hSession, const char *szId, DWORD dwOutType, char **pszOutJson, DWORD *pdwOutJsonLen)
#define GET_INFO_MAX_TPKEY_LEN
Definição dinamo.h:820
#define MAX_HTTP_API_TOKEN_LEN
Definição dinamo.h:3396
#define MAX_MODULE_NAME_VERSION_LEN
Definição dinamo.h:1803
#define MAX_USR_PWD
Definição dinamo.h:1788
int AAP_API DBatchSign(HKEYCTX hKey, BYTE *pbBlock, DWORD dwBlockCount, DWORD dwFlags)
int AAP_API DSetLogParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DVersion(DWORD dwType, DWORD *pdwMajor, DWORD *pdwMinor, DWORD *pdwRevision, DWORD *pdwBuild)
int AAP_API DPowerSignHash(HSESSIONCTX hSession, char *szKeyId, int nHashAlgId, DWORD dwDataLen, BYTE *pbDataBuffer, DWORD *pdwSignLen, BYTE **ppbSignData)
#define DN_KEM_MAX_C_LEN
Definição dinamo.h:3994
#define MAX_OBJ_ID_FQN_LEN
Definição dinamo.h:1819
#define EFT_EMV_PAD_LEN
Definição dinamo.h:1842
#define EFT_VISA_KEY_CHECKSUM_LEN
Definição dinamo.h:1834
#define D_MAX_DS_BIND_URL
Definição dinamo.h:640
int AAP_API DRemoveKey(HSESSIONCTX hSession, char *szKeyId)
#define ND_SPB_MAX_ISSUER
Definição dinamo.h:1993
#define MAX_HSM_MODEL_NAME
Definição dinamo.h:1827
int AAP_API DCreateObjMetadata(HOBJMETACTX *phOutMeta, DWORD dwParam)
int AAP_API DGetHSMP11Info(HSESSIONCTX hSession, HP11ATTRCTX *phOutMeta, DWORD dwParam)
signed char CHAR
Definição dinamo.h:51
int AAP_API DFindObjMetadataInit(HSESSIONCTX hSession, HOBJMETACTX hInMeta, HOBJMETASEARCHCTX *phMetaSearchCtx, DWORD dwParam)
void AAP_API DCleanCERT_X509_INFO(CERT_X509_INFO *pstCert)
int AAP_API DECPrivateKey2Info(BYTE *pbEC, DWORD dwECLen, DWORD dwInForm, void *pvPrivKeyInfo, DWORD dwOutForm, DWORD dwReserved)
#define NET_INFO_MAX_SNMP_T_COUNT
Definição dinamo.h:2119
#define GET_INFO_MAX_HW_STR_LEN
Definição dinamo.h:819
BOOL DDoRSAPadding(HSESSIONCTX hSession, DWORD dwPadding, BYTE *pbBlock, BYTE *pbData, DWORD *pdwDataLen, DWORD dwBlockSize, DWORD dwFlag)
int AAP_API DUPackInfo(DWORD dwPackSize, BYTE *pbPack, DWORD *pdwUPackVersion, BYTE **ppbUPackDescr, BYTE **ppbUPackSignature)
int AAP_API DGenerateMapObj(const HSESSIONCTX hSession, const char *szMapId, const char *szObj1Id, const int nObj1AlgId, const char *szObj2Id, const int nObj2AlgId)
#define NET_INFO_MAX_SNMP_SC_STR
Definição dinamo.h:2120
void * HKEYCTX
Definição dinamo.h:69
#define MAX_HOTP_APP_NAME
Definição dinamo.h:1808
#define MAX_OBJ_NAME_LEN
Definição dinamo.h:1801
#define MAX_PAN_LEN
Definição dinamo.h:1692
int AAP_API DGetStatLogSize(HSESSIONCTX hSession, DWORD *pdwLogLen)
#define DN_BCHAIN_BIP32_SEED_LEN_MAX
Definição dinamo.h:3767
#define ALG_AES_256_LEN
Definição dinamo.h:1335
int AAP_API DGetLibVersion(HSESSIONCTX hSession, char *szVersion, DWORD *pdwVersionLen, DWORD dwFlags)
int AAP_API DSetObjMetadata(HOBJMETACTX hInMeta, DWORD dwOption, void *pvOptionData, DWORD dwOptionDataLen, DWORD dwParam)
int AAP_API DFindObjMetadataEnd(HOBJMETASEARCHCTX *phMetaSearchCtx, DWORD dwParam)
#define GET_INFO_MAX_NTP_SVRS
Definição dinamo.h:821
#define DN_SC_MAX_CARD_OS_VERSION_LEN
Definição dinamo.h:2807
#define MAX_HOTP_IMEI
Definição dinamo.h:1807
int AAP_API DListObjsFilter(HSESSIONCTX hSession, DWORD dwFilterType, void *pvFilter, int(AAP_API *ListObjCallback)(void *pvIN, void *pParam, BOOL bFinal), void *pParam)
int AAP_API DUnsetObjMetadata(HOBJMETACTX hInMeta, DWORD dwOption, DWORD dwParam)
signed int INT
Definição dinamo.h:50
#define MAX_OBJ_ID_BIN_LEN
Definição dinamo.h:1811
int AAP_API DECPubKeyDER2AlgId(BYTE *pbECPubKeyDER, DWORD dwECPubKeyDERLen, int *pnAlgId, DWORD dwFlags)
const OBJ_MET_ATTR * DGetObjMetadataTypeInfoList(int *pnOutLen)
#define MAX_USR_LEN
Definição dinamo.h:1789
#define ISSUE_OATH_BLOB_V2_IV_LEN
Definição dinamo.h:2059
#define NET_INFO_MAX_SNMP_SL_STR
Definição dinamo.h:2121
#define DN_MAX_PRIVATE_KEY_ATTR_LEN
Definição dinamo.h:2781
unsigned long long ND_uint64_t
Definição dinamo.h:36
#define EFT_EMV_CSU_LEN
Definição dinamo.h:1841
int AAP_API DECPrivKeyDER2AlgId(const BYTE *pbDER, DWORD dwDERLen, int *pnAlgId, DWORD dwFlags)
#define ND_SPB_SN_MAX_LEN
Definição dinamo.h:1989
BYTE *AAP_API DBase642ByteArray(char *szBase64, DWORD dwBase64Len, BYTE *pbData, DWORD *pdwDataLen)
void * HSPBCTX
Definição dinamo.h:71
#define DN_RCC_MAX_NODE_COUNT
Definição dinamo.h:3721
#define ND_SPB_CA_LEN
Definição dinamo.h:1987
int AAP_API DFindObjMetadataCont(HOBJMETASEARCHCTX hMetaSearchCtx, HOBJMETACTX *phOutMeta, DWORD dwOutMetaMaxCount, DWORD *pdwOutMetaDataCount, DWORD dwParam)
int AAP_API DBchainEd2X(HSESSIONCTX hSession, const char *cszPk, const char *cszTo, DWORD dwAttr, DWORD dwReserved)
int AAP_API DBchainHashData(HSESSIONCTX hSession, BYTE bMode, BYTE *pbData, DWORD dwDataLen, BYTE *pbHash, DWORD *pdwHashLen, DWORD dwReserved)
int AAP_API DBchainEdDsaSign(HSESSIONCTX hSession, BYTE bType, const char *cszCtxStr, BYTE *pbData, DWORD dwDataLen, const char *cszPk, BYTE *pbSig, DWORD *pdwSigLen, DWORD dwReserved)
int AAP_API DBchainGetAddress(HSESSIONCTX hSession, BYTE bType, BYTE bVer, const char *cszHrp, const char *cszPk, BYTE *pbAddress, DWORD *pdwAddressLen, DWORD dwReserved)
int AAP_API DBchainSignHash(HSESSIONCTX hSession, BYTE bType, BYTE bHashMode, BYTE *pbHash, DWORD dwHashLen, const char *cszPk, BYTE *pbSig, DWORD *pdwSigLen, DWORD dwReserved)
int AAP_API DBchainCreateXPrv(HSESSIONCTX hSession, BYTE bType, DWORD dwAttributes, const char *szId, const BYTE *pcbData, DWORD dwDataLen, DWORD dwReserved)
int AAP_API DBchainCreateBip32Ckd(HSESSIONCTX hSession, BYTE bVersion, DWORD dwIndex, DWORD dwAttributes, const char *cszPar, const char *cszDst, DN_BCHAIN_KEY_INFO *pKeyInfo, DWORD dwReserved)
int AAP_API DBchainPkExport(HSESSIONCTX hSession, BYTE bFormat, BYTE bVersion, BYTE bCompressed, const char *cszId, BYTE **ppbData, DWORD *pdwDataLen, DWORD dwReserved)
int AAP_API DBchainPkImport(HSESSIONCTX hSession, BYTE bFormat, DWORD dwAttributes, const char *cszId, const BYTE *pcbData, DWORD dwDataLen, DWORD dwReserved)
int AAP_API DBchainCreateCkd(HSESSIONCTX hSession, DWORD dwOpt, const BYTE *pbIn, BYTE *pbOut, DWORD dwReserved)
int AAP_API DBchainGetPubKey(HSESSIONCTX hSession, BYTE bType, const char *cszId, BYTE *pbData, DWORD *pdwDataLen, DWORD dwReserved)
int AAP_API DBchainRecoverPbkFromSignature(HSESSIONCTX hSession, BYTE bSigType, BYTE bHashMode, const BYTE *pbHash, DWORD dwHashLen, const BYTE *pbSig, DWORD dwSigLen, DN_BCHAIN_PBK *pPbk, DWORD dwReserved)
int AAP_API DBchainVerify(HSESSIONCTX hSession, BYTE bSigType, BYTE bHashMode, const BYTE *pbHash, DWORD dwHashLen, const BYTE *pbSig, DWORD dwSigLen, BYTE bInPbkType, const BYTE *pbInPbk, BYTE bInPbkLen, DWORD dwReserved)
int AAP_API DBchainGetKeyInfo(HSESSIONCTX hSession, DWORD dwReserved, const char *cszId, void *pvData, DWORD *pdwDataLen)
int AAP_API DBchainEdDsaVerify(HSESSIONCTX hSession, BYTE bType, const char *cszCtxStr, BYTE *pbData, DWORD dwDataLen, BYTE bPbkType, BYTE *pbPbk, DWORD dwPbkLen, BYTE *pbSig, DWORD dwSigLen, DWORD dwReserved)
int AAP_API DGenEcdhKey(HSESSIONCTX hSession, DWORD dwOP, char *szPriKey, void *pvInData, DWORD dwInDataLen, BYTE *pbOutData, DWORD *pdwOutDataLen, DWORD dwFlags)
int AAP_API DKemEncaps(HSESSIONCTX hSession, DWORD dwOpt, const void *pvDataIn, const BYTE *pbEncapsKey, DWORD dwEncapsKeyLen, void *pvDataOut, DWORD dwReserved)
int AAP_API DKemDecaps(HSESSIONCTX hSession, DWORD dwOpt, const void *pvDataIn, const char *szDecapsKey, const BYTE *pbCiphertext, DWORD dwCiphertextLen, void *pvDataOut, DWORD dwReserved)
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 DMofNRecover(HSESSIONCTX hSession, DN_M_OF_N_PART *pstParts, DWORD dwPartsCount, BYTE *pbSecret, DWORD dwReserved)
int AAP_API DDecrypt(HKEYCTX hKey, HHASHCTX hHash, BOOL bFinal, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen)
int AAP_API DGetHashParam(HHASHCTX hHash, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
int AAP_API DPKCS7Sign(HSESSIONCTX hSession, const char *szKeyName, const char *szKeyCert, const char *szCerts, DWORD dwAttrib, BYTE *pbContent, DWORD dwContentLen, DWORD *pdwSignatureLen, BYTE **ppbSignature, DWORD dwParam)
int AAP_API DGetRandom(HSESSIONCTX hSession, BYTE *pbData, DWORD dwDataLen)
int AAP_API DRecoverSVMK(HSESSIONCTX hSession, DN_SC_M_OF_N_SHADOW *pstShadows, BYTE bShadowsCount, BYTE *pbKey, DWORD dwReserved)
int AAP_API DEncrypt(HKEYCTX hKey, HHASHCTX hHash, BOOL bFinal, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen, DWORD dwBufLen)
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 DMofNSplit(HSESSIONCTX hSession, BYTE bM, BYTE bN, BYTE *pbSecret, DWORD dwSecretLen, DN_M_OF_N_SPLIT_INFO *pstSplitInfo, DWORD dwReserved)
int AAP_API DSetHashParam(HHASHCTX hHash, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DDuplicateHash(HHASHCTX hHash, DWORD dwFlag, HHASHCTX *phHash)
int AAP_API DCRLCertCheck(HSESSIONCTX hSession, char *szCRL, char *szCertId, char *szCertOrChain)
int AAP_API DGenerateSVMK(HSESSIONCTX hSession, int nVersion, const BYTE *pbKey, BYTE bM, BYTE bN, DN_SC_M_OF_N_SHADOW *pstShadows, DWORD dwReserved)
int AAP_API DEFTImportTR31(HSESSIONCTX hSession, const char *szKBPK, const char *szKey, DWORD dwKeyAttributes, BYTE *pbKeyBlock, DWORD dwKeyBlockLen, DWORD dwParam)
int AAP_API DCalculateARPC(HSESSIONCTX hSession, char *szIssuerMK, char *szPAN, BYTE *pbSEQ, BYTE *pbARQC, BYTE *pbARC, BYTE *pbARPC, DWORD dwParam)
int AAP_API DGenerateEMV_HMAC(HSESSIONCTX hSession, BYTE bOP, char *szIK, char *szPAN, BYTE *pbSEQ, BYTE *pbNONCE, DWORD dwDataLen, BYTE *pbData, BYTE *pbMAC, DWORD dwParam)
int AAP_API DEFTLmkEncrypt(HSESSIONCTX hSession, const char *szLmk, BYTE bVariant, const char *szKey, BYTE bKs, char *szOut, DWORD *pdwOutLen, DWORD dwParam)
int AAP_API DGenerateICCMK(HSESSIONCTX hSession, BYTE bOP, char *szIK, char *szKeK, char *szPAN, BYTE *pbSEQ, DWORD *pdwEnvelopeLen, BYTE *pbEnvelope, DWORD dwParam)
void AAP_API DGenerateBDKName(BYTE *pbKSI, char *szBDKName, DWORD dwParam)
int AAP_API DGeneratePIN(HSESSIONCTX hSession, char *szPGK, char *szPAN, DWORD dwOperation, int nPinLen, char *szInPin, char *szOffset, char *szOutPin, DWORD dwParam)
int AAP_API DEFTImportKey(HSESSIONCTX hSession, char *szKeyId, int nKeyAlgId, void *pstKeyParts, DWORD dwParam)
int AAP_API DGenerateDAC(HSESSIONCTX hSession, char *szIMKDAC, char *szPAN, BYTE *pbSEQ, BYTE *pbDAC, DWORD dwParam)
int AAP_API DDeriveEMV_Key(HSESSIONCTX hSession, char *szSrcKey, WORD wBufferLen, BYTE *pbBuffer, BYTE bOP, DWORD dwAttrib, char *szDstKey, HKEYCTX *phKey, DWORD dwParam)
int AAP_API DEFTCheckKeyParts(int nKeyAlgId, EFT_VISA_KEY_PARTS *pstKeyParts, DWORD dwParam)
int AAP_API DGenerateEMV_PinBlock(HSESSIONCTX hSession, BYTE bOP, BYTE *pbNONCE, char *szTransportKey, char *szISSUER_MK, char *szISSUER_SMC_MK, char *szPAN, BYTE *pbSEQ, BYTE *pbOLD_PB, BYTE *pbNEW_PB, BYTE *pbOutBlock, DWORD *pdwOutBlockLen, DWORD dwParam)
int AAP_API DMAC_ISO9797_1_Met2(DWORD dwType, BYTE *pbKey, DWORD dwAlg, const BYTE *pbMsg, DWORD dwMsgLen, BYTE *pbMAC)
int AAP_API DEFTGetKcv(HSESSIONCTX hSession, BYTE bType, const char *szKeyId, BYTE *pbKcv, DWORD *pdwKcvLen, DWORD dwReserved)
int AAP_API DVerifyPINBlock(HSESSIONCTX hSession, char *szPTK, char *szPGK, char *szPAN, char *szOffset, BYTE *pbInPinBlock, DWORD dwParam)
int AAP_API DGenerateDDA_ICCCert(HSESSIONCTX hSession, BYTE bOP, char *szIK, char *szPAN, DWORD dwDDA_DATALen, BYTE *pbDDA_DATA, DWORD *pdwSigLen, BYTE *pbSig, DWORD dwParam)
int AAP_API DEFTMergeX9_24KeyParts(HSESSIONCTX hSession, const char *szDestKey, DWORD dwAttributes, const char *szPart1, const char *szPart2, const char *szPart3, const BYTE *pbExpectedKcv, DWORD dwKcvLen, DWORD dwReserved)
void AAP_API DGenerateDUKPTName(BYTE *pbKSI, BYTE *pbDID_CTR, char *szDUKPTName, DWORD dwParam)
int AAP_API DVerifyCVV(HSESSIONCTX hSession, char *szKeyId, char *szPAN, char *szExpirationDate, char *szServiceCode, char *szCVV, DWORD dwParam)
int AAP_API DEFTKeKImport(HSESSIONCTX hSession, BYTE bOP, DWORD dwAlgId, char *szKeKName, char *szKeyName, DWORD dwAttr, BYTE *pbKCV1, BYTE *pbKCV2, BYTE *pbKCV3, BYTE *pbKCVFinal, BYTE *pbBlob, DWORD dwFlags)
int AAP_API DEFTExportKey(HSESSIONCTX hSession, BYTE bExportMode, char *szKEKId, char *szKeyId, BYTE *pbEncryptedBlock, DWORD *pdwEncryptedBlockLen, BYTE *pbKeyCheckValue, DWORD dwParam)
int AAP_API DVerifyDAC(HSESSIONCTX hSession, char *szIMKDAC, char *szPAN, BYTE *pbSEQ, BYTE *pbDAC, DWORD dwParam)
int AAP_API DEFTExportZPK(HSESSIONCTX hSession, char *szKeyId, int *pnKeyAlg, int *pnKeySize, EFT_VISA_KEY_PARTS *pstKeyParts, DWORD dwParam)
int AAP_API DGenerateDUKPT(HSESSIONCTX hSession, BYTE *pbKSI, BYTE *pbDID_CTR, char *szDUKPT, DWORD dwParam)
int AAP_API DGeneratePVV(HSESSIONCTX hSession, char *szPGK, BYTE bPVKI, char *szPAN, char *szPIN, char *szPVV, DWORD dwParam)
int AAP_API DEFTExportAESKeyParts(HSESSIONCTX hSession, BYTE bKcvType, const char *szKeyId, void *pvKeyParts, DWORD dwReserved)
int AAP_API DGenerateEMV_CSR(HSESSIONCTX hSession, BYTE bOP, char *szIK, BYTE *pbTrackNum, BYTE *pbServiceID, BYTE *pbIssuerID, BYTE *pbExpDate, DWORD *pdwCSRLen, BYTE *pbCSR, DWORD dwParam)
int AAP_API DEncryptEMV(HSESSIONCTX hSession, BYTE bEncOP, char *szEncIK, BYTE *pbEncNONCE, BYTE bMacOP, char *szMacIK, BYTE *pbMacNONCE, char *szPAN, BYTE *pbSEQ, DWORD dwDataLen, BYTE *pbData, DWORD *pdwEncDataLen, BYTE *pbEncData, BYTE *pbMAC, DWORD dwParam)
int AAP_API DGenerateEMV_MAC(HSESSIONCTX hSession, BYTE bOP, char *szIK, char *szPAN, BYTE *pbSEQ, BYTE *pbNONCE, DWORD dwDataLen, BYTE *pbData, BYTE *pbMAC, DWORD dwParam)
int AAP_API DGenerateCVV(HSESSIONCTX hSession, char *szKeyId, char *szPAN, char *szExpirationDate, char *szServiceCode, char *szCVV, DWORD dwParam)
int AAP_API DCheckIDN(HSESSIONCTX hSession, char *szIK, char *szPAN, BYTE *pbSEQ, BYTE *pbATC, BYTE *pbUN, BYTE *pbIDN, DWORD dwParam)
int AAP_API DSignSDA(HSESSIONCTX hSession, char *szIK, BYTE *pbDAC, DWORD dwSDA_DATALen, BYTE *pbSDA_DATA, DWORD *pdwSigLen, BYTE *pbSig, DWORD dwParam)
int AAP_API DPINBlockTranslate(HSESSIONCTX hSession, char *szSrcPEK, char *szDstPEK, BYTE bTransBlockType, char *szPAN, BYTE *pbInPinBlock, BYTE *pbOutPinBlock, DWORD dwParam)
int AAP_API DEFTGenKCVOffline(DWORD dwType, int nAlgId, const BYTE *pbKey, DWORD dwKeyLen, BYTE *pbKCV, DWORD *pdwKCVLen, DWORD reserved)
int AAP_API DGenerateEMV_CSREx(HSESSIONCTX hSession, BYTE bOP, char *szIK, BYTE *pbTrackNum, BYTE *pbServiceID, BYTE *pbIssuerID, BYTE *pbExpDate, DBLOB *pdbCSR, BYTE *pbHash, DWORD dwParam)
int AAP_API DEFTExportTR31(HSESSIONCTX hSession, const char *szKBPK, const char *szKey, void *pvReserved, WORD wUsage, BYTE bMode, BYTE bExport, BYTE *pbOutBlock, DWORD *pdwOutBlockLen, DWORD dwParam)
int AAP_API DCalculateARPC_Ex(HSESSIONCTX hSession, DWORD dwOp, void *pvInData, BYTE *pbARPC, DWORD dwParam)
int AAP_API DAssociatePKCS11Key(HSESSIONCTX hSession, char *szPriKey, char *szPubKey, char *szCert, void *pvReserved, DWORD dwReserved)
int AAP_API DRSAPrivateKey2Info(const BYTE *pbRsa, DWORD dwRsaLen, DWORD dwInForm, DN_RSA_PRIVATE_KEY_INFO *stRsaInfo, DWORD dwReserved)
int AAP_API DDuplicateKey(HKEYCTX hKey, DWORD dwFlags, HKEYCTX *phKey)
int AAP_API DSetKeyParam(HKEYCTX hKey, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DGetUserKey(HSESSIONCTX hSession, char *szKeyId, DWORD dwFlags, HKEYCTX *phKey)
int AAP_API DImportPKCS12(const HSESSIONCTX hSession, const char *szPkcs12File, const char *szPkcs12Pwd, const char *szKeyId, const DWORD dwKeyAttr, const char *szCertId)
int AAP_API DPKCS8ExportKey(HSESSIONCTX hSession, char *szKeyId, char *szSecret, BYTE **ppbKeyEnvelope, DWORD *pdwKeyEnvelopeLen)
int AAP_API DGenerateKey(HSESSIONCTX hSession, char *szKeyId, int nAlgId, DWORD dwFlags, HKEYCTX *phKey)
int AAP_API DDeriveKey(HHASHCTX hHash, char *szKeyId, int nAlgId, DWORD dwFlags, HKEYCTX *phKey)
int AAP_API DPKCS8ImportKey(HSESSIONCTX hSession, char *szKeyId, char *szSecret, DWORD dwKeyAlg, DWORD dwAttrib, BYTE *pbKeyEnvelope, DWORD dwKeyEnvelopeLen)
int AAP_API DGenerateKeyMaterial(HSESSIONCTX hSession, int nAlgId, BYTE *pbData, DWORD *pdwDataLen, DWORD dwReserved)
int AAP_API DImportPKCS12Buffer(const HSESSIONCTX hSession, BYTE *pbPkcs12, DWORD dwPkcs12Len, const char *szPkcs12Pwd, const char *szKeyId, DWORD dwKeyAttr, const char *szCertId, const char *szPubKeyId, DWORD dwFlags)
int AAP_API DExportPKCS12(const HSESSIONCTX hSession, const char *szPkcs12Pwd, const char *szKeyId, const char *szCertId, const char *szReserved, BYTE **ppbPkcs12, DWORD *pdwPkcs12Len, DWORD dwFlags)
int AAP_API DRSAPublicKey2Info(BYTE *pbKey, DWORD dwKeyLen, DWORD dwInForm, void *pvPubKeyInfo, DWORD dwReserved)
int AAP_API DGeneratePKCS10CSR(HSESSIONCTX hSession, char *szPrivateKeyName, BYTE bVersion, char *szDN, DWORD dwOutType, DWORD *pdwCSRLen, BYTE **ppbCSR, DWORD dwParam)
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 DByokExport(HSESSIONCTX hSession, const char *cszKeyId, const char *cszKekId, DWORD dwType, const void *pvData, BYTE **ppbOutData, DWORD *pdwOutDataLen, DWORD dwReserved)
int AAP_API DGetKeyParam(HKEYCTX hKey, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
int AAP_API DExportKey(HKEYCTX hKey, HKEYCTX hKEKey, DWORD dwBlobType, DWORD dwFlags, BYTE *pbData, DWORD *pdwDataLen)
int AAP_API DHashSessionKey(HKEYCTX hKey, HHASHCTX hHash, DWORD dwFlags)
int AAP_API DManageAToken(HSESSIONCTX hSession, BYTE bOP, DN_A_TOKEN_FULL *pstATokenFull, funcListAKeysCallback fnCallBack, void *pvCallbackParam, DWORD dwParam)
int AAP_API DGetLogEvents(HSESSIONCTX hSession, funcLogEventCallback fncallback, void *pParam)
int AAP_API DDSBindHSM(HSESSIONCTX hSession, const char *szBindKey, DWORD dwReserved)
int(AAP_API * funcListAKeysCallback)(void *pvToken, void *pParam, BOOL bFinal)
Definição dinamo.h:4733
int AAP_API DReadFile(HSESSIONCTX hSession, char *szFileId, funcWriteLocalFileCallback fncallback, void *pParam)
int AAP_API DWriteFileBuffer(HSESSIONCTX hSession, const char *szFileId, BYTE *pbFile, DWORD dwFileSize, DWORD dwOptions)
int AAP_API DGetHSMTLSCert(char *szAddress, int nPort, DWORD dwOutFormat, BYTE **ppbOutCert, DWORD *pdwOutCertLen, DWORD dwFlags)
int(AAP_API * funcReadLocalFileCallback)(BYTE *pbData, DWORD *pdwDataLen, void *pParam, BOOL *pbFinal)
Definição dinamo.h:4568
const char *AAP_API DGetReturnCodeString(int nErrorValue, RetCodeMsgType eErrorType)
int AAP_API DAdmOperation(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DNSAuthSetState(HSESSIONCTX hSession, DWORD dwAcl, BYTE bState, DN_SC_M_OF_N_SHADOW *pstShadows, DWORD dwShadowsCount, DWORD dwReserved)
int AAP_API DBackupData(HSESSIONCTX hSession, char *szBackupFile, char *szPin, int nDirection)
int AAP_API DDSUnbindHSM(HSESSIONCTX hSession, DWORD dwReserved)
int AAP_API DRemoveObj(HSESSIONCTX hSession, char *szObjId)
int AAP_API DSCWriteShadow(DN_SC_M_OF_N_SHADOW *pstShadow, const char *szPIN, BOOL bOverwrite, DWORD dwReserved)
int AAP_API DSCChangePIN(const char *szCurrentPIN, const char *szNewPIN, DWORD dwReserved)
int(AAP_API * funcListKeyCallback)(char *szKeyName, void *pParam, BOOL bFinal)
Definição dinamo.h:4302
int AAP_API DTruncateLog(HSESSIONCTX hSession)
int AAP_API DSCGetLabel(const char *pin, char *label, DWORD reserved)
int AAP_API DBackupObject(HSESSIONCTX hSession, DWORD dwOP, char *szObjectId, char *szPin, BYTE *pbData, DWORD *pdwDataLen, DWORD dwReserved)
int AAP_API DGetStatLog(HSESSIONCTX hSession, DWORD dwStart, DWORD dwOffset, DWORD *pdwLogSize, BYTE **ppbLog)
BOOL AAP_API DSCIsLibLoaded()
int AAP_API DGetErrorString(int nErrorValue, char *szErrorCode, char *szErrorDesc)
int AAP_API DListObjs(HSESSIONCTX hSession, funcListKeyCallback fncallback, void *pParam)
int AAP_API DListBlobs(HSESSIONCTX hSession, funcListKeyCallback fncallback, void *pParam)
int(AAP_API * funcLogEventCallback)(char *szEvent, void *pParam, BOOL bFinal)
Definição dinamo.h:4399
int AAP_API DHSMTool(HSESSIONCTX hSession, DWORD dwOption, const char *szTarget, void **pvResult, DWORD *pdwResultLen, DWORD dwFlags)
int(AAP_API * funcWriteLocalFileCallback)(BYTE *pbData, DWORD dwDataLen, void *pParam, BOOL bFinal)
Definição dinamo.h:4609
int AAP_API DSCGetInfo(DN_SC_INFO *pstInfo, DWORD dwReserved)
RetCodeMsgType
Definição dinamo.h:4979
int AAP_API DManageATokenCache(HSESSIONCTX hSession, DWORD dwOP, void *pOutData, DWORD dwParam)
int AAP_API DSCSetLabel(const char *pin, const char *label, DWORD reserved)
int AAP_API DFindHSM(DWORD dwServiceType, DWORD dwFilter, void **ppvOutputData, DWORD *pdwOutputDataLen, DWORD dwFlags)
int AAP_API DWriteFile(HSESSIONCTX hSession, char *szFileId, DWORD dwFileSize, funcReadLocalFileCallback fncallback, void *pParam)
int AAP_API DSCReadShadow(const char *szPin, DN_SC_M_OF_N_SHADOW *pstShadow, DWORD dwReserved)
int AAP_API DSCErase(const char *szPIN, DWORD dwReserved)
int AAP_API DReadFileBuffer(HSESSIONCTX hSession, const char *szFileId, BYTE **ppbData, DWORD *pdwDataLen, DWORD dwReserved)
@ DESC_MSG
Definição dinamo.h:4981
@ CODE_MSG
Definição dinamo.h:4980
void *AAP_API DAlloc(DWORD dwsize)
void AAP_API DFree(void *p)
int AAP_API DOATHGetBlobInfo(const HSESSIONCTX hSession, char *szMasterKey, BYTE *pbInBlob, DWORD dwInBlobLen, DWORD dwOutBlobType, BYTE *pbOutInfo, DWORD *pdwOutInfoLen, DWORD dwParam)
int AAP_API DOATHIssueBlob(HSESSIONCTX hSession, char *szMasterKeyId, DWORD dwParamBlobType, void *pvParamBlob, DWORD dwParamBlobLen, BYTE *pbOTPBlob, DWORD *pdwOTPBlobLen, DWORD dwFlags)
int AAP_API DOATHGetNextOTP(HSESSIONCTX hSession, char *szMasterKeyId, BYTE bOTPLen, BYTE *pbOATHBlob, DWORD dwOATHBlobLen, char *szOTP, DWORD dwFlags)
int AAP_API DOATHPskcTranslate(HSESSIONCTX hSession, char *szMasterKey, BYTE *pbPSK, BYTE bPSKLen, BYTE *pbPSKC, DWORD dwPSKCLen, void **pvBlobList, DWORD *pdwBlobListQuantity, DWORD dwParam)
int AAP_API DOATHOcraGen(HSESSIONCTX hSession, DWORD dwSetup, BYTE bOTPLen, const char *szSK, const char *szSuite, const BYTE *pbCounter, const BYTE *pbQuestion, BYTE bQuestionLen, const BYTE *pbPinHash, const char *szSession, const BYTE *pbTimestamp, char *szOTP, DWORD dwFlags)
int AAP_API DOATHCheckOTP(HSESSIONCTX hSession, char *szMasterKeyId, char *szOTP, BYTE *pbOATHBlob, DWORD *pdwOATHBlobLen, DWORD dwFlags)
int AAP_API DOATHBlobResync(HSESSIONCTX hSession, char *szMasterKeyId, char *szOTP1, char *szOTP2, BYTE *pbOATHBlob, DWORD *pdwOATHBlobLen, DWORD dwFlags)
int AAP_API DPIXDictVerify(HSESSIONCTX hSession, const char *szChainId, const char *szCRL, DWORD dwFlags, DWORD dwSizeSignedDictEnvelope, BYTE *pbSignedDictEnvelope)
int AAP_API DPIXDelete(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, const char *szPIXCertChainId, const char *szURL, DWORD dwCountRequestHeaderList, const char *pszRequestHeaderList[], DWORD dwTimeOut, DWORD *pdwSizeResponseHeaders, BYTE **ppbResponseHeaders, DWORD *pdwSizeResponseBody, BYTE **ppbResponseBody, DWORD dwParam)
int AAP_API DPIXSign(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, DWORD dwFlags, DWORD dwSizeUnsignedPIXEnvelope, BYTE *pbUnsignedPIXEnvelope, DWORD *pdwSizeSignedPIXEnvelope, BYTE **ppbSignedPIXEnvelope)
int AAP_API DPIXPost(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, const char *szPIXCertChainId, const char *szURL, DWORD dwCountRequestHeaderList, const char *pszRequestHeaderList[], DWORD dwSizeRequestData, BYTE *pbRequestData, DWORD dwTimeOut, DWORD *pdwSizeResponseHeaders, BYTE **ppbResponseHeaders, DWORD *pdwSizeResponseBody, BYTE **ppbResponseBody, DWORD dwParam)
int AAP_API DPIXJWSCheck(HSESSIONCTX hSession, const char *szChain, const char *szCRL, DWORD dwJWSLen, BYTE *pbJWS, DWORD dwFlags, DWORD *pdwHeaderLen, BYTE *pbHeader, DWORD *pdwPayloadLen, BYTE *pbPayload)
int AAP_API DPIXGet(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, const char *szPIXCertChainId, const char *szURL, DWORD dwCountRequestHeaderList, const char *pszRequestHeaderList[], DWORD dwTimeOut, DWORD *pdwSizeResponseHeaders, BYTE **ppbResponseHeaders, DWORD *pdwSizeResponseBody, BYTE **ppbResponseBody, DWORD dwParam)
int AAP_API DPIXPut(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, const char *szPIXCertChainId, const char *szURL, DWORD dwCountRequestHeaderList, const char *pszRequestHeaderList[], DWORD dwSizeRequestData, BYTE *pbRequestData, DWORD dwTimeOut, DWORD *pdwSizeResponseHeaders, BYTE **ppbResponseHeaders, DWORD *pdwSizeResponseBody, BYTE **ppbResponseBody, DWORD dwParam)
int AAP_API DPIXVerify(HSESSIONCTX hSession, const char *szChainId, const char *szCRL, DWORD dwFlags, DWORD dwSizeSignedPIXEnvelope, BYTE *pbSignedPIXEnvelope)
int AAP_API DPIXJWSSign(HSESSIONCTX hSession, const char *szKeyId, DWORD dwFlags, DWORD dwHeaderLen, BYTE *pbHeader, DWORD dwPayloadLen, BYTE *pbPayload, DWORD *pdwJWSLen, BYTE *pbJWS)
int AAP_API DPIXDictSign(HSESSIONCTX hSession, const char *szKeyId, const char *szCertId, DWORD dwFlags, DWORD dwSizeUnsignedDictEnvelope, BYTE *pbUnsignedDictEnvelope, DWORD *pdwSizeSignedDictEnvelope, BYTE **ppbSignedDictEnvelope)
int AAP_API DSetLBList(DWORD dwParam, void *pvList, DWORD dwListCount, DWORD dwReserved)
int AAP_API DGetSessionParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
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)
int AAP_API DGetLBList(DWORD dwParam, void *pvList, DWORD *pdwListCount, DWORD dwReserved)
int AAP_API DFinalize()
int AAP_API DSetSessionParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DSKeepNewSecret(HSESSIONCTX hSession, const char *cszId, BYTE bSecLevel, WORD wAuthType, DWORD dwReserved)
int AAP_API DSKeepProbeSecret(HSESSIONCTX hSession, const char *cszId, SKeepProbeInfo *pstInfo, DWORD dwReserved)
int AAP_API DSKeepMatchSecret(HSESSIONCTX hSession, const char *cszId, const SKeepShare *cpstShares, DWORD dwSharesCount, DWORD dwReserved)
int AAP_API DSKeepRemoveSecret(HSESSIONCTX hSession, const char *cszId, BYTE bSecLevel, WORD wAuthType, DWORD dwReserved)
int AAP_API DSKeepCalcShareCks(DWORD dwType, const char *cszShare, char *szCks)
int AAP_API DSKeepSplitSecret(HSESSIONCTX hSession, const char *cszId, BYTE bSecLevel, WORD wAuthType, BYTE bM, BYTE bN, SKeepShare *pstShares, DWORD dwReserved)
int AAP_API DSKeepRecoverSecret(HSESSIONCTX hSession, const char *cszId, const SKeepShare *cpstShares, DWORD dwSharesCount, SKeepRecoverInfo *pstRecoverInfo, DWORD dwReserved)
int AAP_API DSPBImportCertificate(HSESSIONCTX hSession, BYTE bActivate, const char *szUser, BYTE *pbCertificate, DWORD dwCertificateLen, const char *szDomain, DWORD dwParam)
int AAP_API DSPBDecodeCont(HSPBCTX hSPBCtx, BYTE *pbDataIn, DWORD dwDataInLen, BYTE **ppbDataOut, DWORD *pdwDataOutLen)
int AAP_API DSPBDecodeEnd(HSPBCTX *hSPBCtx)
int AAP_API DSPBSetISPBMap(HSESSIONCTX hSession, char *szISPB, char *szKeyId, char *szCertId, DWORD dwParam)
int AAP_API DSPBMapInfo(HSESSIONCTX hSession, const char *szIdCert, EXT_MAP_2_OBJ_INFO *pstExtMap, DWORD dwParam)
int AAP_API DSPBExportPKCS12(const HSESSIONCTX hSession, const char *szPkcs12Pwd, const char *szISPB, const char *szReserved, BYTE **ppbPkcs12, DWORD *pdwPkcs12Len, DWORD dwReserved)
int AAP_API DSPBEncodeCont(HSPBCTX hSPBCtx, BYTE *pbDataIn, DWORD dwDataInLen, BYTE *pbDataOut, DWORD *pdwDataOutLen)
int AAP_API DSPBCalculateObjectId(char *szISPB, char *szDomain, DWORD dwKeyType, char *szOutObjName, DWORD dwParam)
int AAP_API DSPBGetCertificate(HSESSIONCTX hSession, const char *szIdCert, BYTE **ppbCertificate, DWORD *pdwCertificateLen, DWORD dwParam)
int AAP_API DSPBGenerateCSR(HSESSIONCTX hSession, char *szPrivateKeyName, BYTE bVersion, char *szSPBSubject, DWORD dwOutType, DWORD *pdwCSRLen, BYTE **ppbCSR, DWORD dwParam)
int AAP_API DSPBImportPKCS12(HSESSIONCTX hSession, BYTE bActivate, const char *szUser, const char *szPkcs12File, const char *szPkcs12Pwd, const char *szDomain, DWORD dwKeyAttr)
int AAP_API DSPBGenerateKey(HSESSIONCTX hSession, char *szID, char *szPrivateKeyName, DWORD dwKeyParam, DWORD dwParam)
int AAP_API DSPBEncodeEnd(HSPBCTX *hSPBCtx, BYTE *pbSPBHeader, DWORD *pdwSPBHeaderLen)
int AAP_API DSPBActivateCertificate(HSESSIONCTX hSession, const char *szIdCert, const char *szDomain, DWORD dwParam)
int AAP_API DSPBDecodeInit(HSESSIONCTX hSession, char *szSrcISPB, char *szDstISPB, BYTE *pbHeader, DWORD dwHeaderLen, BYTE bAcceptExpiredCert, BYTE bAutoUpdateCert, DWORD dwMessageDataLen, HSPBCTX *hSPBCtx, DWORD dwFlags)
int AAP_API DSPBEncodeInit(HSESSIONCTX hSession, char *szSrcISPB, char *szDstISPB, DWORD dwTotalDataLen, BYTE bErrorCode, BYTE bSpecialTreatment, HSPBCTX *hSPBCtx, DWORD dwFlags)
int AAP_API DSVaultGetData(HSESSIONCTX hSession, DWORD dwOp, const char *szMK, const char *szMask, BYTE *pbTokenBlob, DWORD dwTokenBlobLen, char *szData, DWORD *pdwDataLen, DWORD dwReserved)
int AAP_API DSVaultGenToken(HSESSIONCTX hSession, DWORD dwOp, BYTE *pbInData, BYTE *pbTokenBlob, DWORD *pdwTokenBlobLen, char *szToken, DWORD dwReserved)
int AAP_API DRemoveUser(HSESSIONCTX hSession, char *szUserId)
int AAP_API DUnassignToken(const HSESSIONCTX hSession, const DWORD dwParam, const char *szUserId)
int AAP_API DGetUserParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD *pdwDataLen, DWORD dwFlags)
int AAP_API DAssignToken(const HSESSIONCTX hSession, const char *szUserId, const DWORD dwParam, BYTE *pbData, const DWORD dwDataLen)
int AAP_API DCreateUser(HSESSIONCTX hSession, struct USER_INFO userInfo)
int AAP_API DSetUserParam(HSESSIONCTX hSession, DWORD dwParam, BYTE *pbData, DWORD dwDataLen, DWORD dwFlags)
int AAP_API DOATHResync(const HSESSIONCTX hSession, char *szUser, char *szOTP1, char *szOTP2, DWORD dwParam)
int AAP_API DListUsers(HSESSIONCTX hSession, funcListUsersCallback fncallback, void *pParam)
int(AAP_API * funcListUsersCallback)(char *szUserName, void *pParam, BOOL bFinal)
Definição dinamo.h:5160
int AAP_API DVerifySignedXml(HSESSIONCTX hSession, char *szCertsId, DWORD dwSizeSignedXml, BYTE *pbSignedXml, DWORD dwFilterLen, BYTE *pbFilter)
int AAP_API DSignXml(HKEYCTX hKey, HHASHCTX hHash, char *szCertId, DWORD dwSizeUnsignedXml, BYTE *pbUnsignedXml, DWORD dwFilterLen, BYTE *pbFilter, DWORD *pdwSizeSignedXml, BYTE **ppbSignedXml)
int AAP_API DSignXml2(HSESSIONCTX hSession, BYTE bHashMode, DWORD dwFlags, const char *szKeyId, const char *szCertId, DWORD dwSizeUnsignedXml, BYTE *pbUnsignedXml, DWORD dwFilterLen, BYTE *pbFilter, DWORD *pdwSizeSignedXml, BYTE **ppbSignedXml)
int AAP_API DVerifySignedXmlEx(HSESSIONCTX hSession, char *szCertsId, DWORD dwSizeSignedXml, BYTE *pbSignedXml, DWORD dwFilterLen, BYTE *pbFilter, char *szCRL)
Definição dinamo.h:3413
int nPort
Definição dinamo.h:3415
DN_A_TOKEN stAToken
Definição dinamo.h:3416
Definição dinamo.h:3402
char szAPIToken[MAX_HTTP_API_TOKEN_LEN+1]
Definição dinamo.h:3404
DWORD dwTimeout
Definição dinamo.h:3405
char szAddr[MAX_HTTP_ADDR_LEN+1]
Definição dinamo.h:3403
Definição dinamo.h:3379
int nPort
Definição dinamo.h:3381
char szUserId[MAX_USR_LEN]
Definição dinamo.h:3382
DWORD dwAuthType
Definição dinamo.h:3384
char szAddr[MAX_ADDR_LEN]
Definição dinamo.h:3380
char szPassword[MAX_USR_PWD]
Definição dinamo.h:3383
int nStrongAuthLen
Definição dinamo.h:3390
BYTE * pbStrongAuth
Definição dinamo.h:3389
Definição dinamo.h:3367
int nPort
Definição dinamo.h:3369
char szUserId[MAX_USR_LEN]
Definição dinamo.h:3370
char szAddr[MAX_ADDR_LEN]
Definição dinamo.h:3368
char szPassword[MAX_USR_PWD]
Definição dinamo.h:3371
Definição dinamo.h:3424
int nPort
Definição dinamo.h:3426
Definição dinamo.h:2525
int nPubKeyHSMAlgId
Definição dinamo.h:2538
DWORD dwVersion
Definição dinamo.h:2526
DBLOB dbPublicKey
Definição dinamo.h:2537
Definição dinamo.h:3125
int nVersion
Definição dinamo.h:3126
DBLOB dbIssuer
Definição dinamo.h:3129
DBLOB dbSubject
Definição dinamo.h:3128
P11_DATE dtNotBefore
Definição dinamo.h:3132
DBLOB dbSerialNumber
Definição dinamo.h:3130
P11_DATE dtNotAfter
Definição dinamo.h:3133
Definição dinamo.h:3729
DWORD dwIp
Definição dinamo.h:3731
DWORD dwRCode
Definição dinamo.h:3733
DWORD dwCount
Definição dinamo.h:3730
Definição dinamo.h:2498
void * pvData
Definição dinamo.h:2499
DWORD dwDataLen
Definição dinamo.h:2500
Definição dinamo.h:3357
DN_A_TOKEN stAToken
Definição dinamo.h:3358
QWORD qwExpiration
Definição dinamo.h:3359
Definição dinamo.h:3347
Definição dinamo.h:4052
DWORD dwAttributes
Definição dinamo.h:4063
DWORD dwIndex
Definição dinamo.h:4062
BYTE bVersion
Definição dinamo.h:4053
Definição dinamo.h:4073
BYTE bCkdType
Definição dinamo.h:4074
DN_BCHAIN_BIP32_CKD_IN_INFO stBaseInfo
Definição dinamo.h:4079
Definição dinamo.h:4087
BYTE bCkdType
Definição dinamo.h:4088
DN_BCHAIN_BIP32_CKD_IN_INFO stBaseInfo
Definição dinamo.h:4092
Definição dinamo.h:3772
DWORD dwSeedLen
Definição dinamo.h:3774
BYTE bVer
Definição dinamo.h:3773
Definição dinamo.h:3785
BYTE bVer
Definição dinamo.h:3786
Definição dinamo.h:3800
BYTE bStorageType
Definição dinamo.h:3801
BYTE bBip32Depth
Definição dinamo.h:3804
DWORD dwType
Definição dinamo.h:3802
Definição dinamo.h:3815
BYTE bLen
Definição dinamo.h:3817
BYTE bType
Definição dinamo.h:3816
Definição dinamo.h:3660
BYTE bOP
Definição dinamo.h:3667
Definição dinamo.h:3671
DWORD dwPADLen
Definição dinamo.h:3682
DWORD dwCSULen
Definição dinamo.h:3680
BYTE bOP
Definição dinamo.h:3676
Definição dinamo.h:2571
DWORD dwDataLen
Definição dinamo.h:2573
Definição dinamo.h:2583
DN_EC_BIG_NUMBER bnCofactor
Definição dinamo.h:2591
DN_EC_BIG_NUMBER bnOrder
Definição dinamo.h:2593
DN_EC_BIG_NUMBER bnP
Definição dinamo.h:2586
DN_EC_POINT_INFO stGeneratorPoint
Definição dinamo.h:2594
DN_EC_BIG_NUMBER bnA
Definição dinamo.h:2588
DN_EC_BIG_NUMBER bnB
Definição dinamo.h:2589
int nFieldType
Definição dinamo.h:2584
Definição dinamo.h:2577
DN_EC_BIG_NUMBER bnY
Definição dinamo.h:2579
DN_EC_BIG_NUMBER bnX
Definição dinamo.h:2578
Definição dinamo.h:2604
DN_EC_GROUP_INFO stGroupInfo
Definição dinamo.h:2605
DN_EC_BIG_NUMBER bnPrivatevalue
Definição dinamo.h:2606
Definição dinamo.h:2598
DN_EC_GROUP_INFO stGroupInfo
Definição dinamo.h:2599
DN_EC_POINT_INFO stPublicPoint
Definição dinamo.h:2600
Definição dinamo.h:2614
BYTE * pbRawOctetString
Definição dinamo.h:2615
DWORD dwHintSPKILen
Definição dinamo.h:2618
BYTE * pbHintSPKI
Definição dinamo.h:2617
DWORD dwRawOctetStringLen
Definição dinamo.h:2616
Definição dinamo.h:2710
BYTE bIsEftd0Active
Definição dinamo.h:2713
DWORD dwKeyAliasCount
Definição dinamo.h:2715
BYTE bMsgHeaderLen
Definição dinamo.h:2711
BYTE bPinLen
Definição dinamo.h:2712
BYTE bRestrictKcv
Definição dinamo.h:2714
DN_EFTD_KEY_ALIAS * pstKeyAlias
Definição dinamo.h:2716
Definição dinamo.h:2687
BYTE bIsEftd0Active
Definição dinamo.h:2690
BYTE bMsgHeaderLen
Definição dinamo.h:2688
BYTE bPinLen
Definição dinamo.h:2689
Definição dinamo.h:2698
Definição dinamo.h:6348
int nEphemeralKekAlg
Definição dinamo.h:6350
char * szKeKKid
Definição dinamo.h:6349
char * szGenerator
Definição dinamo.h:6351
Definição dinamo.h:3906
DN_OBJ_STATS stGlobal
Definição dinamo.h:3907
Definição dinamo.h:3981
QWORD dtLastHeal
Definição dinamo.h:3987
QWORD dtLastRun
Definição dinamo.h:3985
QWORD qwHealCounter
Definição dinamo.h:3984
QWORD qwCheckCounter
Definição dinamo.h:3983
QWORD qwRunCounter
Definição dinamo.h:3982
QWORD dtLastCheck
Definição dinamo.h:3986
Definição dinamo.h:4042
DWORD dwSharedSecretLen
Definição dinamo.h:4044
Definição dinamo.h:4030
DWORD dwCiphertextLen
Definição dinamo.h:4034
DWORD dwSharedSecretLen
Definição dinamo.h:4033
Definição dinamo.h:4007
DWORD dwAttr
Definição dinamo.h:4018
DWORD dwType
Definição dinamo.h:4017
BYTE bCtxLen
Definição dinamo.h:4015
BYTE bOp
Definição dinamo.h:4008
Definição dinamo.h:2851
INT nMax
Definição dinamo.h:2855
ND_uint64_t qwExpires
Definição dinamo.h:2853
INT nVal
Definição dinamo.h:2854
ND_uint64_t qwCreated
Definição dinamo.h:2852
Definição dinamo.h:3835
BYTE bN
Definição dinamo.h:3838
BYTE bM
Definição dinamo.h:3837
BYTE bPos
Definição dinamo.h:3836
Definição dinamo.h:3846
Definição dinamo.h:3854
DWORD dwPartCount
Definição dinamo.h:3858
Definição dinamo.h:2765
int nAlgId
Definição dinamo.h:2766
QWORD qwCount
Definição dinamo.h:2767
Definição dinamo.h:3865
ND_uint64_t uCount
Definição dinamo.h:3869
ND_uint64_t tFirst
Definição dinamo.h:3866
ND_uint64_t uLast
Definição dinamo.h:3868
ND_uint64_t uFirst
Definição dinamo.h:3867
Definição dinamo.h:3876
DN_OBJ_STAT_INFO stTouch
Definição dinamo.h:3877
DN_OBJ_STAT_INFO stUsage
Definição dinamo.h:3878
Definição dinamo.h:2643
DWORD dwDataLen
Definição dinamo.h:2645
Definição dinamo.h:2784
DWORD dwExponent2Len
Definição dinamo.h:2798
DWORD dwPrime2Len
Definição dinamo.h:2794
DWORD dwModulusLen
Definição dinamo.h:2786
DWORD dwPrime1Len
Definição dinamo.h:2792
DWORD dwCoefficientLen
Definição dinamo.h:2800
DWORD dwPrivExponentLen
Definição dinamo.h:2790
DWORD dwExponent1Len
Definição dinamo.h:2796
DWORD dwPubExponentLen
Definição dinamo.h:2788
Definição dinamo.h:2652
DN_RSA_BIG_NUMBER bnModulus
Definição dinamo.h:2653
DN_RSA_BIG_NUMBER bnPubExponent
Definição dinamo.h:2654
Definição dinamo.h:2813
BOOL bHasPINInfo
Definição dinamo.h:2830
BOOL bIsPINSMCOn
Definição dinamo.h:2831
BOOL bIsFormatted
Definição dinamo.h:2828
BYTE bLockByte1
Definição dinamo.h:2824
BYTE bPINMMPN
Definição dinamo.h:2832
BYTE bPINSCR
Definição dinamo.h:2833
BYTE bCardChipVersion
Definição dinamo.h:2823
BYTE bCardProgramVersion
Definição dinamo.h:2822
BOOL bIsPINLocked
Definição dinamo.h:2829
BOOL bIsOEMKeyAvailable
Definição dinamo.h:2827
BOOL bHasLegacyCard
Definição dinamo.h:2826
BYTE bPINUCR
Definição dinamo.h:2834
int nATRSize
Definição dinamo.h:2815
BYTE bPINCKS
Definição dinamo.h:2835
BYTE bLockByte2
Definição dinamo.h:2825
Definição dinamo.h:3964
BYTE bN
Definição dinamo.h:3967
BYTE bM
Definição dinamo.h:3966
BYTE bPos
Definição dinamo.h:3965
Definição dinamo.h:3975
int nVersion
Definição dinamo.h:3976
Definição dinamo.h:2775
DWORD dwObjCountCount
Definição dinamo.h:2778
DN_OBJ_COUNT * pstObjCount
Definição dinamo.h:2777
Definição dinamo.h:3706
BYTE bVersion
Definição dinamo.h:3707
Definição dinamo.h:2634
DBLOB dbEcPoint
Definição dinamo.h:2635
DBLOB dbEcParams
Definição dinamo.h:2636
Definição dinamo.h:3636
DWORD dwAttributes
Definição dinamo.h:3637
EFT_AES_KEY_PARTS stParts
Definição dinamo.h:3638
Definição dinamo.h:3625
Definição dinamo.h:3645
Definição dinamo.h:3611
Definição dinamo.h:3506
DWORD dwObjAlgId2
Definição dinamo.h:3509
DWORD dwObjAlgId1
Definição dinamo.h:3507
Definição dinamo.h:3690
DWORD dwTargetKeyAlg
Definição dinamo.h:3694
DWORD dwTargetKeyAttributes
Definição dinamo.h:3695
DBLOB dbPubKey
Definição dinamo.h:3696
DBLOB dbKDFData
Definição dinamo.h:3697
Definição dinamo.h:2723
BYTE * pbPubKey
Definição dinamo.h:2728
DWORD dwFlags
Definição dinamo.h:2726
BOOL bTempKey
Definição dinamo.h:2727
int nAlgId
Definição dinamo.h:2725
DWORD dwPubKeyLen
Definição dinamo.h:2729
Definição dinamo.h:3327
DWORD dwImageLen
Definição dinamo.h:3329
Definição dinamo.h:3320
DWORD dwParam
Definição dinamo.h:3321
DWORD dwHipFlags
Definição dinamo.h:3322
DWORD dwHipColor
Definição dinamo.h:3323
Definição dinamo.h:3306
DWORD dwStructId
Definição dinamo.h:3307
Definição dinamo.h:3137
DWORD dwObjAttr
Definição dinamo.h:3140
DWORD dwObjHotpFlags
Definição dinamo.h:3141
DBLOB * pdbStLogoImage
Definição dinamo.h:3145
DWORD dwStructId
Definição dinamo.h:3138
Definição dinamo.h:3312
DWORD dwStructId
Definição dinamo.h:3313
Definição dinamo.h:2463
int nPort
Definição dinamo.h:2465
time_t tmNow
Definição dinamo.h:2466
int nqtdcache
Definição dinamo.h:2467
Definição dinamo.h:2544
Definição dinamo.h:3056
ISSUE_OATH_INFO_t stInfo
Definição dinamo.h:3057
Definição dinamo.h:3065
ISSUE_OATH_INFO_t stInfo
Definição dinamo.h:3066
Definição dinamo.h:2990
BYTE seed_len
Definição dinamo.h:2991
ND_OATH_uint64_t T0
Definição dinamo.h:3011
WORD time_step
Definição dinamo.h:3006
ND_OATH_uint64_t moving_factor
Definição dinamo.h:2998
BYTE truncation_offset
Definição dinamo.h:3002
Definição dinamo.h:3025
BYTE seed_len
Definição dinamo.h:3026
ND_OATH_uint64_t T0
Definição dinamo.h:3046
WORD time_step
Definição dinamo.h:3041
ND_OATH_uint64_t moving_factor
Definição dinamo.h:3033
BYTE truncation_offset
Definição dinamo.h:3037
Definição dinamo.h:2955
WORD wTimeStep
Definição dinamo.h:2967
BYTE bUseDefaultMovingFactor
Definição dinamo.h:2976
ND_OATH_uint64_t otMovingFactor
Definição dinamo.h:2979
ND_OATH_uint64_t otT0
Definição dinamo.h:2972
BYTE bTruncationOffset
Definição dinamo.h:2963
BYTE bSeedLen
Definição dinamo.h:2956
Definição dinamo.h:2475
HSM_ADDR * pstLBList
Definição dinamo.h:2476
DWORD dwLBListCount
Definição dinamo.h:2477
Definição dinamo.h:3498
char szObj1Id[MAX_OBJ_NAME_LEN+1]
Definição dinamo.h:3500
char szObj2Id[MAX_OBJ_NAME_LEN+1]
Definição dinamo.h:3502
DWORD dwObj1AlgId
Definição dinamo.h:3499
DWORD dwObj2AlgId
Definição dinamo.h:3501
Definição dinamo.h:3515
DWORD dwModuleId
Definição dinamo.h:3516
char szModuleNameVersion[MAX_MODULE_NAME_VERSION_LEN]
Definição dinamo.h:3517
Definição dinamo.h:3075
ISSUE_OATH_BLOB_t stOATHBlob
Definição dinamo.h:3076
Definição dinamo.h:3084
BYTE key_len
Definição dinamo.h:3089
BYTE type
Definição dinamo.h:3085
BYTE truncation_offset
Definição dinamo.h:3091
Definição dinamo.h:3098
OATH_SA_v1 sa_v1
Definição dinamo.h:3099
ND_OATH_uint64_t T0
Definição dinamo.h:3104
WORD time_step
Definição dinamo.h:3100
Definição dinamo.h:2860
DWORD len
Definição dinamo.h:2864
DWORD type
Definição dinamo.h:2862
DWORD attrib
Definição dinamo.h:2863
DWORD version
Definição dinamo.h:2861
Definição dinamo.h:2937
OBJ_HDR_V1 stSlot2Header
Definição dinamo.h:2944
OBJ_HDR_V1 stObjectHeader
Definição dinamo.h:2938
BYTE bBlockedStatus
Definição dinamo.h:2947
ND_uint64_t stCreationTime
Definição dinamo.h:2948
OBJ_HDR_V1 stSlot1Header
Definição dinamo.h:2941
Definição dinamo.h:2926
OBJ_HDR_V1 stObjectHeader
Definição dinamo.h:2928
DWORD dwVERB
Definição dinamo.h:2927
Definição dinamo.h:5407
const char * pszString
Definição dinamo.h:5409
DWORD dwId
Definição dinamo.h:5408
DWORD dwType
Definição dinamo.h:5410
Definição dinamo.h:2871
QWORD qwOrig_creat
Definição dinamo.h:2881
QWORD qwDeactiv
Definição dinamo.h:2876
QWORD qwComprom
Definição dinamo.h:2878
QWORD qwLast_change
Definição dinamo.h:2880
QWORD qwC_occur
Definição dinamo.h:2877
QWORD qwProtect_s
Definição dinamo.h:2875
QWORD qwMask
Definição dinamo.h:2882
QWORD qwInit
Definição dinamo.h:2872
QWORD qwActiv
Definição dinamo.h:2873
QWORD qwProc_s
Definição dinamo.h:2874
BYTE bState
Definição dinamo.h:2883
QWORD qwArchive
Definição dinamo.h:2879
Definição dinamo.h:3118
Definição dinamo.h:2737
ND_uint64_t redirect_time
Definição dinamo.h:2744
ND_uint64_t upload_size
Definição dinamo.h:2751
ND_uint64_t upload_speed
Definição dinamo.h:2748
ND_uint64_t starttransfer_time
Definição dinamo.h:2742
ND_uint64_t content_length_upload
Definição dinamo.h:2746
ND_uint64_t connect_time
Definição dinamo.h:2739
ND_uint64_t request_size
Definição dinamo.h:2755
ND_uint64_t pretransfer_time
Definição dinamo.h:2741
ND_uint64_t num_connects
Definição dinamo.h:2754
ND_uint64_t download_size
Definição dinamo.h:2750
ND_uint64_t http_response_code
Definição dinamo.h:2757
ND_uint64_t redirect_count
Definição dinamo.h:2753
ND_uint64_t name_lookup_time
Definição dinamo.h:2738
ND_uint64_t received_header_size
Definição dinamo.h:2756
ND_uint64_t appconnect_time
Definição dinamo.h:2740
ND_uint64_t download_speed
Definição dinamo.h:2749
ND_uint64_t total_time
Definição dinamo.h:2743
ND_uint64_t content_length_download
Definição dinamo.h:2747
Definição dinamo.h:3521
BYTE Trusted
Definição dinamo.h:3535
BYTE Local
Definição dinamo.h:3537
BYTE WrapWithTrusted
Definição dinamo.h:3536
DWORD JavaMidpSecDomain
Definição dinamo.h:3540
DWORD CertificateCategory
Definição dinamo.h:3539
DWORD KeyGenMechanism
Definição dinamo.h:3541
DWORD Class
Definição dinamo.h:3525
Definição dinamo.h:3595
BYTE bMaxInvalidLogins
Definição dinamo.h:3597
BYTE bLower
Definição dinamo.h:3604
BYTE bHistory
Definição dinamo.h:3599
BYTE bUpper
Definição dinamo.h:3603
BYTE bMinLength
Definição dinamo.h:3601
BYTE bExpiration
Definição dinamo.h:3598
BYTE bMinSpecial
Definição dinamo.h:3602
Definição dinamo.h:3299
DWORD dwPeer
Definição dinamo.h:3301
BYTE bOP
Definição dinamo.h:3300
Definição dinamo.h:2625
DBLOB dbPubExponent
Definição dinamo.h:2627
DBLOB dbModulus
Definição dinamo.h:2626
Definição dinamo.h:3917
WORD wAuthType
Definição dinamo.h:3918
BYTE bSecLevel
Definição dinamo.h:3919
Definição dinamo.h:3931
BYTE bSecLevel
Definição dinamo.h:3932
Definição dinamo.h:3940
Definição dinamo.h:2486
int nPort
Definição dinamo.h:2487
Definição dinamo.h:2506
DWORD dwVersion
Definição dinamo.h:2507
DBLOB dbPublicKey
Definição dinamo.h:2521
Definição dinamo.h:3112
Definição dinamo.h:2423
BYTE bFrom
Definição dinamo.h:2442
BYTE bCKS
Definição dinamo.h:2431
BYTE bFlags
Definição dinamo.h:2424
BYTE bType
Definição dinamo.h:2441
BYTE bTo
Definição dinamo.h:2448
Definição dinamo.h:3283
SYS_NTP_INFO stNTPInfo
Definição dinamo.h:3291
int nFilledCount
Definição dinamo.h:3284
SYS_HW_STR_INFO stHardwareInfo
Definição dinamo.h:3290
SYS_REPL_INFO stReplicationInfo
Definição dinamo.h:3288
DWORD dwFIPSReturnCode
Definição dinamo.h:3293
SYS_STATUS_INFO stStatusInfo
Definição dinamo.h:3285
DWORD dwFIPSMode
Definição dinamo.h:3286
SYS_DISK_INFO stDiskInfo
Definição dinamo.h:3287
QWORD qwCurrentDateTime
Definição dinamo.h:3289
SYS_PENDING_INFO stPendingInfo
Definição dinamo.h:3294
SYS_COUNTER_INFO stCounterInfo
Definição dinamo.h:3292
Definição dinamo.h:3210
QWORD qwUsers
Definição dinamo.h:3211
QWORD qwSLBeFileSize
Definição dinamo.h:3213
QWORD qwVMSize
Definição dinamo.h:3215
QWORD qwTasks
Definição dinamo.h:3214
QWORD qwObjects
Definição dinamo.h:3212
Definição dinamo.h:3184
DWORD dwBlockSize
Definição dinamo.h:3185
DWORD dwFreeBlocks
Definição dinamo.h:3187
DWORD dwTotalBlocks
Definição dinamo.h:3186
Definição dinamo.h:3178
DWORD dwBatteryOK
Definição dinamo.h:3180
DWORD dwUptime
Definição dinamo.h:3179
Definição dinamo.h:3235
Definição dinamo.h:3162
DWORD dwSysNetInfoCount
Definição dinamo.h:3164
SYS_NET_INFO * pstSysNetInfo
Definição dinamo.h:3163
Definição dinamo.h:3151
DWORD dwSpeed
Definição dinamo.h:3157
BYTE bUp
Definição dinamo.h:3156
Definição dinamo.h:3252
BYTE bENABLED
Definição dinamo.h:3253
Definição dinamo.h:3242
DWORD dwKeyLen
Definição dinamo.h:3246
WORD wKeyIndex
Definição dinamo.h:3245
Definição dinamo.h:3227
BYTE bPendingBackup
Definição dinamo.h:3228
Definição dinamo.h:3260
DWORD dwDiscoveryPulse
Definição dinamo.h:3274
QWORD qwSpVal
Definição dinamo.h:3269
DWORD dwManagerPulse
Definição dinamo.h:3272
DWORD dwRecoveryPulse
Definição dinamo.h:3273
QWORD qwEventType
Definição dinamo.h:3265
DWORD dwBoundEth
Definição dinamo.h:3262
WORD wSpvv
Definição dinamo.h:3270
QWORD qwGuid
Definição dinamo.h:3263
QWORD qwDateTime
Definição dinamo.h:3264
DWORD dwDiscoveryReset
Definição dinamo.h:3271
DWORD dwState
Definição dinamo.h:3266
Definição dinamo.h:3195
DWORD dwMemTotal
Definição dinamo.h:3199
DWORD dwMemUsed
Definição dinamo.h:3200
DWORD dwCPU
Definição dinamo.h:3197
DWORD dwUnit
Definição dinamo.h:3198
DWORD dwSwapTotal
Definição dinamo.h:3201
DWORD dwSwapUsed
Definição dinamo.h:3202
DWORD dwSessions
Definição dinamo.h:3196
Definição dinamo.h:2678
Definição dinamo.h:3434
DBLOB dbHSMCert
Definição dinamo.h:3438
DBLOB dbPrivateKeyCert
Definição dinamo.h:3437
char * szPrivateKeyPwd
Definição dinamo.h:3436
DBLOB dbPrivateKey
Definição dinamo.h:3435
Definição dinamo.h:3337
DWORD dwAttempts
Definição dinamo.h:3340
int nBlocked
Definição dinamo.h:3339
Definição dinamo.h:2664
DBLOB dbCert
Definição dinamo.h:2671
BYTE bOP
Definição dinamo.h:2666
Definição dinamo.h:3445
DWORD dwAuthMask
Definição dinamo.h:3448
char szPassword[MAX_USR_PWD+1]
Definição dinamo.h:3447
char szUserId[MAX_USR_LEN+1]
Definição dinamo.h:3446
Definição dinamo.h:3476
DWORD dwACL
Definição dinamo.h:3486
DWORD dwState
Definição dinamo.h:3478