Windows2003-3790/admin/pchealth/sr/tools/dumpmap/dumpmap.cpp
2020-09-30 16:53:55 +02:00

150 lines
3.5 KiB
C++

#include <nt.h>
#include <ntrtl.h>
#include <nturtl.h>
#include <windows.h>
#include "restmap.h"
#include "shellapi.h"
#include <stdio.h>
#include <stdlib.h>
struct _EVENT_STR_MAP
{
DWORD EventId;
LPWSTR pEventStr;
} EventMap[ 12 ] =
{
{SrEventInvalid , L"INVALID " },
{SrEventStreamChange, L"FILE-MODIFY" },
{SrEventAclChange, L"ACL-CHANGE " },
{SrEventAttribChange, L"ATTR-CHANGE" },
{SrEventStreamOverwrite,L"FILE-MODIFY" },
{SrEventFileDelete, L"FILE-DELETE" },
{SrEventFileCreate, L"FILE-CREATE" },
{SrEventFileRename, L"FILE-RENAME" },
{SrEventDirectoryCreate,L"DIR-CREATE " },
{SrEventDirectoryRename,L"DIR-RENAME " },
{SrEventDirectoryDelete,L"DIR-DELETE " },
{SrEventMaximum, L"INVALID-MAX" }
};
LPWSTR
GetEventString(
DWORD EventId
)
{
LPWSTR pStr = L"NOT-FOUND";
for( int i=0; i<sizeof(EventMap)/sizeof(_EVENT_STR_MAP);i++)
{
if ( EventMap[i].EventId == EventId )
{
pStr = EventMap[i].pEventStr;
}
}
return pStr;
}
void
PrintUsage()
{
printf("Usage: restmap <option>");
printf("\n 1 = dumpmap [filename]");
printf("\n 2 = createmap <filename> <drive> <RPNum>");
}
void
PrintRestoreMap(LPWSTR pszFileName)
{
RestoreMapEntry *prme = NULL;
HANDLE hFile;
LPWSTR pszSrc, pszDest, pszTemp;
LPBYTE pbAcl = NULL;
hFile = CreateFile(pszFileName, GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
if (hFile == INVALID_HANDLE_VALUE)
goto Err;
while (ERROR_SUCCESS == ReadRestoreMapEntry(hFile, &prme))
{
GetPaths(prme, &pszSrc, &pszTemp, &pszDest, &pbAcl);
printf("\n%S\tAttr=%08d\tAcl=%S\tSrc=%S\tTmp=%S\tDest=%S\tAcl=%S",
GetEventString(prme->m_dwOperation),
prme->m_dwAttribute,
(prme->m_cbAcl > 0) ? L"Yes" : L"No",
pszSrc,
pszTemp ? pszTemp : L"",
pszDest ? pszDest : L"",
pbAcl ? (prme->m_fAclInline ? L"inline" : (LPWSTR) pbAcl) : L"");
}
FreeRestoreMapEntry(prme);
CloseHandle(hFile);
Err:
return;
}
void __cdecl
main()
{
LPWSTR * argv = NULL;
int argc;
HGLOBAL hMem = NULL;
HANDLE hFile = NULL;
int option;
argv = CommandLineToArgvW(GetCommandLine(), &argc);
if (! argv)
{
printf("Error parsing arguments");
goto done;
}
if (argc < 2)
{
PrintUsage();
goto done;
}
option = _wtoi(argv[1]);
switch (option)
{
case 1:
PrintRestoreMap(argv[2]);
break;
case 2:
if (argc != 5)
{
PrintUsage();
goto done;
}
hFile = CreateFile(argv[2], GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
if (hFile != INVALID_HANDLE_VALUE)
{
printf("CreateRestoreMap...DWORD %ld", CreateRestoreMap(argv[3], _wtoi(argv[4]), hFile));
CloseHandle(hFile);
}
else
printf("Error creating file");
break;
default:
PrintUsage();
goto done;
break;
}
done:
if (argv) hMem = GlobalHandle(argv);
if (hMem) GlobalFree(hMem);
}