BSOne.SFC/Tocsg.Module/Bs1Flt/tool/toolDlg.cpp

821 lines
22 KiB
C++

// toolDlg.cpp: 구현 파일
//
#include "pch.h"
#include "framework.h"
#include "tool.h"
#include "toolDlg.h"
#include "afxdialogex.h"
#include <string>
Bs1fltControl bs1flt_;
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// 응용 프로그램 정보에 사용되는 CAboutDlg 대화 상자입니다.
class CAboutDlg : public CDialogEx
{
public:
CAboutDlg();
// 대화 상자 데이터입니다.
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_ABOUTBOX };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 지원입니다.
// 구현입니다.
protected:
DECLARE_MESSAGE_MAP()
};
CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX)
{
}
void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
}
BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()
// CtoolDlg 대화 상자
CtoolDlg::CtoolDlg(CWnd* pParent /*=nullptr*/)
: CDialogEx(IDD_TOOL_DIALOG, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}
void CtoolDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
DDX_Control(pDX, IDC_LIST1, listLog_);
DDX_Control(pDX, IDC_EDIT_DEBUG, editDebug_);
}
BEGIN_MESSAGE_MAP(CtoolDlg, CDialogEx)
ON_WM_SYSCOMMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_BUTTON_START, &CtoolDlg::OnBnClickedButtonStart)
ON_BN_CLICKED(IDC_BUTTON_STOP, &CtoolDlg::OnBnClickedButtonStop)
ON_BN_CLICKED(IDC_BUTTON_USB_REMOVAL_SET_POLICY, &CtoolDlg::OnBnClickedButtonSetPolicy)
ON_BN_CLICKED(IDCANCEL, &CtoolDlg::OnBnClickedCancel)
ON_BN_CLICKED(IDC_BUTTON_PROCESS_PROTECT, &CtoolDlg::OnBnClickedButtonProcessProtect)
ON_MESSAGE(WM_UPDATE_LOG_MSG, &CtoolDlg::OnUpdateLog)
ON_BN_CLICKED(IDC_BUTTON_USB_EXCEPTION, &CtoolDlg::OnBnClickedButtonUsbException)
ON_BN_CLICKED(IDC_BUTTON_DEVICE_PROTECT, &CtoolDlg::OnBnClickedButtonDeviceProtect)
ON_BN_CLICKED(IDC_BUTTON2, &CtoolDlg::OnBnClickedButton2)
ON_BN_CLICKED(IDC_BUTTON_SET_USB_HOOK, &CtoolDlg::OnBnClickedButtonSetUsbHook)
ON_BN_CLICKED(IDC_BUTTON_SET_BLUETOOTH_HOOK, &CtoolDlg::OnBnClickedButtonSetBluetoothHook)
ON_BN_CLICKED(IDC_BUTTON_SET_MTP_HOOK, &CtoolDlg::OnBnClickedButtonSetMtpHook)
ON_BN_CLICKED(IDC_BUTTON3, &CtoolDlg::OnBnClickedButton3)
ON_BN_CLICKED(IDC_BUTTON_INIT, &CtoolDlg::OnBnClickedButtonInit)
ON_BN_CLICKED(IDC_BUTTON_OPEN, &CtoolDlg::OnBnClickedButtonOpen)
ON_BN_CLICKED(IDC_BUTTON_FOLDER_SETTING, &CtoolDlg::OnBnClickedButtonFolderSetting)
ON_BN_CLICKED(IDC_BUTTON_REGDIT_SETTING, &CtoolDlg::OnBnClickedButtonRegditSetting)
END_MESSAGE_MAP()
BOOL RegeditMessageMsg(DWORD msg)
{
BOOL bRet = FALSE;
TCHAR szModulePath[MAX_PATH] = { 0, };
typedef BOOL(WINAPI* fn_ChangeWindowmessageFilter)(UINT message, DWORD dwFlag);
fn_ChangeWindowmessageFilter ChangeWindowMsgFilter_ = NULL;
::GetSystemDirectory(szModulePath, MAX_PATH - 1);
_tcscat(szModulePath, _T("\\user32.dll"));
HMODULE h = NULL;
h = ::LoadLibrary(szModulePath);
if (!h)
return FALSE;
ChangeWindowMsgFilter_ = (fn_ChangeWindowmessageFilter)GetProcAddress(h, "ChangeWindowMessageFilter");
if (ChangeWindowMsgFilter_ != NULL)
{
bRet = ChangeWindowMsgFilter_(msg, MSGFLT_ADD);
}
bRet = TRUE;
if (h)
{
FreeLibrary(h);
h = NULL;
}
return bRet;
}
DWORD WINAPI Report(PVOID context)
{
if (context == NULL) return 0;
//CString* pLogString = new CString((WCHAR*)context);
//CWnd* pMainWnd = AfxGetMainWnd();
//if (pMainWnd && pMainWnd->GetSafeHwnd())
//{
// ::PostMessage(pMainWnd->GetSafeHwnd(), WM_UPDATE_LOG_MSG, 0, (LPARAM)pLogString);
//}
//else
//{
// delete pLogString;
//}
CString pLogString = (WCHAR*)context;
OutputDebugStringW(pLogString.GetBuffer(0));
int idx = theApp.dlg.listLog_.AddString(pLogString);
return 0;
}
LRESULT CtoolDlg::OnUpdateLog(WPARAM wParam, LPARAM lParam)
{
// 1. lParam을 다시 CString 포인터로 캐스팅
CString* pLogString = (CString*)lParam;
if (pLogString)
{
// 2. 리스트 컨트롤에 추가 (여기는 UI 쓰레드라 안전함)
// theApp.listLog_ 대신 현재 클래스의 멤버 변수(m_listLog)를 쓰는 것이 일반적입니다.
// 만약 theApp에 있다면 theApp.listLog_.AddString(*pLogString); 도 가능합니다.
// 예: 리스트 박스인 경우
int idx = listLog_.AddString(*pLogString);
listLog_.SetCurSel(idx); // 오토 스크롤
// 3. **중요** 할당했던 메모리 해제
delete pLogString;
}
return 0;
}
// CtoolDlg 메시지 처리기
BOOL CtoolDlg::OnInitDialog()
{
CDialogEx::OnInitDialog();
// 시스템 메뉴에 "정보..." 메뉴 항목을 추가합니다.
// IDM_ABOUTBOX는 시스템 명령 범위에 있어야 합니다.
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != nullptr)
{
BOOL bNameValid;
CString strAboutMenu;
bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
ASSERT(bNameValid);
if (!strAboutMenu.IsEmpty())
{
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
}
}
device_protect_ = FALSE;
// 이 대화 상자의 아이콘을 설정합니다. 응용 프로그램의 주 창이 대화 상자가 아닐 경우에는
// 프레임워크가 이 작업을 자동으로 수행합니다.
SetIcon(m_hIcon, TRUE); // 큰 아이콘을 설정합니다.
SetIcon(m_hIcon, FALSE); // 작은 아이콘을 설정합니다.
// TODO: 여기에 추가 초기화 작업을 추가합니다.
RegeditMessageMsg(WM_COPYDATA);
WCHAR dllpath[MAX_PATH] = { 0, };
WCHAR buffer[MAX_PATH] = { 0, };
DWORD state = 0;
GetModuleFileNameW(NULL, dllpath, ARRAYSIZE(dllpath));
WCHAR* ptr = wcsrchr(dllpath, L'\\');
if (!ptr)
return TRUE;
*ptr = '\0';
s_wcurrent_path_ = dllpath;
state = bs1flt_.Init(s_wcurrent_path_.c_str(), Report);
if(state != ERROR_SUCCESS)
{
MessageBoxW(L"Bs1fltControl 초기화 실패", L"Error", MB_ICONERROR);
}
return TRUE; // 포커스를 컨트롤에 설정하지 않으면 TRUE를 반환합니다.
}
void CtoolDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
}
else
{
CDialogEx::OnSysCommand(nID, lParam);
}
}
// 대화 상자에 최소화 단추를 추가할 경우 아이콘을 그리려면
// 아래 코드가 필요합니다. 문서/뷰 모델을 사용하는 MFC 애플리케이션의 경우에는
// 프레임워크에서 이 작업을 자동으로 수행합니다.
void CtoolDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // 그리기를 위한 디바이스 컨텍스트입니다.
SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
// 클라이언트 사각형에서 아이콘을 가운데에 맞춥니다.
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;
// 아이콘을 그립니다.
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CDialogEx::OnPaint();
}
}
// 사용자가 최소화된 창을 끄는 동안에 커서가 표시되도록 시스템에서
// 이 함수를 호출합니다.
HCURSOR CtoolDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CtoolDlg::OnBnClickedButtonStart()
{
bs1flt_.Bs1FltFolderProtectControl(TRUE);
}
void CtoolDlg::OnBnClickedButtonStop()
{
bs1flt_.Bs1FltFolderProtectControl(FALSE);
}
void CtoolDlg::OnBnClickedButtonSetPolicy()
{
DWORD devcie_type = 0;
DWORD state = ENABLE;
BOOL islog = FALSE;
CString debug;
DEVICE_POLICY policy[BDC_MAX_DEVICE_TYPE];
for(int i = 0; i < BDC_MAX_DEVICE_TYPE; i++)
{
policy[i].device_type = BDC_UNKNOWN_DEV;
policy[i].state = ENABLE;
policy[i].islog = FALSE;
}
policy[BDC_USB_DISK].device_type = BDC_USB_DISK;
if (((CButton*)GetDlgItem(IDC_RADIO_USB_REMOVAL_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_USB_REMOVAL_DISABLE");
listLog_.AddString(debug);
policy[BDC_USB_DISK].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_USB_REMOVAL_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_USB_REMOVAL_ENABLE");
listLog_.AddString(debug);
policy[BDC_USB_DISK].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_USB_REMOVAL_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_USB_REMOVAL_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_USB_DISK].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_USB_REMOVAL_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_USB_REMOVAL_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_USB_DISK].islog = FALSE;
}
///
policy[BDC_EXTERNALHDD].device_type = BDC_EXTERNALHDD;
if (((CButton*)GetDlgItem(IDC_RADIO_EXTERNAL_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_EXTERNAL_DISABLE");
listLog_.AddString(debug);
policy[BDC_EXTERNALHDD].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_EXTERNAL_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_EXTERNAL_ENABLE");
listLog_.AddString(debug);
policy[BDC_EXTERNALHDD].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_EXTERNAL_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_EXTERNAL_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_EXTERNALHDD].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_EXTERNAL_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_EXTERNAL_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_EXTERNALHDD].islog = FALSE;
}
///
policy[BDC_NETWORKSHAREOUT].device_type = BDC_NETWORKSHAREOUT;
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKOUT_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_NETWORKOUT_DISABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKSHAREOUT].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKOUT_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_NETWORKOUT_ENABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKSHAREOUT].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKOUT_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_NETWORKOUT_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKSHAREOUT].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKOUT_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_NETWORKOUT_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKSHAREOUT].islog = FALSE;
}
///
policy[BDC_NETWORKDRIVEIN].device_type = BDC_NETWORKDRIVEIN;
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKIN_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_NETWORKIN_DISABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKDRIVEIN].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_NETWORKIN_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_NETWORKIN_ENABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKDRIVEIN].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO11_NETWORKIN_LOG_DISABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO11_NETWORKIN_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKDRIVEIN].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO11_NETWORKIN_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO11_NETWORKIN_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_NETWORKDRIVEIN].islog = FALSE;
}
///
policy[BDC_CDROM].device_type = BDC_CDROM;
if (((CButton*)GetDlgItem(IDC_RADIO12_CDROM_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO12_CDROM_DISABLE");
listLog_.AddString(debug);
policy[BDC_CDROM].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO13_CDROM_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO13_CDROM_ENABLE");
listLog_.AddString(debug);
policy[BDC_CDROM].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO14_CDROM_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO14_CDROM_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_CDROM].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO15_CDROM_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO15_CDROM_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_CDROM].islog = FALSE;
}
///
policy[BDC_FLOOPY].device_type = BDC_FLOOPY;
if (((CButton*)GetDlgItem(IDC_RADIO16_FLOPPYDISK_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO16_FLOPPYDISK_DISABLE");
listLog_.AddString(debug);
policy[BDC_FLOOPY].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO17_FLOPPYDISK_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO17_FLOPPYDISK_ENABLE");
listLog_.AddString(debug);
policy[BDC_FLOOPY].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO18_FLOPPYDISK_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO18_FLOPPYDISK_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_FLOOPY].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO19_FLOPPYDISK_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO19_FLOPPYDISK_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_FLOOPY].islog = FALSE;
}
policy[BDC_USB].device_type = BDC_USB;
if (((CButton*)GetDlgItem(IDC_RADIO16_USBPORT_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO16_USBPORT_DISABLE");
listLog_.AddString(debug);
policy[BDC_USB].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO17_USBPORT_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO17_USBPORT_ENABLE");
listLog_.AddString(debug);
policy[BDC_USB].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO18_USBPORT_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO18_USBPORT_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_USB].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO19_USBPORT_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO19_USBPORT_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_USB].islog = FALSE;
}
//블루투스
policy[BDC_BLUETOOTH].device_type = BDC_BLUETOOTH;
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHPORT_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_BLUETOOTHPORT_DISABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHPORT_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_BLUETOOTHPORT_ENABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHPORT_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_BLUETOOTHPORT_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHPORT_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_BLUETOOTHPORT_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH].islog = FALSE;
}
//블루투스 파일
policy[BDC_BLUETOOTH_FILE].device_type = BDC_BLUETOOTH_FILE;
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHFILEPORT_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_BLUETOOTHFILEPORT_DISABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH_FILE].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHFILEPORT_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_BLUETOOTHFILEPORT_ENABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH_FILE].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHFILEPORT_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_BLUETOOTHFILEPORT_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH_FILE].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_BLUETOOTHFILEPORT_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_BLUETOOTHFILEPORT_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_BLUETOOTH_FILE].islog = FALSE;
}
//MTP
policy[BDC_MTP].device_type = BDC_MTP;
if (((CButton*)GetDlgItem(IDC_RADIO_MTPPORT_DISABLE))->GetCheck())
{
state = (DWORD)DISABLE;
debug.Format(L"IDC_RADIO_MTPPORT_DISABLE");
listLog_.AddString(debug);
policy[BDC_MTP].state = (enum_devicestate)DISABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_MTPPORT_ENABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_MTPPORT_ENABLE");
listLog_.AddString(debug);
policy[BDC_MTP].state = (enum_devicestate)ENABLE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_MTPPORT_LOG_ENABLE))->GetCheck())
{
islog = (DWORD)TRUE;
debug.Format(L"IDC_RADIO_MTPPORT_LOG_ENABLE");
listLog_.AddString(debug);
policy[BDC_MTP].islog = TRUE;
}
if (((CButton*)GetDlgItem(IDC_RADIO_MTPPORT_LOG_DISABLE))->GetCheck())
{
debug.Format(L"IDC_RADIO_MTPPORT_LOG_DISABLE");
listLog_.AddString(debug);
policy[BDC_MTP].islog = FALSE;
}
for (int i = 0; i < BDC_MAX_DEVICE_TYPE; i++)
{
if(policy[i].device_type == BDC_UNKNOWN_DEV)
continue;
debug.Format(L"SetPolicy : Device Type %d State %d Islog %d", policy[i].device_type, policy[i].state, policy[i].islog);
listLog_.AddString(debug);
bs1flt_.Bs1FltSetPolicy((DWORD)policy[i].device_type, policy[i].state, policy[i].islog);
}
/*debug.Format(L"SetPolicy : %d %d", state, islog);
listLog_.AddString(debug);
bs1flt_.Bs1FltSetPolicy((DWORD)BDC_USB_DISK, state, islog);*/
}
void CtoolDlg::OnBnClickedCancel()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
bs1flt_.Bs1FltCleanup();
CDialogEx::OnCancel();
}
void CtoolDlg::OnBnClickedButtonProcessProtect()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CDialogProtectProcess dlg;
dlg.DoModal();
}
void CtoolDlg::OnBnClickedButtonUsbException()
{
CDialogUsbException dlg;
dlg.DoModal();
}
void CtoolDlg::OnBnClickedButtonDeviceProtect()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
if (!device_protect_)
device_protect_ = TRUE;
else
device_protect_ = FALSE;
bs1flt_.Bs1fltSetDeviceProtect(device_protect_);
if(device_protect_)
GetDlgItem(IDC_BUTTON_DEVICE_PROTECT)->SetWindowTextW(L"장치 제어 중지");
else
GetDlgItem(IDC_BUTTON_DEVICE_PROTECT)->SetWindowTextW(L"장치 제어 시작");
}
void CtoolDlg::OnBnClickedButton2()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CString input;
editDebug_.GetWindowTextW(input);
int value = _ttoi(input); // input이 "123"이면 value는 123이 됨
bs1flt_.Bs1FltDebug(value);
}
static BOOL isUsbhook = FALSE;
static BOOL isBlueToothhook = FALSE;
static BOOL isMtphook = FALSE;
void CtoolDlg::OnBnClickedButtonSetUsbHook()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
//IDC_BUTTON_SET_USB_HOOK
if(isUsbhook)
isUsbhook = FALSE;
else
isUsbhook = TRUE;
bs1flt_.Bs1FltSetHook(BDC_USB, isUsbhook);
if(isUsbhook)
GetDlgItem(IDC_BUTTON_SET_USB_HOOK)->SetWindowTextW(L"USB 후킹 해제");
else
GetDlgItem(IDC_BUTTON_SET_USB_HOOK)->SetWindowTextW(L"USB 후킹 시작");
}
void CtoolDlg::OnBnClickedButtonSetBluetoothHook()
{
if (isBlueToothhook)
isBlueToothhook = FALSE;
else
isBlueToothhook = TRUE;
bs1flt_.Bs1FltSetHook(BDC_BLUETOOTH, isBlueToothhook);
if (isBlueToothhook)
GetDlgItem(IDC_BUTTON_SET_BLUETOOTH_HOOK)->SetWindowTextW(L"블루투스 후킹 해제");
else
GetDlgItem(IDC_BUTTON_SET_BLUETOOTH_HOOK)->SetWindowTextW(L"블루투스 후킹 시작");
}
void CtoolDlg::OnBnClickedButtonSetMtpHook()
{
if (isMtphook)
isMtphook = FALSE;
else
isMtphook = TRUE;
bs1flt_.Bs1FltSetHook(BDC_MTP, isMtphook);
if (isMtphook)
GetDlgItem(IDC_BUTTON_SET_MTP_HOOK)->SetWindowTextW(L"MTP 후킹 해제");
else
GetDlgItem(IDC_BUTTON_SET_MTP_HOOK)->SetWindowTextW(L"MTP 후킹 시작");
}
void CtoolDlg::OnBnClickedButton3()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CDlgProcessCreateRule dlg;
dlg.DoModal();
}
void CtoolDlg::OnBnClickedButtonInit()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
DWORD state;
state = bs1flt_.Bs1FltInit(s_wcurrent_path_.c_str(), Report, NULL);
if (state)
{
MessageBoxW(L"Bs1fltControl 초기화 실패", L"Error", MB_ICONERROR);
return;
}
CString debug;
debug.Format(L"CDS Filter Driver Init State %s : %d", s_wcurrent_path_.c_str(), state);
listLog_.AddString(debug);
state = bs1flt_.Bs1FltSetPid(PG_PID_ALLOW, GetCurrentProcessId());
if (state)
{
MessageBoxW(L"Bs1FltSetPid 실패", L"Error", MB_ICONERROR);
return;
}
bs1flt_.Bs1FltSetPath(PG_PATH_BLACK, s_wcurrent_path_.c_str());
if (state)
{
MessageBoxW(L"Bs1FltSetPath 실패", L"Error", MB_ICONERROR);
return;
}
//bs1flt_.Bs1FltFolderProtectControl(TRUE);
//SetProtectedFilePath(dir);
bs1flt_.Bs1FltBegin(TRUE);
if (state)
{
MessageBoxW(L"Bs1FltBegin 실패", L"Error", MB_ICONERROR);
return;
}
}
void CtoolDlg::OnBnClickedButtonOpen()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
DWORD state = bs1flt_.Bs1fltOpen();
if (state != ERROR_SUCCESS)
{
CString debug;
debug.Format(L"Bs1fltControl 열기 실패 : %d, %p", state, bs1flt_.Bs1fltOpen);
MessageBoxW(debug.GetBuffer(0), L"Error", MB_ICONERROR);
return;
}
MessageBoxW(L"Bs1fltControl 열기 성공", L"Success", MB_ICONINFORMATION);
}
void CtoolDlg::OnBnClickedButtonFolderSetting()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CFolderProtectDlg dlg;
dlg.DoModal();
}
void CtoolDlg::OnBnClickedButtonRegditSetting()
{
// TODO: 여기에 컨트롤 알림 처리기 코드를 추가합니다.
CDialogRegProtect dlg;
dlg.DoModal();
}