PDA

Просмотр полной версии : [x86] lemonhook


sc6ut
13.08.2021, 20:20
да-да, ещё один класс для хуков, он самый.

особенности:

- возможность выгрузки хука при любой ситуации, не ломая цепочку вызовов хуков.​- трамплин передается первым аргументом в хукнутую функцию, что позволяет не создавать глобальных объектов и переменных.​- автоматическое определение размера хука.​- поддержка лямбд, колбеков-методов (спиздил у @SR_team (https://www.blast.hk/members/11231/)).​- поддержка cdecl, stdcall, thiscall.​

примеры:

хук CChat::AddEntry:






using
add_entry_t
=
int
(
__thiscall
*
)
(
void
*
,
int
,
const
char
*
,
const
char
*
,
std
::
uint32_t
,
std
::
uint32_t
)
;
lemon
::
detour

add_entry_hook
(
0x64010
,
"samp.dll"
)
;
// пример с обычной функцией
int
add_entry
(
add_entry_t orig
,
void
*
this_ptr
,
int
type
,
const
char
*
text
,
const
char
*
prefix
,
std
::
uint32_t
text_color
,
std
::
uint32_t
prefix_color
)
{
// do your stuff
return
orig
(
this_ptr
,
type
,
text
,
prefix
,
text_color
,
prefix_color
)
;
}
add_entry_hook
.
install
(
add_entry
)
;
// пример с лямбдой
add_entry_hook
.
install
(
[
]
(
auto
orig
,
void
*
this_ptr
,
int
type
,
const
char
*
text
,
const
char
*
prefix
,
std
::
uint32_t
text_color
,
std
::
uint32_t
prefix_color
)
->
int
{
// do your stuff
return
orig
(
this_ptr
,
type
,
text
,
prefix
,
text_color
,
prefix_color
)
;
}
)
;
// пример с колбеком-методом
struct
ex
{
int
add_entry
(
add_entry_t orig
,
void
*
this_ptr
,
int
type
,
const
char
*
text
,
const
char
*
prefix
,
std
::
uint32_t
text_color
,
std
::
uint32_t
prefix_color
)
{
// do your stuff
return
orig
(
this_ptr
,
type
,
text
,
prefix
,
text_color
,
prefix_color
)
;
}
}
;
ex obj
;
add_entry_hook
.
install
(
std
::
make_tuple
(
&
obj
,
&
ex
::
add_entry
)
)
;




в этих примерах, хукается функция класса CChat - AddEntry, находящаяся в динамической библиотеке samp.dll. в параметрах каждого из колбеков видно, что помимо оригинальных аргументов функции она так же получает трамплин для вызова оригинальной функции.

планы на будущее:

- x64 support.​- класс для хуков любого места (что-то вроде SRHook'ов @SR_team (https://www.blast.hk/members/11231/)).​- (maybe?) linux support (пока не знаю зачем).​

src:

NIKITA / LemonHook (https://gitlab.com/sc6ut/lemonhook)

GitLab.com

gitlab.com

kin4stat
13.08.2021, 21:55
Да-да, ещё один класс для хуков, он самый.

Особенности:
- Возможность выгрузки хука при любой ситуации, не ломая цепочку вызовов хуков.​- Трамплин передается первым аргументом в хукнутую функцию, что позволяет не создавать глобальных объектов и переменных.​- Автоматическое определение размера хука.​
Пример:

Хук CChat::AddEntry:






using
AddEntry
=
int
(
__thiscall
*
)
(
void
*
,
int
,
const
char
*
,
const
char
*
,
uint32_t
,
uint32_t
)
;
int
__fastcall
hookedAddEntry
(
void
*
ecx
,
void
*
,
AddEntry oAddEntry
,
const
char
*
text
,
const
char
*
prefix
,
uint32_t
color
,
uint32_t
prefixColor
)
{
// Do your stuff
return
oAddEntry
(
ecx
,
text
,
prefix
,
color
,
prefixColor
)
;
}
LemonHook
::
Hook _addEntryHook
{
0x64010
,
"samp"
}
;
_addEntryHook
.
install
(
hookedAddEntry
)
;




В этом примере, хукается функция класса CChat - AddEntry, находящаяся в динамической библиотеке samp.dll. На 3 строчке видно, что помимо параметров самой функции и регистра EDX, добавился так же указатель на трамплин для вызова оригинальной функции.

Source:

NIKITA / LemonHook (https://gitlab.com/sc6ut/lemonhook)

GitLab.com

gitlab.com



Используйте код из примеров и получите UB и ошибки компиляции в подарок!

__thiscall* недопустим на MSVC, но GCC позволяет.

А еще AddEntry имеет 6 параметров, а вызываешь ты его с 5 параметрами.

Хоть проверил бы код

Имена начинающиеся на _ и __ зарезервированы под нужды компилятора.

А еще лучше второму параметру дать имя, ибо компилятор можно похерить регистр неиспользуемого аргумента, он же внутри функции не нужен?(хотя в целом он не должен такие оптимизации производить над функциями у которых берется адрес, но все же -O3 на GCC(MinGW) может все похерить)

SR_team
13.08.2021, 21:57
Смотрю на некоторые участки кода и прям дежавю

kin4stat
13.08.2021, 21:58
Смотрю на некоторые участки кода и прям дежавю


Похоже на Попытку переписать srhook с минимальным оверхедом и совместить его с минхуком

sc6ut
13.08.2021, 22:11
Используйте код из примеров и получите UB и ошибки компиляции в подарок!
__thiscall* недопустим на MSVC, но GCC позволяет.


??



А еще AddEntry имеет 6 параметров, а вызываешь ты его с 5 параметрами.
Хоть проверил бы код


проверял. не заметил, что проебал 1 параметр, так как код не копировал из проекта.



А еще лучше второму параметру дать имя, ибо компилятор можно похерить регистр неиспользуемого аргумента, он же внутри функции не нужен?(хотя в целом он не должен такие оптимизации производить над функциями у которых берется адрес, но все же -O3 на GCC(MinGW) может все похерить)


этого не знал, спасибо.



Смотрю на некоторые участки кода и прям дежавю


и в правду смотрел некоторые вещи там, стоило написать об этом в шапке.



совместить его с минхуком


единственное что взял оттуда это файлы Hacker Disassembler Engine.

kin4stat
13.08.2021, 23:05
??


Мб через typedef не работает. Я просто забил, везде fastcall начал использовать, даже при переходе с typedef на using

sc6ut
13.08.2021, 23:09
Мб через typedef не работает.


тоже работает.

loganhackerdff
14.08.2021, 03:11
А че за gitlab, он круче гитхаба?

SR_team
14.08.2021, 03:22
он круче гитхаба?


нельзя так рассуждать, потому что у каждой из этих двух вещей есть свои плюс и минусы. и каждый выбирает пользоваться тем, что ему нужно. почитай лучше в интернете разные статьи на эту тему. чем они друг от друга отличаются. может быть тебе @SR_team (https://www.blast.hk/members/11231/) своё мнение напишет, почему он пользуется именно гитлабом. Но я думаю, что как минимум из-за того, что там нельзя подавать DMCA, в отличии от гитхаба) а у всех вышестоящих над бх челов триггеры на эти жалобы)) поскольку у них дохуя репозиториев калкор забанил. Но это я так думаю. И может быть я ошибаюсь. Всё остальное он тебе может быть напишет

bottom_text
03.09.2021, 16:10
https://forum.antichat.xyz/attachments/27835428/

Переписал код с твоего скрина и всё равно эта ошибка, сборка ломается , как исправить?

Musaigen
03.09.2021, 16:31
Переписал код с твоего скрина и всё равно эта ошибка, сборка ломается , как исправить?


Убери квадратные скобки в 23 и 82 строке и _size в 82 строке.

sc6ut
03.09.2021, 17:19
Переписал код с твоего скрина и всё равно эта ошибка, сборка ломается , как исправить?


C++ 20 включить

F0RQU1N and
03.09.2021, 17:25
C++ 20 включить


так сделай чтобы с любой версией можно было

legendabrn
03.09.2021, 19:41
так сделай чтобы с любой версией можно было


переписать на c++11 ради твоих нужд, гений😀

sc6ut
10.04.2022, 02:15
обновил ***ни вроде меньше, но еще работать, зачем сюда пишу об этом я незнаю мне по***

кстати с++ 17 а не 20

эксперты напишите что код ***ня и почему (серьезно)