377 lines
9.1 KiB
C++
377 lines
9.1 KiB
C++
|
//
|
||
|
// CertContentsPages.cpp
|
||
|
//
|
||
|
#include "stdafx.h"
|
||
|
#include "resource.h"
|
||
|
#include "CertContentsPages.h"
|
||
|
#include "Certificat.h"
|
||
|
#include "CertUtil.h"
|
||
|
|
||
|
#ifdef _DEBUG
|
||
|
#define new DEBUG_NEW
|
||
|
#undef THIS_FILE
|
||
|
static char THIS_FILE[] = __FILE__;
|
||
|
#endif
|
||
|
|
||
|
////////////////////// Local helper functions ////////////////////////
|
||
|
static void
|
||
|
AppendField(CString& str, UINT id, const CString& text)
|
||
|
{
|
||
|
CString strName;
|
||
|
if (!text.IsEmpty())
|
||
|
{
|
||
|
if (strName.LoadString(id))
|
||
|
{
|
||
|
str += strName;
|
||
|
str += _T("\t");
|
||
|
str += text;
|
||
|
str += _T("\r\n");
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static void
|
||
|
FormatCertDescription(CERT_DESCRIPTION& desc, CString& str)
|
||
|
{
|
||
|
AppendField(str, IDS_ISSUED_TO, desc.m_CommonName);
|
||
|
AppendField(str, IDS_ISSUED_BY, desc.m_CAName);
|
||
|
AppendField(str, IDS_EXPIRATION_DATE, desc.m_ExpirationDate);
|
||
|
AppendField(str, IDS_PURPOSE, desc.m_Usage);
|
||
|
AppendField(str, IDS_FRIENDLY_NAME, desc.m_FriendlyName);
|
||
|
AppendField(str, IDS_COUNTRY, desc.m_Country);
|
||
|
AppendField(str, IDS_STATE, desc.m_State);
|
||
|
AppendField(str, IDS_LOCALITY, desc.m_Locality);
|
||
|
AppendField(str, IDS_ORGANIZATION, desc.m_Organization);
|
||
|
AppendField(str, IDS_ORGANIZATION_UNIT, desc.m_OrganizationUnit);
|
||
|
}
|
||
|
|
||
|
#if 0
|
||
|
static void
|
||
|
FormatCertContactInfo(CCertificate * pCert, CString& str)
|
||
|
{
|
||
|
AppendField(str, IDS_CONTACT_NAME, pCert->m_ContactName);
|
||
|
AppendField(str, IDS_CONTACT_ADDRESS, pCert->m_ContactAddress);
|
||
|
CString strPhone = pCert->m_ContactPhone;
|
||
|
if (!pCert->m_ContactPhoneExt.IsEmpty())
|
||
|
{
|
||
|
strPhone += _T("x");
|
||
|
strPhone += pCert->m_ContactPhoneExt;
|
||
|
}
|
||
|
AppendField(str, IDS_CONTACT_PHONE, strPhone);
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
static BOOL
|
||
|
ExtractDescription(CCertificate * pCert, CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
ASSERT(pCert != NULL);
|
||
|
cd.m_CommonName = pCert->m_CommonName;
|
||
|
cd.m_FriendlyName = pCert->m_FriendlyName;
|
||
|
cd.m_Country = pCert->m_Country;
|
||
|
cd.m_State = pCert->m_State;
|
||
|
cd.m_Locality = pCert->m_Locality;
|
||
|
cd.m_Organization = pCert->m_Organization;
|
||
|
cd.m_OrganizationUnit = pCert->m_OrganizationUnit;
|
||
|
return TRUE;
|
||
|
}
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////
|
||
|
// CCertContentsPage base property page
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CCertContentsPage, CIISWizardPage)
|
||
|
|
||
|
CCertContentsPage::CCertContentsPage(UINT id, CCertificate * pCert)
|
||
|
: CIISWizardPage(id, IDS_CERTWIZ, TRUE),
|
||
|
m_pCert(pCert)
|
||
|
{
|
||
|
ASSERT(id != 0);
|
||
|
}
|
||
|
|
||
|
CCertContentsPage::~CCertContentsPage()
|
||
|
{
|
||
|
}
|
||
|
|
||
|
void CCertContentsPage::DoDataExchange(CDataExchange* pDX)
|
||
|
{
|
||
|
CIISWizardPage::DoDataExchange(pDX);
|
||
|
//{{AFX_DATA_MAP(CCertContentsPage)
|
||
|
//}}AFX_DATA_MAP
|
||
|
}
|
||
|
|
||
|
BEGIN_MESSAGE_MAP(CCertContentsPage, CIISWizardPage)
|
||
|
//{{AFX_MSG_MAP(CCertContentsPage)
|
||
|
//}}AFX_MSG_MAP
|
||
|
END_MESSAGE_MAP()
|
||
|
|
||
|
// OnSetActive we format cert contents and put it to edit
|
||
|
// control with predefined ID. We should do it here, because
|
||
|
// if user will get back and reselect certificate, text should
|
||
|
// also be changed
|
||
|
//
|
||
|
BOOL
|
||
|
CCertContentsPage::OnSetActive()
|
||
|
{
|
||
|
CERT_DESCRIPTION cd;
|
||
|
if (CIISWizardPage::OnSetActive())
|
||
|
{
|
||
|
// If page defines GetCertDescription() then it want this
|
||
|
// data to be displayed
|
||
|
if (GetCertDescription(cd))
|
||
|
{
|
||
|
ASSERT(NULL != GetDlgItem(IDC_CERT_CONTENTS));
|
||
|
CString str;
|
||
|
FormatCertDescription(cd, str);
|
||
|
GetDlgItem(IDC_CERT_CONTENTS)->SetWindowText(str);
|
||
|
}
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL CCertContentsPage::OnInitDialog()
|
||
|
{
|
||
|
ASSERT(m_pCert != NULL);
|
||
|
CIISWizardPage::OnInitDialog();
|
||
|
ASSERT(NULL != GetDlgItem(IDC_CERT_CONTENTS));
|
||
|
CEdit * pEdit = (CEdit *)CWnd::FromHandle(GetDlgItem(IDC_CERT_CONTENTS)->m_hWnd);
|
||
|
CRect rcEdit;
|
||
|
pEdit->GetClientRect(&rcEdit);
|
||
|
int baseunitX = LOWORD(GetDialogBaseUnits());
|
||
|
int width_units = MulDiv(rcEdit.Width(), 4, baseunitX);
|
||
|
pEdit->SetTabStops(MulDiv(45, width_units, 100));
|
||
|
return TRUE;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CInstallCertPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CInstallCertPage, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
CInstallCertPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
return GetCertificate()->GetSelectedCertDescription(cd);
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CInstallCertPage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->InstallSelectedCert();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CReplaceCertPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CReplaceCertPage, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
CReplaceCertPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
return GetCertificate()->GetSelectedCertDescription(cd);
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CReplaceCertPage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->InstallSelectedCert();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CInstallKeyPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CInstallKeyPage, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
CInstallKeyPage::OnSetActive()
|
||
|
{
|
||
|
ASSERT(NULL != GetDlgItem(IDC_CERT_CONTENTS));
|
||
|
ASSERT(NULL != GetDlgItem(IDC_FILE_NAME));
|
||
|
if (CCertContentsPage::OnSetActive())
|
||
|
{
|
||
|
CString strPath = GetCertificate()->m_KeyFileName;
|
||
|
CompactPathToWidth(GetDlgItem(IDC_FILE_NAME), strPath);
|
||
|
SetDlgItemText(IDC_FILE_NAME, strPath);
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
CInstallKeyPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
return GetCertificate()->GetKeyCertDescription(cd);
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CInstallKeyPage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->InstallKeyRingCert();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CInstallRespPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CInstallRespPage, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
CInstallRespPage::OnSetActive()
|
||
|
{
|
||
|
ASSERT(NULL != GetDlgItem(IDC_CERT_CONTENTS));
|
||
|
ASSERT(NULL != GetDlgItem(IDC_FILE_NAME));
|
||
|
if (CCertContentsPage::OnSetActive())
|
||
|
{
|
||
|
CString strPath = GetCertificate()->m_RespFileName;
|
||
|
CompactPathToWidth(GetDlgItem(IDC_FILE_NAME), strPath);
|
||
|
SetDlgItemText(IDC_FILE_NAME, strPath);
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
BOOL
|
||
|
CInstallRespPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
return GetCertificate()->GetResponseCertDescription(cd);
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CInstallRespPage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->InstallResponseCert();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CRemoveCertPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CRemoveCertPage, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
CRemoveCertPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
CCertificate * pCert = GetCertificate();
|
||
|
ASSERT(NULL != pCert);
|
||
|
return pCert->GetInstalledCertDescription(cd);
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CRemoveCertPage::OnWizardNext()
|
||
|
{
|
||
|
CCertificate * pCert = GetCertificate();
|
||
|
ASSERT(NULL != pCert);
|
||
|
if ( FAILED(pCert->UninstallCert())
|
||
|
|| FAILED(ShutdownSSL(pCert->m_MachineName, pCert->m_WebSiteInstanceName))
|
||
|
)
|
||
|
GetCertificate()->SetBodyTextID(IDS_REMOVE_CERT_FAILED);
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
////////////////////////////////////////////////////////////////////////////////////////
|
||
|
// CRequestCancelPage
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CRequestCancelPage, CCertContentsPage)
|
||
|
|
||
|
//
|
||
|
// In this case we should get request from the dummy cert in REQUEST store,
|
||
|
// because we dropping request without any connection to response.
|
||
|
//
|
||
|
BOOL
|
||
|
CRequestCancelPage::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
LRESULT
|
||
|
CRequestCancelPage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->CancelRequest();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////
|
||
|
// CRequestToFilePage property page
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(CRequestToFilePage, CCertContentsPage)
|
||
|
|
||
|
// This page prepares and shows contents itself
|
||
|
// We should format contact info first, then description
|
||
|
// default method could do only description
|
||
|
//
|
||
|
BOOL CRequestToFilePage::OnSetActive()
|
||
|
{
|
||
|
if (CCertContentsPage::OnSetActive())
|
||
|
{
|
||
|
ASSERT(GetCertificate() != NULL);
|
||
|
ASSERT(GetDlgItem(IDC_CERT_CONTENTS) != NULL);
|
||
|
ASSERT(GetDlgItem(IDC_FILE_NAME) != NULL);
|
||
|
|
||
|
if (GetCertificate()->GetStatusCode() == CCertificate::REQUEST_RENEW_CERT)
|
||
|
{
|
||
|
GetCertificate()->LoadRenewalData();
|
||
|
}
|
||
|
|
||
|
CString str;
|
||
|
// FormatCertContactInfo(m_pCert, str);
|
||
|
|
||
|
CERT_DESCRIPTION cd;
|
||
|
ExtractDescription(GetCertificate(), cd);
|
||
|
FormatCertDescription(cd, str);
|
||
|
|
||
|
SetDlgItemText(IDC_CERT_CONTENTS, str);
|
||
|
|
||
|
CString strPath = m_pCert->m_ReqFileName;
|
||
|
CompactPathToWidth(GetDlgItem(IDC_FILE_NAME), strPath);
|
||
|
SetDlgItemText(IDC_FILE_NAME, strPath);
|
||
|
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
LRESULT CRequestToFilePage::OnWizardNext()
|
||
|
{
|
||
|
GetCertificate()->PrepareRequest();
|
||
|
return IDD_PAGE_NEXT;
|
||
|
}
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////////////
|
||
|
// COnlineRequestSubmit property page
|
||
|
|
||
|
IMPLEMENT_DYNCREATE(COnlineRequestSubmit, CCertContentsPage)
|
||
|
|
||
|
BOOL
|
||
|
COnlineRequestSubmit::GetCertDescription(CERT_DESCRIPTION& cd)
|
||
|
{
|
||
|
// we have all data in CCertificate
|
||
|
return ExtractDescription(GetCertificate(), cd);
|
||
|
}
|
||
|
|
||
|
LRESULT COnlineRequestSubmit::OnWizardNext()
|
||
|
{
|
||
|
LRESULT id = IDD_PAGE_NEXT;
|
||
|
BeginWaitCursor();
|
||
|
if (GetCertificate()->GetStatusCode() == CCertificate::REQUEST_RENEW_CERT)
|
||
|
GetCertificate()->SubmitRenewalRequest();
|
||
|
else if (m_pCert->GetStatusCode() == CCertificate::REQUEST_NEW_CERT)
|
||
|
GetCertificate()->SubmitRequest();
|
||
|
else
|
||
|
id = 1;
|
||
|
EndWaitCursor();
|
||
|
return id;
|
||
|
}
|
||
|
|
||
|
BOOL COnlineRequestSubmit::OnSetActive()
|
||
|
{
|
||
|
ASSERT(GetCertificate() != NULL);
|
||
|
ASSERT(GetDlgItem(IDC_CA_NAME) != NULL);
|
||
|
if (CCertContentsPage::OnSetActive())
|
||
|
{
|
||
|
SetDlgItemText(IDC_CA_NAME, GetCertificate()->m_ConfigCA);
|
||
|
return TRUE;
|
||
|
}
|
||
|
return FALSE;
|
||
|
}
|