00001 /*************************************************************************** 00002 * Copyright (C) 2007 by Rick L. Vinyard, Jr. * 00003 * rvinyard@cs.nmsu.edu * 00004 * * 00005 * This file is part of the conexus library. * 00006 * * 00007 * The conexus library is free software; you can redistribute it and/or * 00008 * modify it under the terms of the GNU General Public License * 00009 * version 3 as published by the Free Software Foundation. * 00010 * * 00011 * The conexus library is distributed in the hope that it will be * 00012 * useful, but WITHOUT ANY WARRANTY; without even the implied warranty * 00013 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00014 * General Public License for more details. * 00015 * * 00016 * You should have received a copy of the GNU General Public License * 00017 * along with this software. If not see <http://www.gnu.org/licenses/>. * 00018 ***************************************************************************/ 00019 #ifndef CONEXUSNSSCERTIFICATEDB_H 00020 #define CONEXUSNSSCERTIFICATEDB_H 00021 00022 #include <conexus/pointer.h> 00023 #include <conexus-nss/enums.h> 00024 #include <conexus-nss/certificate.h> 00025 #include <conexus-nss/certificatenicknames.h> 00026 00027 namespace Conexus 00028 { 00029 00030 namespace NSS 00031 { 00032 00036 class CertificateDB 00037 { 00038 public: 00039 typedef ConexusPointer<CertificateDB> pointer; 00040 00041 protected: 00042 CertificateDB(CERTCertDBHandle* cobj=NULL); 00043 00044 public: 00045 00046 static pointer create(CERTCertDBHandle* cobj); 00047 00049 static pointer create(); 00050 00051 ~CertificateDB(); 00052 00053 // TODO rethink how wincx should be handled 00054 bool verify_certificate_now( Certificate::pointer cert, bool check_sig, CERT_USAGE usage, void* wincx ); 00055 00056 Certificate::pointer find_certificate_by_name( SECItem* name ); 00057 00058 // TODO rethink how wincx should be handled 00059 CertificateNicknames::pointer get_certificate_nicknames( NICKNAMES what, void* wincx ); 00060 00061 operator bool(); 00062 00063 void set_cobj( CERTCertDBHandle* cobj ); 00064 00065 CERTCertDBHandle* cobj(); 00066 00067 protected: 00068 CERTCertDBHandle* m_cobj; 00069 }; 00070 00071 } 00072 00073 } 00074 00075 #endif