blob: 346e04df9ca552bb40ef5c73e669c7e818ab1567 [file] [log] [blame]
Jean-Paul Calderone897bc252008-02-18 20:50:23 -05001/*
2 * crypto.h
3 *
4 * Copyright (C) AB Strakt 2001, All rights reserved
5 *
6 * Exports from crypto.c.
7 * See the file RATIONALE for a short explanation of why this module was written.
8 *
9 * Reviewed 2001-07-23
10 *
11 * @(#) $Id: crypto.h,v 1.14 2004/08/09 13:41:25 martin Exp $
12 */
13#ifndef PyOpenSSL_CRYPTO_H_
14#define PyOpenSSL_CRYPTO_H_
15
16#include <Python.h>
17#include "x509.h"
18#include "x509name.h"
19#include "netscape_spki.h"
20#include "x509store.h"
21#include "x509req.h"
22#include "pkey.h"
23#include "x509ext.h"
24#include "pkcs7.h"
25#include "pkcs12.h"
26#include "../util.h"
27
28extern PyObject *crypto_Error;
29
Jean-Paul Calderone897bc252008-02-18 20:50:23 -050030#define crypto_X509_New_NUM 0
31#define crypto_X509_New_RETURN crypto_X509Obj *
32#define crypto_X509_New_PROTO (X509 *, int)
33
34#define crypto_X509Req_New_NUM 1
35#define crypto_X509Req_New_RETURN crypto_X509ReqObj *
36#define crypto_X509Req_New_PROTO (X509_REQ *, int)
37
38#define crypto_X509Store_New_NUM 2
39#define crypto_X509Store_New_RETURN crypto_X509StoreObj *
40#define crypto_X509Store_New_PROTO (X509_STORE *, int)
41
42#define crypto_PKey_New_NUM 3
43#define crypto_PKey_New_RETURN crypto_PKeyObj *
44#define crypto_PKey_New_PROTO (EVP_PKEY *, int)
45
46#define crypto_X509Name_New_NUM 4
47#define crypto_X509Name_New_RETURN crypto_X509NameObj *
48#define crypto_X509Name_New_PROTO (X509_NAME *, int)
49
50#define crypto_X509Extension_New_NUM 5
51#define crypto_X509Extension_New_RETURN crypto_X509ExtensionObj *
Rick Dean47262da2009-07-08 16:17:17 -050052#define crypto_X509Extension_New_PROTO (char *, int, char *, crypto_X509Obj *, crypto_X509Obj *)
Jean-Paul Calderone897bc252008-02-18 20:50:23 -050053
54#define crypto_PKCS7_New_NUM 6
55#define crypto_PKCS7_New_RETURN crypto_PKCS7Obj *
56#define crypto_PKCS7_New_PROTO (PKCS7 *, int)
57
58#define crypto_NetscapeSPKI_New_NUM 7
59#define crypto_NetscapeSPKI_New_RETURN crypto_NetscapeSPKIObj *
60#define crypto_NetscapeSPKI_New_PROTO (NETSCAPE_SPKI *, int)
61
62#define crypto_API_pointers 8
63
64#ifdef crypto_MODULE
65
66extern crypto_X509_New_RETURN crypto_X509_New crypto_X509_New_PROTO;
67extern crypto_X509Name_New_RETURN crypto_X509Name_New crypto_X509Name_New_PROTO;
68extern crypto_X509Req_New_RETURN crypto_X509Req_New crypto_X509Req_New_PROTO;
69extern crypto_X509Store_New_RETURN crypto_X509Store_New crypto_X509Store_New_PROTO;
70extern crypto_PKey_New_RETURN crypto_PKey_New crypto_PKey_New_PROTO;
71extern crypto_X509Extension_New_RETURN crypto_X509Extension_New crypto_X509Extension_New_PROTO;
72extern crypto_PKCS7_New_RETURN crypto_PKCS7_New crypto_PKCS7_New_PROTO;
73extern crypto_NetscapeSPKI_New_RETURN crypto_NetscapeSPKI_New crypto_NetscapeSPKI_New_PROTO;
74
75#else /* crypto_MODULE */
76
77extern void **crypto_API;
78
79#define crypto_X509_New \
80 (*(crypto_X509_New_RETURN (*)crypto_X509_New_PROTO) crypto_API[crypto_X509_New_NUM])
81#define crypto_X509Name_New \
82 (*(crypto_X509Name_New_RETURN (*)crypto_X509Name_New_PROTO) crypto_API[crypto_X509Name_New_NUM])
83#define crypto_X509Req_New \
84 (*(crypto_X509Req_New_RETURN (*)crypto_X509Req_New_PROTO) crypto_API[crypto_X509Req_New_NUM])
85#define crypto_X509Store_New \
86 (*(crypto_X509Store_New_RETURN (*)crypto_X509Store_New_PROTO) crypto_API[crypto_X509Store_New_NUM])
87#define crypto_PKey_New \
88 (*(crypto_PKey_New_RETURN (*)crypto_PKey_New_PROTO) crypto_API[crypto_PKey_New_NUM])
89#define crypto_X509Extension_New\
90 (*(crypto_X509Extension_New_RETURN (*)crypto_X509Extension_New_PROTO) crypto_API[crypto_X509Extension_New_NUM])
91#define crypto_PKCS7_New \
92 (*(crypto_PKCS7_New_RETURN (*)crypto_PKCS7_New_PROTO) crypto_API[crypto_PKCS7_New_NUM])
93#define crypto_NetscapeSPKI_New \
94 (*(crypto_NetscapeSPKI_New_RETURN (*)crypto_NetscapeSPKI_New_PROTO) crypto_API[crypto_NetscapeSPKI_New_NUM])
95
96#define import_crypto() \
97{ \
98 PyObject *crypto_module = PyImport_ImportModule("OpenSSL.crypto"); \
99 if (crypto_module != NULL) { \
100 PyObject *crypto_dict, *crypto_api_object; \
101 crypto_dict = PyModule_GetDict(crypto_module); \
102 crypto_api_object = PyDict_GetItemString(crypto_dict, "_C_API"); \
Jean-Paul Calderone86ad7112010-05-11 16:08:45 -0400103 if (crypto_api_object && PyCObject_Check(crypto_api_object)) { \
Jean-Paul Calderone897bc252008-02-18 20:50:23 -0500104 crypto_API = (void **)PyCObject_AsVoidPtr(crypto_api_object); \
105 } \
106 } \
107}
108
109#endif /* crypto_MODULE */
110
Jean-Paul Calderone2685e432009-04-01 12:58:26 -0400111/* Define a new type for emitting text. Hopefully these don't collide with
112 * future official OpenSSL constants, but the switch statement of
113 * dump_certificate() will alert us if it matters.
114 */
Rick Dean5b7b6372009-04-01 11:34:06 -0500115#ifndef X509_FILETYPE_TEXT
116#define X509_FILETYPE_TEXT (58)
117#endif
118
Jean-Paul Calderone897bc252008-02-18 20:50:23 -0500119#endif /* PyOpenSSL_CRYPTO_H_ */