2020-09-30 16:53:55 +02:00

276 lines
8.4 KiB
C++

//
// SECCERTS.CPP
//
#include "pch.h"
INT_PTR CALLBACK SecurityCertsDlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
switch (uMsg)
{
case WM_INITDIALOG:
CheckRadioButton(hDlg, IDC_NOSC, IDC_IMPORTSC, IDC_NOSC);
DisableDlgItem(hDlg, IDC_MODIFYSC);
CheckRadioButton(hDlg, IDC_NOAUTH, IDC_IMPORTAUTH, IDC_NOAUTH);
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
return TRUE;
case UM_SAVE:
{
TCHAR szSecWorkDir[MAX_PATH];
TCHAR szSiteCertInf[MAX_PATH];
TCHAR szRootStr[MAX_PATH];
TCHAR szCaStr[MAX_PATH];
TCHAR szAuthCodeInf[MAX_PATH];
HCURSOR hOldCur;
BOOL fCheckDirtyOnly = (BOOL) lParam;
hOldCur = SetCursor(LoadCursor(NULL, IDC_WAIT));
// prepare the work dir where the SITECERT.INF and *.STR would temporarily get copied to
PathCombine(szSecWorkDir, g_szWorkDir, TEXT("sitecert.wrk"));
PathCombine(szSiteCertInf, szSecWorkDir, TEXT("sitecert.inf"));
PathCombine(szRootStr, szSecWorkDir, TEXT("root.str"));
PathCombine(szCaStr, szSecWorkDir, TEXT("ca.str"));
if (IsDlgButtonChecked(hDlg, IDC_IMPORTSC) == BST_CHECKED)
{
if (!fCheckDirtyOnly)
{
ImportSiteCert(g_szInsFile, NULL, szSiteCertInf, TRUE);
CheckRadioButton(hDlg, IDC_NOSC, IDC_IMPORTSC, IDC_NOSC);
DisableDlgItem(hDlg, IDC_MODIFYSC);
}
g_fInsDirty = TRUE;
}
// prepare the work dir where the AUTHCODE.INF would temporarily get copied to
PathCombine(szSecWorkDir, g_szWorkDir, TEXT("authcode.wrk"));
PathCombine(szAuthCodeInf, szSecWorkDir, TEXT("authcode.inf"));
if (IsDlgButtonChecked(hDlg, IDC_IMPORTAUTH) == BST_CHECKED)
{
if (!fCheckDirtyOnly)
{
ImportAuthCode(g_szInsFile, NULL, szAuthCodeInf, TRUE);
CheckRadioButton(hDlg, IDC_NOAUTH, IDC_IMPORTAUTH, IDC_NOAUTH);
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
}
g_fInsDirty = TRUE;
}
SetCursor(hOldCur);
}
*((LPBOOL)wParam) = TRUE;
break;
case WM_CLOSE:
DestroyWindow(hDlg);
break;
case WM_COMMAND:
switch (wParam)
{
case IDC_NOSC:
DisableDlgItem(hDlg, IDC_MODIFYSC);
return TRUE;
case IDC_IMPORTSC:
EnableDlgItem(hDlg, IDC_MODIFYSC);
return TRUE;
case IDC_MODIFYSC:
ModifySiteCert(hDlg);
SetFocus(GetDlgItem(hDlg, IDC_MODIFYSC));
break;
case IDC_NOAUTH:
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
return TRUE;
case IDC_IMPORTAUTH:
EnableDlgItem(hDlg, IDC_MODIFYAUTH);
return TRUE;
case IDC_MODIFYAUTH:
ModifyAuthCode(hDlg);
SetFocus(GetDlgItem(hDlg, IDC_MODIFYAUTH));
return TRUE;
}
break;
}
return FALSE;
}
HRESULT CertsFinalCopy(LPCTSTR pcszDestDir, DWORD dwFlags, LPDWORD pdwCabState)
{
TCHAR szFrom[MAX_PATH];
if ((HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL) || HasFlag(dwFlags, PM_COPY))
{
TCHAR szFile[MAX_PATH];
// move sitecert.inf, *.str and *.dis to pcszDestDir
PathCombine(szFrom, g_szWorkDir, TEXT("sitecert.wrk"));
PathCombine(szFile, szFrom, TEXT("sitecert.inf"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
PathCombine(szFile, szFrom, TEXT("root.str"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
PathCombine(szFile, szFrom, TEXT("root.dis"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
PathCombine(szFile, szFrom, TEXT("ca.str"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
// move authcode.inf to pcszDestDir
PathCombine(szFrom, g_szWorkDir, TEXT("authcode.wrk"));
PathCombine(szFile, szFrom, TEXT("authcode.inf"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
}
// blow away the work dirs
if (HasFlag(dwFlags, PM_CLEAR))
{
PathCombine(szFrom, g_szWorkDir, TEXT("sitecert.wrk"));
PathRemovePath(szFrom);
PathCombine(szFrom, g_szWorkDir, TEXT("authcode.wrk"));
PathRemovePath(szFrom);
}
return S_OK;
}
INT_PTR CALLBACK SecurityAuthDlgProc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
switch (uMsg)
{
case WM_INITDIALOG:
CheckRadioButton(hDlg, IDC_NOAUTH, IDC_IMPORTAUTH, IDC_NOAUTH);
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
HideDlgItem(hDlg, IDC_TPL_TEXT);
HideDlgItem(hDlg, IDC_TPL);
break;
case UM_SAVE:
{ // process authenticode
TCHAR szInf[MAX_PATH];
HCURSOR hOldCur;
BOOL fCheckDirtyOnly = (BOOL) lParam;
hOldCur = SetCursor(LoadCursor(NULL, IDC_WAIT));
PathCombine(szInf, g_szWorkDir, TEXT("authcode.wrk"));
PathAppend(szInf, TEXT("authcode.inf"));
if (IsDlgButtonChecked(hDlg, IDC_IMPORTAUTH) == BST_CHECKED)
{
if (!fCheckDirtyOnly)
{
ImportAuthCode(g_szInsFile, NULL, szInf, TRUE);
CheckRadioButton(hDlg, IDC_NOAUTH, IDC_IMPORTAUTH, IDC_NOAUTH);
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
}
g_fInsDirty = TRUE;
}
else
if (!fCheckDirtyOnly)
ImportAuthCode(g_szInsFile, NULL, szInf, FALSE);
SetCursor(hOldCur);
}
*((LPBOOL)wParam) = TRUE;
break;
case WM_CLOSE:
DestroyWindow(hDlg);
break;
case WM_COMMAND:
if (GET_WM_COMMAND_CMD(wParam, lParam) != BN_CLICKED)
return FALSE;
switch (GET_WM_COMMAND_ID(wParam, lParam))
{
case IDC_NOAUTH:
DisableDlgItem(hDlg, IDC_MODIFYAUTH);
break;
case IDC_IMPORTAUTH:
EnableDlgItem(hDlg, IDC_MODIFYAUTH);
break;
case IDC_MODIFYAUTH:
ModifyAuthCode(hDlg);
break;
default:
return FALSE;
}
break;
default:
return FALSE;
}
return TRUE;
}
HRESULT AuthFinalCopy(LPCTSTR pcszDestDir, DWORD dwFlags, LPDWORD pdwCabState)
{
TCHAR szFrom[MAX_PATH];
if ((HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL) || HasFlag(dwFlags, PM_COPY))
{
TCHAR szFile[MAX_PATH];
// move authcode.inf to pcszDestDir
PathCombine(szFrom, g_szWorkDir, TEXT("authcode.wrk"));
PathCombine(szFile, szFrom, TEXT("authcode.inf"));
if (HasFlag(dwFlags, PM_CHECK) && pdwCabState != NULL && PathFileExists(szFile))
SetFlag(pdwCabState, CAB_TYPE_CONFIG);
if (HasFlag(dwFlags, PM_COPY))
CopyFileToDir(szFile, pcszDestDir);
}
// blow away the work dir
if (HasFlag(dwFlags, PM_CLEAR))
{
PathCombine(szFrom, g_szWorkDir, TEXT("authcode.wrk"));
PathRemovePath(szFrom);
}
return S_OK;
}