Page Menu
Home
desp's stash
Search
Configure Global Search
Log In
Files
F527288
ImportRebuilder.h
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
2 KB
Subscribers
None
ImportRebuilder.h
View Options
#pragma once
#include
<map>
#include
"PeParser.h"
#include
"Thunks.h"
#include
"IATReferenceScan.h"
class
ImportRebuilder
:
public
PeParser
{
public
:
ImportRebuilder
(
const
WCHAR
*
file
)
:
PeParser
(
file
,
true
)
{
pImportDescriptor
=
0
;
pThunkData
=
0
;
pImportByName
=
0
;
numberOfImportDescriptors
=
0
;
sizeOfImportSection
=
0
;
sizeOfApiAndModuleNames
=
0
;
importSectionIndex
=
0
;
useOFT
=
false
;
sizeOfOFTArray
=
0
;
newIatInSection
=
false
;
BuildDirectImportsJumpTable
=
false
;
sizeOfJumpTable
=
0
;
}
bool
rebuildImportTable
(
const
WCHAR
*
newFilePath
,
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
void
enableOFTSupport
();
void
enableNewIatInSection
(
DWORD_PTR
iatAddress
,
DWORD
iatSize
);
IATReferenceScan
*
iatReferenceScan
;
bool
BuildDirectImportsJumpTable
;
private
:
PIMAGE_IMPORT_DESCRIPTOR
pImportDescriptor
;
PIMAGE_THUNK_DATA
pThunkData
;
PIMAGE_IMPORT_BY_NAME
pImportByName
;
size_t
numberOfImportDescriptors
;
size_t
sizeOfImportSection
;
size_t
sizeOfApiAndModuleNames
;
size_t
importSectionIndex
;
//OriginalFirstThunk Array in Import Section
size_t
sizeOfOFTArray
;
bool
useOFT
;
bool
newIatInSection
;
DWORD_PTR
IatAddress
;
DWORD
IatSize
;
DWORD
sizeOfJumpTable
;
DWORD
directImportsJumpTableRVA
;
BYTE
*
JMPTableMemory
;
DWORD
newIatBaseAddressRVA
;
DWORD
fillImportSection
(
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
BYTE
*
getMemoryPointerFromRVA
(
DWORD_PTR
dwRVA
);
bool
createNewImportSection
(
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
bool
buildNewImportTable
(
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
void
setFlagToIATSection
(
DWORD_PTR
iatAddress
);
size_t
addImportToImportTable
(
ImportThunk
*
pImport
,
PIMAGE_THUNK_DATA
pThunk
,
PIMAGE_IMPORT_BY_NAME
pImportByName
,
DWORD
sectionOffset
);
size_t
addImportDescriptor
(
ImportModuleThunk
*
pImportModule
,
DWORD
sectionOffset
,
DWORD
sectionOffsetOFTArray
);
void
calculateImportSizes
(
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
void
addSpecialImportDescriptor
(
DWORD_PTR
rvaFirstThunk
,
DWORD
sectionOffsetOFTArray
);
void
patchFileForNewIatLocation
();
void
changeIatBaseAddress
(
std
::
map
<
DWORD_PTR
,
ImportModuleThunk
>
&
moduleList
);
void
patchFileForDirectImportJumpTable
();
};
File Metadata
Details
Attached
Mime Type
text/x-c++
Expires
Wed, Jan 7, 1:50 PM (8 h, 3 m)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
ae/e3/257a3cc64607a63892fc61b68d29
Attached To
rSCY Scylla
Event Timeline
Log In to Comment