My favorites | Sign in
Project Home Downloads Source
Checkout   Browse   Changes    
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
#ifndef __Web_SSL__
#define __Web_SSL__

#ifndef flagNOSSL

#include <Web/Web.h>

#include <openssl/ssl.h>
#include <openssl/conf.h>
#include <openssl/err.h>

NAMESPACE_UPP

void *SSLAlloc(size_t size);
void SSLFree(void *ptr);
void *SSLRealloc(void *ptr, size_t size);

String SSLGetLastError();
String SSLToString(X509_NAME *name);
String ASN1ToString(ASN1_STRING *time);
Date ASN1ToDate(ASN1_STRING *time);

//void SSLInit();

class SSLBuffer
{
public:
SSLBuffer(BUF_MEM *m = NULL) : buf_mem(m) {}
~SSLBuffer() { Clear(); }

bool IsEmpty() const { return !buf_mem; }

bool Set(BUF_MEM *b) { Clear(); return !!(buf_mem = b); }
bool Create() { return Set(BUF_MEM_new()); }
void Clear() { if(buf_mem) { BUF_MEM_free(buf_mem); buf_mem = NULL; } }
BUF_MEM *Detach() { BUF_MEM *b = buf_mem; buf_mem = NULL; return b; }

bool Grow(int length);

String Get() const;
bool Set(String d);

operator BUF_MEM * () const { return buf_mem; }

private:
BUF_MEM *buf_mem;
};

class SSLStream
{
public:
SSLStream(BIO *b = NULL) : bio(b) {}
~SSLStream() { Clear(); }

bool IsEmpty() const { return !bio; }

bool Set(BIO *b) { Clear(); return !!(bio = b); }
bool Create(BIO_METHOD *meth) { return Set(BIO_new(meth)); }
void Clear() { if(bio) { BIO_free(bio); bio = NULL; } }

bool OpenBuffer(const char *data, int length);
bool CreateBuffer();
String GetResult() const;

operator BIO * () const { return bio; }

private:
BIO *bio;
};

class SSLKey
{
public:
SSLKey(EVP_PKEY *k = NULL) : key(k) {}
~SSLKey() { Clear(); }

bool IsEmpty() const { return !key; }

bool Set(EVP_PKEY *k) { Clear(); return !!(key = k); }
void Clear() { if(key) { EVP_PKEY_free(key); key = NULL; } }
EVP_PKEY *Detach() { EVP_PKEY *k = key; key = NULL; return k; }

operator EVP_PKEY * () const { return key; }

bool Load(String data);

private:
EVP_PKEY *key;
};

class SSLCertificate
{
public:
SSLCertificate(X509 *c = NULL) : cert(c) {}
~SSLCertificate() { Clear(); }

bool IsEmpty() const { return !cert; }

bool Set(X509 *c) { Clear(); return !!(cert = c); }
bool Create() { return Set(X509_new()); }
void Clear() { if(cert) { X509_free(cert); cert = NULL; } }
X509 *Detach() { X509 *c = cert; cert = NULL; return c; }

bool Load(String data, bool asn1 = false);
String Save(bool asn1 = false) const;

String GetSubjectName() const;
String GetIssuerName() const;
Date GetNotBefore() const;
Date GetNotAfter() const;
int GetVersion() const;
String GetSerialNumber() const;
// String GetSignatureType() const;
// String GetPublicKey() const;
// String GetAuthority() const;
// String GetHashType() const;
// String GetHash() const;

operator X509 * () const { return cert; }

private:
X509 *cert;
};

class SSLContext
{
public:
SSLContext(SSL_CTX *c = NULL);
~SSLContext() { Clear(); }

bool IsEmpty() const { return !ssl_ctx; }

bool Set(SSL_CTX *c) { Clear(); return !!(ssl_ctx = c); }
bool Create(SSL_METHOD *meth) { return Set(SSL_CTX_new(meth)); }
void Clear() { if(ssl_ctx) { SSL_CTX_free(ssl_ctx); ssl_ctx = NULL; } }
SSL_CTX *Detach() { SSL_CTX *c = ssl_ctx; ssl_ctx = NULL; return c; }

operator SSL_CTX * () const { return ssl_ctx; }

bool CipherList(const char *list);
bool UseCertificate(String certificate, String private_key, bool cert_asn1 = false);
void VerifyPeer(bool verify = true, int depth = 2);

private:
SSL_CTX *ssl_ctx;
};

bool SSLServerSocket(Socket& socket, SSLContext& ssl_context, int port, bool nodelay = true, int listen_count = 5, bool is_blocking = true);
bool SSLClientSocket(Socket& socket, SSLContext& ssl_context, const char *host, int port,
bool nodelay = true, dword *my_addr = NULL, int timeout = DEFAULT_CONNECT_TIMEOUT,
bool is_blocking = true);


bool SSLClientSocketUnsecured(Socket& socket, SSLContext& ssl_context, const char *host, int port,
bool nodelay = true, dword *my_addr = NULL, int timeout = DEFAULT_CONNECT_TIMEOUT,
bool is_blocking = true);
bool SSLSecureSocket(Socket& socket);

static const int SOCKKIND_SSL = 1; // GetKind() for SSL socket

inline String SSLInfoCipher() { return "SSL_CIPHER"; } // String
inline String SSLInfoCertAvail() { return "SSL_CERT_AVAIL"; } // bool
inline String SSLInfoCertVerified() { return "SSL_CERT_VERIFIED"; } // bool
inline String SSLInfoCertSubjectName() { return "SSL_CERT_SUBJECT_NAME"; } // String
inline String SSLInfoCertIssuerName() { return "SSL_CERT_ISSUER_NAME"; } // String
inline String SSLInfoCertNotBefore() { return "SSL_CERT_NOT_BEFORE"; } // Date
inline String SSLInfoCertNotAfter() { return "SSL_CERT_NOT_AFTER"; } // Date
inline String SSLInfoCertVersion() { return "SSL_CERT_VERSION"; } // int
inline String SSLInfoCertSerialNumber() { return "SSL_CERT_SERIAL_NUMBER"; } // String

class HttpsClient : public HttpClient {
public:
HttpsClient();

void Secure(bool s) { secure = s; }

virtual bool CreateClientSocket();
virtual bool IsSecure();

public:
One<SSLContext> ssl_context;

bool secure;

enum { DEFAULT_HTTPS_PORT = 443 };

private:
typedef HttpsClient CLASSNAME;

bool ProxyConnect();
};

END_UPP_NAMESPACE

#endif//flagNOSSL

#endif//__Web_SSL__

Change log

r4361 by cxl on Jan 5, 2012   Diff
*Web/SSL: HttpsClient now correctly uses
CONNECT for proxy
Go to: 
Project members, sign in to write a code review

Older revisions

r3553 by rylek on Jun 22, 2011   Diff
*Web: bug fix - default HTTPS port
number
*Web: added ugly hack to get rid of
SSL memory leaks
r2042 by rylek on Feb 9, 2010   Diff
First version of HttpsClient (using
SSL)
r281 by mdelfede on Jun 7, 2008   Diff
changed svn layout
All revisions of this file

File info

Size: 6082 bytes, 197 lines

File properties

svn:eol-style
native
Powered by Google Project Hosting