ksslx509v3.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 "ksslx509v3.h"
00026 #include <kopenssl.h>
00027 #include <kdebug.h>
00028 
00029 
00030 KSSLX509V3::KSSLX509V3() {
00031     flags = 0;
00032 }
00033 
00034 
00035 KSSLX509V3::~KSSLX509V3() {
00036 }
00037 
00038 
00039 
00040 
00041 
00042 
00043 bool KSSLX509V3::certTypeCA() {
00044 #ifdef KSSL_HAVE_SSL
00045     
00046     return (flags & (65471L << 16)) ? true : false;
00047 #endif
00048     return false;
00049 }
00050 
00051 
00052 bool KSSLX509V3::certTypeSSLCA() {
00053 #ifdef KSSL_HAVE_SSL
00054     return (flags & ((1 << (16+X509_PURPOSE_NS_SSL_SERVER-1))|
00055                          (1 << (16+X509_PURPOSE_SSL_SERVER-1))|
00056                          (1 << (16+X509_PURPOSE_SSL_CLIENT-1)))) ? true : 
00057         (false || ((1 << (16+X509_PURPOSE_ANY-1)) &&
00058                (certTypeSSLServer() ||
00059                 certTypeSSLClient() ||
00060                 certTypeNSSSLServer())));
00061 #endif
00062     return false;
00063 }
00064 
00065 
00066 bool KSSLX509V3::certTypeEmailCA() {
00067 #ifdef KSSL_HAVE_SSL
00068     return (flags & ((1 << (16+X509_PURPOSE_SMIME_ENCRYPT-1))|
00069                          (1 << (16+X509_PURPOSE_SMIME_SIGN-1)))) ? true : 
00070         (false || ((1 << (16+X509_PURPOSE_ANY-1)) &&
00071                certTypeSMIME()));
00072 #endif
00073     return false;
00074 }
00075 
00076 
00077 bool KSSLX509V3::certTypeCodeCA() {
00078 #ifdef KSSL_HAVE_SSL
00079     return (flags & (1 << (16+X509_PURPOSE_ANY-1))) ? true : false;
00080 #endif
00081     return false;
00082 }
00083 
00084 
00085 bool KSSLX509V3::certTypeSSLClient() {
00086 #ifdef KSSL_HAVE_SSL
00087     return (flags & (1 << (X509_PURPOSE_SSL_CLIENT-1))) ? true : false;
00088 #endif
00089     return false;
00090 }
00091 
00092 
00093 bool KSSLX509V3::certTypeSSLServer() {
00094 #ifdef KSSL_HAVE_SSL
00095     return (flags & (1 << (X509_PURPOSE_SSL_SERVER-1))) ? true : false;
00096 #endif
00097     return false;
00098 }
00099 
00100 
00101 bool KSSLX509V3::certTypeNSSSLServer() {
00102 #ifdef KSSL_HAVE_SSL
00103     return (flags & (1 << (X509_PURPOSE_NS_SSL_SERVER-1))) ? true : false;
00104 #endif
00105     return false;
00106 }
00107 
00108 
00109 bool KSSLX509V3::certTypeSMIME() {
00110 #ifdef KSSL_HAVE_SSL
00111     return certTypeSMIMEEncrypt()||certTypeSMIMESign();
00112 #endif
00113     return false;
00114 }
00115 
00116 
00117 bool KSSLX509V3::certTypeSMIMEEncrypt() {
00118 #ifdef KSSL_HAVE_SSL
00119     return (flags & (1 << (X509_PURPOSE_SMIME_ENCRYPT-1))) ? true : false;
00120 #endif
00121     return false;
00122 }
00123 
00124 
00125 bool KSSLX509V3::certTypeSMIMESign() {
00126 #ifdef KSSL_HAVE_SSL
00127     return (flags & (1 << (X509_PURPOSE_SMIME_SIGN-1))) ? true : false;
00128 #endif
00129     return false;
00130 }
00131 
00132 
00133 bool KSSLX509V3::certTypeCRLSign() {
00134 #ifdef KSSL_HAVE_SSL
00135     return (flags & (1 << (X509_PURPOSE_CRL_SIGN-1))) ? true : false;
00136 #endif
00137     return false;
00138 }
00139 
00140 
00141 
00142 
00143 
 
This file is part of the documentation for kio Library Version 3.2.0.