ksslsession.cc
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
#ifdef HAVE_CONFIG_H
00022
#include <config.h>
00023
#endif
00024
00025
#include <kopenssl.h>
00026
#include <kmdcodec.h>
00027
00028
#include "ksslsession.h"
00029
00030
00031 KSSLSession::KSSLSession() : _session(0L) {
00032 }
00033
00034
00035 KSSLSession::~KSSLSession() {
00036
#ifdef KSSL_HAVE_SSL
00037
if (_session) {
00038
KOpenSSLProxy::self()->
SSL_SESSION_free(static_cast<SSL_SESSION*>(_session));
00039 _session = 0L;
00040 }
00041
#endif
00042
}
00043
00044
00045 QString KSSLSession::toString()
const {
00046
QString rc;
00047
#ifdef KSSL_HAVE_SSL
00048
QByteArray qba;
00049 SSL_SESSION *session = static_cast<SSL_SESSION*>(_session);
00050
unsigned int slen =
KOpenSSLProxy::self()->
i2d_SSL_SESSION(session, 0L);
00051
00052
00053
char *csess =
new char[slen];
00054
char *p = csess;
00055
00056
if (!
KOpenSSLProxy::self()->
i2d_SSL_SESSION(session, (
unsigned char **)&p)) {
00057
delete[] csess;
00058
return QString::null;
00059 }
00060
00061
00062 qba.duplicate(csess, slen);
00063
delete[] csess;
00064 rc = KCodecs::base64Encode(qba);
00065
#endif
00066
return rc;
00067 }
00068
00069
00070 KSSLSession *
KSSLSession::fromString(
const QString& s) {
00071
KSSLSession *session = 0L;
00072
#ifdef KSSL_HAVE_SSL
00073
QByteArray qba, qbb = s.local8Bit().copy();
00074 KCodecs::base64Decode(qbb, qba);
00075
unsigned char *qbap = reinterpret_cast<unsigned char *>(qba.data());
00076 SSL_SESSION *ss = KOSSL::self()->d2i_SSL_SESSION(0L, &qbap, qba.size());
00077
if (ss) {
00078 session =
new KSSLSession;
00079 session->
_session = ss;
00080 }
00081
#endif
00082
return session;
00083 }
00084
00085
This file is part of the documentation for kio Library Version 3.2.3.