⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 crlview.cpp

📁 一个跨平台的CA系统 实现了数字证书的制作、SSL安全通讯、加解密操作等功能
💻 CPP
字号:
/* vi: set sw=4 ts=4: *//* * Copyright (C) 2001 Christian Hohnstaedt. * *  All rights reserved. * * *  Redistribution and use in source and binary forms, with or without  *  modification, are permitted provided that the following conditions are met: * *  - Redistributions of source code must retain the above copyright notice, *    this list of conditions and the following disclaimer. *  - Redistributions in binary form must reproduce the above copyright notice, *    this list of conditions and the following disclaimer in the documentation *    and/or other materials provided with the distribution. *  - Neither the name of the author nor the names of its contributors may be  *    used to endorse or promote products derived from this software without *    specific prior written permission. * * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * * This program links to software with different licenses from: * *	http://www.openssl.org which includes cryptographic software * 	written by Eric Young (eay@cryptsoft.com)" * *	http://www.sleepycat.com * *	http://www.trolltech.com *  * * * http://www.hohnstaedt.de/xca * email: christian@hohnstaedt.de * * $Id: CrlView.cpp,v 1.16 2004/05/25 20:31:40 chris2511 Exp $  * */                           #include "CrlView.h"#include <qpopupmenu.h>#include <qmessagebox.h>#include <qlineedit.h>#include "widgets/CrlDetail.h"#include "widgets/KeyDetail.h"#include "widgets/CertDetail.h"#include "lib/pki_crl.h"#include "widgets/MainWindow.h"#include "widgets/clicklabel.h"CrlView::CrlView(QWidget * parent, const char * name, WFlags f)	:XcaListView(parent, name, f){	addColumn(tr("Internal Name"));	addColumn(tr("Issuer Common Name"));	addColumn(tr("Revoked"));}void CrlView::showCert(QListViewItem *i){	showCert(i->text(0));}					 void CrlView::showCert(QString name){	pki_base *item = MainWindow::certs->getByName(name);	if (!item) return; 	CertDetail *dlg=NULL;	CHECK_DB    try {		dlg = new CertDetail(this,0,true);		dlg->setCert((pki_x509 *)item);		connect( dlg->privKey, SIGNAL( doubleClicked(QString) ), 			this, SLOT( showKey(QString) ));		connect( dlg->signCert, SIGNAL( doubleClicked(QString) ), 			this, SLOT( showCert(QString) ));		dlg->exec();    }    catch (errorEx &err) {	    Error(err);    }	if (dlg)		delete dlg;    return ;}void CrlView::showKey(QString name){	pki_key *key = (pki_key *)MainWindow::keys->getByName(name);	KeyDetail *dlg = NULL;	if (!key) return;	CHECK_DB	try {			dlg = new KeyDetail(this, 0, true, 0 );		dlg->setKey(key);		dlg->exec();	}	catch (errorEx &err) {		Error(err);	}	if (dlg)		delete dlg;}void CrlView::showItem(pki_base *item, bool import){	if (!item) return;    CrlDetail *dlg;	CHECK_DB	try {		dlg = new CrlDetail(this,0,true);		dlg->setCrl((pki_crl *)item);		connect( dlg->certList, SIGNAL( doubleClicked(QListViewItem*) ), 			this, SLOT( showCert(QListViewItem *) ));		connect( dlg->issuerIntName, SIGNAL( doubleClicked(QString) ), 			this, SLOT( showCert(QString) ));				dlg->exec();    }    catch (errorEx &err) {	    Error(err);    }	if (dlg)		delete dlg;		    return;}void CrlView::deleteItem(){	deleteItem_default(tr("The Revocation list"),		tr("is going to be deleted"));}void CrlView::load(){	load_crl l;	load_default(l);}void CrlView::writeCrl_pem(){	store(true);}	void CrlView::writeCrl_der(){	store(false);}		void CrlView::store(bool pem){	pki_crl *crl;	CHECK_DB	try {		crl = (pki_crl *)getSelected();	}	catch (errorEx &err) {		Error(err);		return;	}		if (!crl) return;	QStringList filt;	filt.append("Revocation Lists ( *.crl *.pem)");	filt.append("All Files ( *.* )");	QString s="";	QFileDialog *dlg = new QFileDialog(this,0,true);	dlg->setCaption(tr("Export Certificate revokation list"));	dlg->setFilters(filt);	dlg->setMode( QFileDialog::AnyFile );	dlg->setSelection( (crl->getIntName() + ".crl") );	dlg->setDir(MainWindow::getPath());	if (dlg->exec()) {		s = dlg->selectedFile();		MainWindow::setPath(dlg->dirPath());	}	delete dlg;	if (s.isEmpty()) return;	s=QDir::convertSeparators(s);	try {		crl->writeCrl(s.latin1(), pem);	}	catch (errorEx &err) {		Error(err);	}		}void CrlView::popupMenu(QListViewItem *item, const QPoint &pt, int x) {	QPopupMenu *menu = new QPopupMenu(this);	QPopupMenu *subExport = new QPopupMenu(this);		if (!item) {		menu->insertItem(tr("Import"), this, SLOT(load()));	}	else {		CHECK_DB		menu->insertItem(tr("Rename"), this, SLOT(startRename()));		menu->insertItem(tr("Show Details"), this, SLOT(showItem()));		menu->insertItem(tr("Export"), subExport);		subExport->insertItem(tr("PEM"), this, SLOT(writeCrl_pem()));		subExport->insertItem(tr("DER"), this, SLOT(writeCrl_der()));		menu->insertItem(tr("Delete"), this, SLOT(deleteItem()));	}	menu->exec(pt);	delete menu;	delete subExport;		return;}pki_crl *CrlView::newItem(pki_x509 *cert){	if (!cert) return NULL;	QList<pki_x509> list;	a1time time;	pki_x509 *issuedcert = NULL;	pki_crl *crl = NULL;	CHECK_DB_NULL	x509v3ext e;	X509V3_CTX ext_ctx;	X509V3_set_ctx(&ext_ctx, cert->getCert() , NULL, NULL, NULL, 0);	X509V3_set_ctx_nodb((&ext_ctx));		   	try {			crl = new pki_crl();		crl->createCrl(cert->getIntName(), cert);		list = MainWindow::certs->getIssuedCerts(cert);		if (!list.isEmpty()) {	    	for ( issuedcert = list.first(); 					issuedcert != NULL; issuedcert = list.next() )			{				if (issuedcert->isRevoked() ) {					crl->addRev(issuedcert->getRev());				}			}		}		crl->addV3ext(e.create(NID_authority_key_identifier,			"keyid,issuer", &ext_ctx));		if (cert->hasSubAltName()) {			crl->addV3ext(e.create(NID_issuer_alt_name,				"issuer:copy", &ext_ctx));		}		crl->sign(cert->getRefKey());		crl->setLastUpdate(time.now());		crl->setNextUpdate(time.now(60*60*24*cert->getCrlDays()));		cert->setLastCrl(time);		crl->sign(cert->getRefKey(), EVP_md5());		MainWindow::certs->updatePKI(cert); 		// FIXME: set Last update		db->insert(crl); 		updateView();	}	catch (errorEx &err) {		Error(err);	}	return crl;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -