436 lines
14 KiB
C++
436 lines
14 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Microsoft Windows
|
|
// Copyright (C) Microsoft Corporation, 2000-2001.
|
|
//
|
|
// File: TemplateV2SubjectNamePropertyPage.cpp
|
|
//
|
|
// Contents: Implementation of CTemplateV2SubjectNamePropertyPage
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
// TemplateV2SubjectNamePropertyPage.cpp : implementation file
|
|
//
|
|
|
|
#include "stdafx.h"
|
|
#include "TemplateV2SubjectNamePropertyPage.h"
|
|
|
|
#ifdef _DEBUG
|
|
#define new DEBUG_NEW
|
|
#undef THIS_FILE
|
|
static char THIS_FILE[] = __FILE__;
|
|
#endif
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CTemplateV2SubjectNamePropertyPage property page
|
|
|
|
CTemplateV2SubjectNamePropertyPage::CTemplateV2SubjectNamePropertyPage(
|
|
CCertTemplate& rCertTemplate, bool& rbIsDirty, bool bIsComputerOrDC)
|
|
: CHelpPropertyPage(CTemplateV2SubjectNamePropertyPage::IDD),
|
|
m_rCertTemplate (rCertTemplate),
|
|
m_rbIsDirty (rbIsDirty),
|
|
m_bIsComputerOrDC (bIsComputerOrDC)
|
|
{
|
|
//{{AFX_DATA_INIT(CTemplateV2SubjectNamePropertyPage)
|
|
// NOTE: the ClassWizard will add member initialization here
|
|
//}}AFX_DATA_INIT
|
|
m_rCertTemplate.AddRef ();
|
|
}
|
|
|
|
CTemplateV2SubjectNamePropertyPage::~CTemplateV2SubjectNamePropertyPage()
|
|
{
|
|
m_rCertTemplate.Release ();
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::DoDataExchange(CDataExchange* pDX)
|
|
{
|
|
CHelpPropertyPage::DoDataExchange(pDX);
|
|
//{{AFX_DATA_MAP(CTemplateV2SubjectNamePropertyPage)
|
|
DDX_Control(pDX, IDC_SUBJECT_NAME_NAME_COMBO, m_nameCombo);
|
|
//}}AFX_DATA_MAP
|
|
}
|
|
|
|
|
|
BEGIN_MESSAGE_MAP(CTemplateV2SubjectNamePropertyPage, CHelpPropertyPage)
|
|
//{{AFX_MSG_MAP(CTemplateV2SubjectNamePropertyPage)
|
|
ON_BN_CLICKED(IDC_SUBJECT_AND_SUBJECT_ALT_NAME, OnSubjectAndSubjectAltName)
|
|
ON_CBN_SELCHANGE(IDC_SUBJECT_NAME_NAME_COMBO, OnSelchangeSubjectNameNameCombo)
|
|
ON_BN_CLICKED(IDC_SUBJECT_NAME_BUILT_BY_CA, OnSubjectNameBuiltByCa)
|
|
ON_BN_CLICKED(IDC_SUBJECT_NAME_SUPPLIED_IN_REQUEST, OnSubjectNameSuppliedInRequest)
|
|
ON_BN_CLICKED(IDC_DNS_NAME, OnDnsName)
|
|
ON_BN_CLICKED(IDC_EMAIL_IN_ALT, OnEmailInAlt)
|
|
ON_BN_CLICKED(IDC_EMAIL_IN_SUB, OnEmailInSub)
|
|
ON_BN_CLICKED(IDC_SPN, OnSpn)
|
|
ON_BN_CLICKED(IDC_UPN, OnUpn)
|
|
ON_WM_KILLFOCUS()
|
|
//}}AFX_MSG_MAP
|
|
END_MESSAGE_MAP()
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
// CTemplateV2SubjectNamePropertyPage message handlers
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnSubjectAndSubjectAltName()
|
|
{
|
|
EnableControls ();
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::EnableControls()
|
|
{
|
|
BOOL bEnable = FALSE;
|
|
|
|
|
|
if ( m_rCertTemplate.ReadOnly () )
|
|
{
|
|
bEnable = FALSE;
|
|
GetDlgItem (IDC_SUBJECT_NAME_SUPPLIED_IN_REQUEST)->EnableWindow (FALSE);
|
|
GetDlgItem (IDC_SUBJECT_NAME_BUILT_BY_CA)->EnableWindow (FALSE);
|
|
}
|
|
else if ( BST_CHECKED == SendDlgItemMessage (IDC_SUBJECT_NAME_BUILT_BY_CA, BM_GETCHECK) )
|
|
bEnable = TRUE;
|
|
|
|
GetDlgItem (IDC_SUBJECT_NAME_NAME_COMBO)->EnableWindow (bEnable);
|
|
GetDlgItem (IDC_SUBJECT_NAME_NAME_LABEL)->EnableWindow (bEnable);
|
|
GetDlgItem (IDC_EMAIL_IN_ALT)->EnableWindow (bEnable);
|
|
GetDlgItem (IDC_DNS_NAME)->EnableWindow (bEnable); // removed for bug 253823 "&& !m_bIsComputerOrDC);"
|
|
GetDlgItem (IDC_UPN)->EnableWindow (bEnable);
|
|
GetDlgItem (IDC_SPN)->EnableWindow (bEnable);
|
|
|
|
BOOL bEnableEmailInSub = FALSE;
|
|
if ( bEnable )
|
|
{
|
|
int nSel = m_nameCombo.GetCurSel ();
|
|
if ( nSel >= 0 )
|
|
{
|
|
if ( NAME_TYPE_NONE != m_nameCombo.GetItemData (nSel) )
|
|
bEnableEmailInSub = TRUE;
|
|
}
|
|
}
|
|
|
|
GetDlgItem (IDC_EMAIL_IN_SUB)->EnableWindow (bEnableEmailInSub);
|
|
if ( !bEnableEmailInSub )
|
|
SendDlgItemMessage (IDC_EMAIL_IN_SUB, BM_SETCHECK, BST_UNCHECKED);
|
|
}
|
|
|
|
|
|
BOOL CTemplateV2SubjectNamePropertyPage::OnInitDialog()
|
|
{
|
|
CHelpPropertyPage::OnInitDialog ();
|
|
|
|
// Initialize Combo Box
|
|
CString text;
|
|
|
|
VERIFY (text.LoadString (IDS_SUBJECT_NAME_NONE));
|
|
int nIndex = m_nameCombo.AddString (text);
|
|
if ( nIndex >= 0 )
|
|
{
|
|
m_nameCombo.SetCurSel (nIndex); // set by default
|
|
m_nameCombo.SetItemData (nIndex, (DWORD_PTR) NAME_TYPE_NONE);
|
|
}
|
|
|
|
VERIFY (text.LoadString (IDS_FULL_DN));
|
|
nIndex = m_nameCombo.AddString (text);
|
|
if ( nIndex >= 0 )
|
|
{
|
|
m_nameCombo.SetItemData (nIndex, (DWORD_PTR) NAME_TYPE_FULL_DN);
|
|
if ( m_rCertTemplate.SubjectNameMustBeFullDN () )
|
|
m_nameCombo.SetCurSel (nIndex);
|
|
}
|
|
|
|
VERIFY (text.LoadString (IDS_CN_ONLY));
|
|
nIndex = m_nameCombo.AddString (text);
|
|
if ( nIndex >= 0 )
|
|
{
|
|
m_nameCombo.SetItemData (nIndex, (DWORD_PTR) NAME_TYPE_CN_ONLY);
|
|
if ( m_rCertTemplate.SubjectNameMustBeCN () )
|
|
m_nameCombo.SetCurSel (nIndex);
|
|
}
|
|
|
|
// Initialize Radio buttons
|
|
if ( m_rCertTemplate.RequireSubjectInRequest () )
|
|
SendDlgItemMessage (IDC_SUBJECT_NAME_SUPPLIED_IN_REQUEST, BM_SETCHECK, BST_CHECKED);
|
|
else
|
|
SendDlgItemMessage (IDC_SUBJECT_NAME_BUILT_BY_CA, BM_SETCHECK, BST_CHECKED);
|
|
|
|
// Initialize Check boxes
|
|
if ( m_rCertTemplate.SubjectNameIncludesEMail () )
|
|
SendDlgItemMessage (IDC_EMAIL_IN_SUB, BM_SETCHECK, BST_CHECKED);
|
|
|
|
if ( m_rCertTemplate.AltNameIncludesDNS () )
|
|
SendDlgItemMessage (IDC_DNS_NAME, BM_SETCHECK, BST_CHECKED);
|
|
|
|
if ( m_rCertTemplate.AltNameIncludesEMail () )
|
|
SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_SETCHECK, BST_CHECKED);
|
|
|
|
if ( m_rCertTemplate.AltNameIncludesUPN () )
|
|
SendDlgItemMessage (IDC_UPN, BM_SETCHECK, BST_CHECKED);
|
|
|
|
if ( m_rCertTemplate.AltNameIncludesSPN () )
|
|
SendDlgItemMessage (IDC_SPN, BM_SETCHECK, BST_CHECKED);
|
|
|
|
EnableControls ();
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::SetSettingsForNameTypeNone ()
|
|
{
|
|
m_rCertTemplate.SubjectNameMustBeCN (false);
|
|
m_rCertTemplate.SubjectNameMustBeFullDN (false);
|
|
int nCntChecked = 0;
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_DNS_NAME, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_UPN, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_SPN, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
|
|
if ( 0 == nCntChecked )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesUPN (true);
|
|
SendDlgItemMessage (IDC_UPN, BM_SETCHECK, BST_CHECKED);
|
|
}
|
|
|
|
// NTRAID# 313588 CertTMPL: If subject name format = none,
|
|
// sub alt name should be marked as critical for D.C.A. cert
|
|
// template.
|
|
m_rCertTemplate.ModifyCriticalExtensions (szOID_SUBJECT_ALT_NAME, true);
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnSelchangeSubjectNameNameCombo()
|
|
{
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
|
|
int nSel = m_nameCombo.GetCurSel ();
|
|
if ( nSel >= 0 )
|
|
{
|
|
switch (m_nameCombo.GetItemData (nSel) )
|
|
{
|
|
case NAME_TYPE_NONE:
|
|
SetSettingsForNameTypeNone ();
|
|
break;
|
|
|
|
case NAME_TYPE_FULL_DN:
|
|
m_rCertTemplate.SubjectNameMustBeCN (false);
|
|
m_rCertTemplate.SubjectNameMustBeFullDN (true);
|
|
// NTRAID# 313588 CertTMPL: If subject name format = none,
|
|
// sub alt name should be marked as critical for D.C.A. cert
|
|
// template.
|
|
m_rCertTemplate.ModifyCriticalExtensions (szOID_SUBJECT_ALT_NAME,
|
|
false);
|
|
break;
|
|
|
|
case NAME_TYPE_CN_ONLY:
|
|
m_rCertTemplate.SubjectNameMustBeCN (true);
|
|
m_rCertTemplate.SubjectNameMustBeFullDN (false);
|
|
// NTRAID# 313588 CertTMPL: If subject name format = none,
|
|
// sub alt name should be marked as critical for D.C.A. cert
|
|
// template.
|
|
m_rCertTemplate.ModifyCriticalExtensions (szOID_SUBJECT_ALT_NAME,
|
|
false);
|
|
break;
|
|
|
|
default:
|
|
ASSERT (0);
|
|
break;
|
|
}
|
|
}
|
|
|
|
EnableControls ();
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnSubjectNameBuiltByCa()
|
|
{
|
|
SetModified ();
|
|
SendDlgItemMessage (IDC_SUBJECT_NAME_SUPPLIED_IN_REQUEST, BM_SETCHECK, BST_UNCHECKED);
|
|
m_rbIsDirty = true;
|
|
|
|
m_rCertTemplate.RequireSubjectInRequest (false);
|
|
|
|
EnableControls ();
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnSubjectNameSuppliedInRequest()
|
|
{
|
|
SetModified ();
|
|
SendDlgItemMessage (IDC_SUBJECT_NAME_BUILT_BY_CA, BM_SETCHECK, BST_UNCHECKED);
|
|
m_rbIsDirty = true;
|
|
m_rCertTemplate.RequireSubjectInRequest (true);
|
|
|
|
// Clear all "built by CA" settings
|
|
int nCnt = m_nameCombo.GetCount ();
|
|
for (int nIndex = 0; nIndex < nCnt; nIndex++)
|
|
{
|
|
if ( NAME_TYPE_NONE == m_nameCombo.GetItemData (nIndex) )
|
|
{
|
|
m_nameCombo.SetCurSel (nIndex);
|
|
break;
|
|
}
|
|
}
|
|
SetSettingsForNameTypeNone ();
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_SUB, BM_GETCHECK) )
|
|
{
|
|
SendDlgItemMessage (IDC_EMAIL_IN_SUB, BM_SETCHECK, BST_UNCHECKED);
|
|
m_rCertTemplate.SubjectNameIncludesEMail (false);
|
|
}
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_GETCHECK) &&
|
|
CanUncheckLastSetting (IDC_EMAIL_IN_ALT) )
|
|
{
|
|
SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_SETCHECK, BST_UNCHECKED);
|
|
m_rCertTemplate.AltNameIncludesEMail (false);
|
|
}
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_DNS_NAME, BM_GETCHECK) &&
|
|
CanUncheckLastSetting (IDC_DNS_NAME) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesDNS (false);
|
|
SendDlgItemMessage (IDC_DNS_NAME, BM_SETCHECK, BST_UNCHECKED);
|
|
}
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_UPN, BM_GETCHECK) &&
|
|
CanUncheckLastSetting (IDC_UPN) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesUPN (false);
|
|
SendDlgItemMessage (IDC_UPN, BM_SETCHECK, BST_UNCHECKED);
|
|
}
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_SPN, BM_GETCHECK) &&
|
|
CanUncheckLastSetting (IDC_SPN) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesSPN (false);
|
|
SendDlgItemMessage (IDC_SPN, BM_SETCHECK, BST_UNCHECKED);
|
|
}
|
|
|
|
EnableControls ();
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnDnsName()
|
|
{
|
|
if ( CanUncheckLastSetting (IDC_DNS_NAME) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesDNS (
|
|
BST_CHECKED == SendDlgItemMessage (IDC_DNS_NAME, BM_GETCHECK));
|
|
}
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnEmailInAlt()
|
|
{
|
|
if ( CanUncheckLastSetting (IDC_EMAIL_IN_ALT) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesEMail (
|
|
BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_GETCHECK));
|
|
}
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnEmailInSub()
|
|
{
|
|
m_rCertTemplate.SubjectNameIncludesEMail (
|
|
BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_SUB, BM_GETCHECK));
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnSpn()
|
|
{
|
|
if ( CanUncheckLastSetting (IDC_SPN) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesSPN (
|
|
BST_CHECKED == SendDlgItemMessage (IDC_SPN, BM_GETCHECK));
|
|
}
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::OnUpn()
|
|
{
|
|
if ( CanUncheckLastSetting (IDC_UPN) )
|
|
{
|
|
m_rCertTemplate.AltNameIncludesUPN (
|
|
BST_CHECKED == SendDlgItemMessage (IDC_UPN, BM_GETCHECK));
|
|
}
|
|
SetModified ();
|
|
m_rbIsDirty = true;
|
|
}
|
|
|
|
|
|
bool CTemplateV2SubjectNamePropertyPage::CanUncheckLastSetting(int ctrlID)
|
|
{
|
|
bool bResult = true;
|
|
|
|
// If request is to be built by CA and "none" is selected for subject name,
|
|
// ensure that at least one of the alt-name options is checked
|
|
// If the control in question is now unchecked, verify that at least
|
|
// one other is checked
|
|
if ( BST_UNCHECKED == SendDlgItemMessage (ctrlID, BM_GETCHECK) )
|
|
{
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_SUBJECT_NAME_BUILT_BY_CA, BM_GETCHECK) )
|
|
{
|
|
int nSel = m_nameCombo.GetCurSel ();
|
|
if ( nSel >= 0 )
|
|
{
|
|
if ( NAME_TYPE_NONE == m_nameCombo.GetItemData (nSel) )
|
|
{
|
|
int nCntChecked = 0;
|
|
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_EMAIL_IN_ALT, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_DNS_NAME, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_UPN, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
if ( BST_CHECKED == SendDlgItemMessage (IDC_SPN, BM_GETCHECK) )
|
|
nCntChecked++;
|
|
|
|
if ( 0 == nCntChecked )
|
|
{
|
|
CString text;
|
|
CString caption;
|
|
CThemeContextActivator activator;
|
|
|
|
VERIFY (caption.LoadString (IDS_CERTTMPL));
|
|
VERIFY (text.LoadString (IDS_AT_LEAST_1_NAME_OPTION_MUST_BE_CHECKED));
|
|
|
|
MessageBox (text, caption, MB_OK);
|
|
|
|
bResult = false;
|
|
SendDlgItemMessage (ctrlID, BM_SETCHECK, BST_CHECKED);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return bResult;
|
|
}
|
|
|
|
void CTemplateV2SubjectNamePropertyPage::DoContextHelp (HWND hWndControl)
|
|
{
|
|
_TRACE(1, L"Entering CTemplateV2SubjectNamePropertyPage::DoContextHelp\n");
|
|
|
|
switch (::GetDlgCtrlID (hWndControl))
|
|
{
|
|
case IDC_STATIC:
|
|
break;
|
|
|
|
default:
|
|
// Display context help for a control
|
|
if ( !::WinHelp (
|
|
hWndControl,
|
|
GetContextHelpFile (),
|
|
HELP_WM_HELP,
|
|
(DWORD_PTR) g_aHelpIDs_IDD_TEMPLATE_V2_SUBJECT_NAME) )
|
|
{
|
|
_TRACE(0, L"WinHelp () failed: 0x%x\n", GetLastError ());
|
|
}
|
|
break;
|
|
}
|
|
_TRACE(-1, L"Leaving CTemplateV2SubjectNamePropertyPage::DoContextHelp\n");
|
|
} |