mirror-ac/user/report.h

87 lines
1.7 KiB
C
Raw Normal View History

2023-08-18 07:33:13 +02:00
#ifndef REPORT_H
#define REPORT_H
#include <Windows.h>
#include "threadpool.h"
#include "client.h"
2023-08-18 10:39:21 +02:00
#include <TlHelp32.h>
#define REPORT_BUFFER_SIZE 1024
2023-08-18 15:22:53 +02:00
#define MAX_SIGNATURE_SIZE 256
2023-08-18 10:39:21 +02:00
#define REPORT_CODE_MODULE_VERIFICATION 10
2023-08-18 15:22:53 +02:00
#define REPORT_CODE_START_ADDRESS_VERIFICATION 20
#define REPORT_PAGE_PROTECTION_VERIFICATION 30
#define REPORT_PATTERN_SCAN_FAILURE 40
2023-08-18 07:33:13 +02:00
2023-08-18 16:34:15 +02:00
2023-08-18 07:33:13 +02:00
namespace global
{
class Report
{
std::shared_ptr<global::ThreadPool> thread_pool;
2023-08-18 09:18:00 +02:00
std::shared_ptr<global::Client> client;
2023-08-18 10:39:21 +02:00
std::mutex mutex;
byte buffer[ REPORT_BUFFER_SIZE ];
2023-08-18 15:22:53 +02:00
2023-08-18 07:33:13 +02:00
public:
2023-08-18 15:22:53 +02:00
2023-08-18 07:33:13 +02:00
Report( std::shared_ptr<global::ThreadPool> ThreadPool, LPTSTR PipeName );
2023-08-18 10:39:21 +02:00
2023-08-18 16:34:15 +02:00
/* lock buffer, copy report, send to service then clear buffer */
2023-08-18 10:39:21 +02:00
template <typename T>
void ReportViolation( T* Report )
{
mutex.lock();
2023-08-18 16:34:15 +02:00
global::headers::PIPE_PACKET_HEADER header;
header.message_type = REPORT_PACKET_ID;
memcpy( this->buffer, &header, sizeof( global::headers::PIPE_PACKET_HEADER ) );
memcpy( this->buffer + sizeof( global::headers::PIPE_PACKET_HEADER ), Report, sizeof(T));
2023-08-18 10:39:21 +02:00
this->client->WriteToPipe( buffer, sizeof(T) );
RtlZeroMemory( this->buffer, REPORT_BUFFER_SIZE );
2023-08-18 16:34:15 +02:00
2023-08-18 10:39:21 +02:00
mutex.unlock();
}
2023-08-18 07:33:13 +02:00
};
2023-08-18 10:39:21 +02:00
namespace report_structures
{
struct MODULE_VERIFICATION_CHECKSUM_FAILURE
{
INT report_code;
UINT64 module_base_address;
UINT64 module_size;
std::string module_name;
};
2023-08-18 15:22:53 +02:00
struct PROCESS_THREAD_START_FAILURE
{
INT report_code;
LONG thread_id;
UINT64 start_address;
};
struct PAGE_PROTECTION_FAILURE
{
INT report_code;
UINT64 page_base_address;
LONG allocation_protection;
LONG allocation_state;
LONG allocation_type;
};
struct PATTERN_SCAN_FAILURE
{
INT report_code;
INT signature_id;
UINT64 address;
};
2023-08-18 10:39:21 +02:00
}
2023-08-18 07:33:13 +02:00
}
#endif