extract more strings

This commit is contained in:
Akash Mozumdar 2018-11-04 04:00:14 -05:00
parent 62541968aa
commit b218e241da
8 changed files with 64 additions and 54 deletions

View File

@ -1,8 +1,7 @@
#include "extenwindow.h" #include "extenwindow.h"
#include "ui_extenwindow.h" #include "ui_extenwindow.h"
#include "defs.h"
#include "types.h"
#include "text.h" #include "text.h"
#include "types.h"
#include <QFileDialog> #include <QFileDialog>
#include <QMimeData> #include <QMimeData>
#include <QUrl> #include <QUrl>

View File

@ -2,6 +2,7 @@
#define EXTENSIONS_H #define EXTENSIONS_H
#include "qtcommon.h" #include "qtcommon.h"
#include "defs.h"
#include <shared_mutex> #include <shared_mutex>
#include <QListWidget> #include <QListWidget>
#include <QDragEnterEvent> #include <QDragEnterEvent>
@ -34,7 +35,7 @@ private:
void dropEvent(QDropEvent* event); void dropEvent(QDropEvent* event);
Ui::ExtenWindow* ui; Ui::ExtenWindow* ui;
QFile extenSaveFile = QFile("Extensions.txt"); QFile extenSaveFile = QFile(EXTEN_SAVE_FILE);
QListWidget* extenList; QListWidget* extenList;
}; };

View File

@ -30,8 +30,8 @@ namespace Host
void AddConsoleOutput(std::wstring text); void AddConsoleOutput(std::wstring text);
} }
inline UINT DEFAULT_CODEPAGE = SHIFT_JIS; inline UINT CURRENT_CODEPAGE = SHIFT_JIS;
inline std::wstring StringToWideString(const std::string& text, UINT encoding = DEFAULT_CODEPAGE) inline std::wstring StringToWideString(const std::string& text, UINT encoding = CURRENT_CODEPAGE)
{ {
std::wstring ret(text.size() + 1, 0); std::wstring ret(text.size() + 1, 0);
ret.resize(MultiByteToWideChar(encoding, 0, text.c_str(), -1, ret.data(), ret.capacity()) - 1); ret.resize(MultiByteToWideChar(encoding, 0, text.c_str(), -1, ret.data(), ret.capacity()) - 1);

View File

@ -38,7 +38,7 @@ void TextThread::Push(const BYTE* data, int len)
LOCK(threadMutex); LOCK(threadMutex);
buffer += hp.type & USING_UNICODE buffer += hp.type & USING_UNICODE
? std::wstring((wchar_t*)data, len / 2) ? std::wstring((wchar_t*)data, len / 2)
: StringToWideString(std::string((char*)data, len), hp.codepage != 0 ? hp.codepage : DEFAULT_CODEPAGE); : StringToWideString(std::string((char*)data, len), hp.codepage != 0 ? hp.codepage : CURRENT_CODEPAGE);
if (std::all_of(buffer.begin(), buffer.end(), [&](wchar_t c) { return repeatingChars.count(c) > 0; })) buffer.clear(); if (std::all_of(buffer.begin(), buffer.end(), [&](wchar_t c) { return repeatingChars.count(c) > 0; })) buffer.clear();
lastPushTime = GetTickCount(); lastPushTime = GetTickCount();
} }

View File

@ -1,6 +1,5 @@
#include "mainwindow.h" #include "mainwindow.h"
#include "ui_mainwindow.h" #include "ui_mainwindow.h"
#include "defs.h"
#include "text.h" #include "text.h"
#include "extenwindow.h" #include "extenwindow.h"
#include "misc.h" #include "misc.h"
@ -17,11 +16,11 @@ MainWindow::MainWindow(QWidget *parent) :
ttCombo = findChild<QComboBox*>("ttCombo"); ttCombo = findChild<QComboBox*>("ttCombo");
textOutput = findChild<QPlainTextEdit*>("textOutput"); textOutput = findChild<QPlainTextEdit*>("textOutput");
if (settings.contains("Window")) this->setGeometry(settings.value("Window").toRect()); if (settings.contains(WINDOW)) this->setGeometry(settings.value(WINDOW).toRect());
// TODO: add GUI for changing these // TODO: add GUI for changing these
if (settings.contains("Default_Codepage")) DEFAULT_CODEPAGE = settings.value("Default_Codepage").toInt(); if (settings.contains(DEFAULT_CODEPAGE)) CURRENT_CODEPAGE = settings.value(DEFAULT_CODEPAGE).toInt();
if (settings.contains("Flush_Delay")) TextThread::flushDelay = settings.value("Flush_Delay").toInt(); if (settings.contains(FLUSH_DELAY)) TextThread::flushDelay = settings.value(FLUSH_DELAY).toInt();
if (settings.contains("Max_Buffer_Size")) TextThread::maxBufferSize = settings.value("Max_Buffer_Size").toInt(); if (settings.contains(MAX_BUFFER_SIZE)) TextThread::maxBufferSize = settings.value(MAX_BUFFER_SIZE).toInt();
qRegisterMetaType<std::shared_ptr<TextThread>>(); qRegisterMetaType<std::shared_ptr<TextThread>>();
@ -43,10 +42,10 @@ MainWindow::MainWindow(QWidget *parent) :
MainWindow::~MainWindow() MainWindow::~MainWindow()
{ {
settings.setValue("Window", this->geometry()); settings.setValue(WINDOW, this->geometry());
settings.setValue("Default_Codepage", DEFAULT_CODEPAGE); settings.setValue(DEFAULT_CODEPAGE, CURRENT_CODEPAGE);
settings.setValue("Flush_Delay", TextThread::flushDelay); settings.setValue(FLUSH_DELAY, TextThread::flushDelay);
settings.setValue("Max_Buffer_Size", TextThread::maxBufferSize); settings.setValue(MAX_BUFFER_SIZE, TextThread::maxBufferSize);
settings.sync(); settings.sync();
delete ui; delete ui;
@ -61,7 +60,7 @@ void MainWindow::closeEvent(QCloseEvent*)
void MainWindow::AddProcess(unsigned processId) void MainWindow::AddProcess(unsigned processId)
{ {
processCombo->addItem(QString::number(processId, 16).toUpper() + ": " + GetModuleName(processId)); processCombo->addItem(QString::number(processId, 16).toUpper() + ": " + GetModuleName(processId));
QFile file("SavedHooks.txt"); QFile file(HOOK_SAVE_FILE);
file.open(QIODevice::ReadOnly); file.open(QIODevice::ReadOnly);
QString processName = GetFullModuleName(processId); QString processName = GetFullModuleName(processId);
QStringList allProcesses = QString(file.readAll()).split("\r", QString::SkipEmptyParts); QStringList allProcesses = QString(file.readAll()).split("\r", QString::SkipEmptyParts);
@ -223,7 +222,7 @@ void MainWindow::on_saveButton_clicked()
for (auto hook : hooks) for (auto hook : hooks)
if (!(hook.type & HOOK_ENGINE)) if (!(hook.type & HOOK_ENGINE))
hookList += " , " + GenerateCode(hook, GetSelectedProcessId()); hookList += " , " + GenerateCode(hook, GetSelectedProcessId());
QFile file("SavedHooks.txt"); QFile file(HOOK_SAVE_FILE);
file.open(QIODevice::Append); file.open(QIODevice::Append);
file.write((hookList + "\r\n").toUtf8()); file.write((hookList + "\r\n").toUtf8());
} }

View File

@ -3,6 +3,7 @@
#include "qtcommon.h" #include "qtcommon.h"
#include "host/host.h" #include "host/host.h"
#include "defs.h"
#include <QPlainTextEdit> #include <QPlainTextEdit>
#include <QComboBox> #include <QComboBox>
#include <QSettings> #include <QSettings>
@ -53,7 +54,7 @@ private:
void closeEvent(QCloseEvent*); void closeEvent(QCloseEvent*);
Ui::MainWindow* ui; Ui::MainWindow* ui;
QSettings settings = QSettings("Textractor.ini", QSettings::IniFormat); QSettings settings = QSettings(CONFIG_FILE, QSettings::IniFormat);
QComboBox* processCombo; QComboBox* processCombo;
QComboBox* ttCombo; QComboBox* ttCombo;
QPlainTextEdit* textOutput; QPlainTextEdit* textOutput;

View File

@ -3,19 +3,32 @@
// vnrhook/defs.h // vnrhook/defs.h
// 8/23/2013 jichi // 8/23/2013 jichi
#define ITH_DLL L"vnrhook" constexpr auto ITH_DLL = L"vnrhook";
// Pipes // Pipes
#define HOOK_PIPE L"\\\\.\\pipe\\TEXTRACTOR_HOOK" constexpr auto HOOK_PIPE = L"\\\\.\\pipe\\TEXTRACTOR_HOOK";
#define HOST_PIPE L"\\\\.\\pipe\\TEXTRACTOR_HOST" constexpr auto HOST_PIPE = L"\\\\.\\pipe\\TEXTRACTOR_HOST";
// Sections // Sections
#define ITH_SECTION_ L"VNR_SECTION_" // _%d constexpr auto ITH_SECTION_ = L"VNR_SECTION_"; // _%d
// Mutex // Mutex
#define ITH_HOOKMAN_MUTEX_ L"VNR_HOOKMAN_" // ITH_HOOKMAN_%d constexpr auto ITH_HOOKMAN_MUTEX_ = L"VNR_HOOKMAN_"; // ITH_HOOKMAN_%d
// Files
constexpr auto CONFIG_FILE = u8"Textractor.ini";
constexpr auto HOOK_SAVE_FILE = u8"SavedHooks.txt";
constexpr auto EXTEN_SAVE_FILE = u8"Extensions.txt";
// Settings
constexpr auto WINDOW = u8"Window";
constexpr auto DEFAULT_CODEPAGE = u8"Default_Codepage";
constexpr auto FLUSH_DELAY = u8"Flush_Delay";
constexpr auto MAX_BUFFER_SIZE = u8"Max_Buffer_Size";
// EOF // EOF

View File

@ -1,33 +1,30 @@
#pragma once #pragma once
namespace constexpr auto SELECT_PROCESS = u8"Select Process";
{ constexpr auto INJECT_INFO = u8"If you don't see the process you want to inject, try running with admin rights\r\n"
auto ABOUT = L"Textractor beta v3.4.0 by Artikash\r\n" "You can also type in the process id";
"Source code and more information available under GPLv3 at https://github.com/Artikash/Textractor"; constexpr auto ADD_HOOK = u8"Add hook";
auto SELECT_PROCESS = "Select Process"; constexpr auto CODE_INFODUMP = u8"Enter hook code\r\n"
auto INJECT_INFO = "If you don't see the process you want to inject, try running with admin rights\r\n" "/H{A|B|W|S|Q|V}[N][codepage#]data_offset[*deref_offset1][:split_offset[*deref_offset2]]@addr[:module[:func]]\r\n"
"You can also type in the process id"; "OR\r\n"
auto ADD_HOOK = "Add hook"; "Enter read code\r\n"
auto CODE_INFODUMP = "Enter hook code\r\n" "/R{S|Q|V}[codepage#][*deref_offset|0]@addr\r\n"
"/H{A|B|W|S|Q|V}[N][codepage#]data_offset[*deref_offset1][:split_offset[*deref_offset2]]@addr[:module[:func]]\r\n" "All numbers except codepage in hexadecimal\r\n"
"OR\r\n" "A/B: Shift-JIS char little/big endian\r\n"
"Enter read code\r\n" "W: UTF-16 char\r\n"
"/R{S|Q|V}[codepage#][*deref_offset|0]@addr\r\n" "S/Q/V: Shift-JIS/UTF-16/UTF-8 string\r\n"
"All numbers except codepage in hexadecimal\r\n" "Negatives for data_offset/sub_offset refer to registers\r\n"
"A/B: Shift-JIS char little/big endian\r\n" "-4 for EAX, -8 for ECX, -C for EDX, -10 for EBX, -14 for ESP, -18 for EBP, -1C for ESI, -20 for EDI\r\n"
"W: UTF-16 char\r\n" "* means dereference pointer+deref_offset";
"S/Q/V: Shift-JIS/UTF-16/UTF-8 string\r\n" constexpr auto UNHOOK = u8"Unhook";
"Negatives for data_offset/sub_offset refer to registers\r\n" constexpr auto REMOVE_HOOK = u8"Which hook to remove?";
"-4 for EAX, -8 for ECX, -C for EDX, -10 for EBX, -14 for ESP, -18 for EBP, -1C for ESI, -20 for EDI\r\n" constexpr auto SELECT_EXTENSION = u8"Select Extension";
"* means dereference pointer+deref_offset"; constexpr auto EXTENSIONS = u8"Extensions (*.dll)";
auto UNHOOK = "Unhook"; constexpr auto ABOUT = L"Textractor beta v3.4.0 by Artikash\r\n"
auto REMOVE_HOOK = "Which hook to remove?"; "Source code and more information available under GPLv3 at https://github.com/Artikash/Textractor";
auto SELECT_EXTENSION = "Select Extension"; constexpr auto TOO_MANY_THREADS = L"Textractor: ERROR: too many text threads: can't create more";
auto EXTENSIONS = "Extensions (*.dll)"; constexpr auto ALREADY_INJECTED = L"Textractor: ERROR: already injected";
auto TOO_MANY_THREADS = L"Textractor: ERROR: too many text threads: can't create more"; constexpr auto ARCHITECTURE_MISMATCH = L"Textractor: ERROR: architecture mismatch: try 32 bit Textractor instead";
auto ALREADY_INJECTED = L"Textractor: ERROR: already injected"; constexpr auto INJECT_FAILED = L"Textractor: ERROR: couldn't inject";
auto ARCHITECTURE_MISMATCH = L"Textractor: ERROR: architecture mismatch: try 32 bit Textractor instead"; constexpr auto INVALID_CODE = L"Textractor: invalid code";
auto INJECT_FAILED = L"Textractor: ERROR: couldn't inject"; constexpr auto NO_HOOKS = L"Textractor: no hooks detected";
auto INVALID_CODE = L"Textractor: invalid code";
auto NO_HOOKS = :"Textractor: no hooks detected";
}