5469 lines
192 KiB
C
5469 lines
192 KiB
C
//***************************************************************************
|
|
// Copyright (c) Microsoft Corporation
|
|
//
|
|
// Module Name:
|
|
// TAKEOWN.C
|
|
//
|
|
// Abstract:
|
|
// Implements a recovery scheme to give an Administrator
|
|
// access to a file that has been denied to all.
|
|
//
|
|
// Author:
|
|
// Wipro Technologies
|
|
//
|
|
// Revision History:
|
|
// Wipro Technologies 22-jun-01 : Created It.
|
|
//***************************************************************************
|
|
|
|
// Include files
|
|
#include "pch.h"
|
|
#include "takeown.h"
|
|
#include "resource.h"
|
|
#include "Lm.h"
|
|
//#include <malloc.h>
|
|
|
|
|
|
/*GLOBAL VARIABLES*/
|
|
|
|
PStore_Path_Name g_pPathName = NULL ; // Holds path name from where started .
|
|
PStore_Path_Name g_pFollowPathName = NULL ; // Holds information about a subdirectory .
|
|
LPTSTR g_lpszFileToSearch = NULL; // Holds information about directories and subdirectories .
|
|
|
|
|
|
DWORD
|
|
_cdecl _tmain(
|
|
IN DWORD argc,
|
|
IN LPCWSTR argv[]
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
Main function which calls all the other functions depending on the
|
|
option specified by the user.
|
|
|
|
Arguments:
|
|
[ IN ] argc - Number of command line arguments.
|
|
[ IN ] argv - Array containing command line arguments.
|
|
|
|
Return Value:
|
|
EXIT_FAILURE if takeown utility is not successful.
|
|
EXIT_SUCCESS if takeown utility is successful.
|
|
--*/
|
|
{
|
|
//local variables
|
|
BOOL bUsage = FALSE;
|
|
BOOL bFlag = FALSE;
|
|
BOOL bNeedPassword = FALSE;
|
|
BOOL bCloseConnection = FALSE;
|
|
BOOL bLocalSystem = FALSE;
|
|
BOOL bTakeOwnAllFiles = FALSE;
|
|
BOOL bCurrDirTakeOwnAllFiles = FALSE;
|
|
BOOL bDriveCurrDirTakeOwnAllFiles = FALSE;
|
|
BOOL bRecursive = FALSE;
|
|
BOOL bLogonDomainAdmin = FALSE;
|
|
BOOL bAdminsOwner = FALSE;
|
|
BOOL bFileInUNCFormat = FALSE;
|
|
BOOL bNTFSFileSystem = FALSE;
|
|
BOOL bMatchPattern = FALSE;
|
|
|
|
|
|
LPWSTR szUserName = NULL;
|
|
LPWSTR szPassword = NULL;
|
|
LPWSTR szMachineName = NULL;
|
|
LPWSTR wszPatternString = NULL;
|
|
LPWSTR szTmpFileName = NULL;
|
|
LPWSTR szDirTok = NULL;
|
|
LPWSTR szFileName = NULL;
|
|
LPWSTR szTemporaryFileName = NULL;
|
|
LPWSTR szTempPath = NULL;
|
|
LPTSTR szFilePart = NULL;
|
|
LPWSTR szFullPath = NULL;
|
|
LPWSTR szDispFileName = NULL;
|
|
|
|
WCHAR dwUserName[2 * MAX_STRING_LENGTH] ;
|
|
WCHAR szOwnerString[4 * MAX_STRING_LENGTH+5] ;
|
|
WCHAR ch = L'\\';
|
|
WCHAR szTempChar[20] ;
|
|
WCHAR szConfirm [MAX_CONFIRM_VALUE] ;
|
|
|
|
|
|
|
|
DWORD nSize1 = 4 * MAX_STRING_LENGTH + 5;
|
|
DWORD dwi = 0;
|
|
DWORD dwCount = 2;
|
|
DWORD dwFileCount = 0;
|
|
DWORD dwCnt = 0;
|
|
|
|
HRESULT hr;
|
|
|
|
SecureZeroMemory(dwUserName, (2 * MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
SecureZeroMemory(szOwnerString, (4 * MAX_STRING_LENGTH+5) * sizeof(WCHAR));
|
|
SecureZeroMemory(szTempChar, (20) * sizeof(WCHAR));
|
|
SecureZeroMemory(szConfirm, (MAX_CONFIRM_VALUE) * sizeof(WCHAR));
|
|
|
|
bFlag = ParseCmdLine( argc, argv, &szMachineName, &szUserName,
|
|
&szPassword, &szFileName, &bUsage, &bNeedPassword, &bRecursive, &bAdminsOwner, szConfirm);
|
|
|
|
//if syntax of command line arguments is false display the error
|
|
//and exit
|
|
if( FALSE == bFlag )
|
|
{
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
//if usage is specified at command line, display usage
|
|
if( TRUE == bUsage )
|
|
{
|
|
DisplayUsage();
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_SUCCESS );
|
|
}
|
|
|
|
|
|
if(0 == GetUserNameEx(NameSamCompatible, szOwnerString,&nSize1))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
/*Check whether the current logged on user is domain administrator or not*/
|
|
if( EXIT_FAIL == IsLogonDomainAdmin(szOwnerString,&bLogonDomainAdmin) )
|
|
{
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
/*If /a option is specified, before giving ownership to the administrators group, check whether current logged on user has administrative privileges or NOT*/
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
if(FALSE == IsUserAdmin())
|
|
{
|
|
ShowMessage( stderr, GetResString(IDS_NOT_ADMINISTRATOR ));
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
}
|
|
|
|
|
|
if( StringLengthW( szFileName, 0 ) > 3 )
|
|
{
|
|
|
|
if((szFileName[1] == L':') && ( SINGLE_QUOTE == szFileName[ 2 ] ) &&
|
|
( SINGLE_QUOTE == szFileName[ 3 ] ))
|
|
|
|
{
|
|
ShowMessage( stderr , ERROR_PATH_NAME ) ;
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
if(StringLengthW(szFileName, 0) != 0)
|
|
{
|
|
if(-1 != FindChar2((szFileName), L'?', TRUE, 0))
|
|
{
|
|
ShowMessage( stderr , ERROR_PATH_NAME ) ;
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
bLocalSystem = IsLocalSystem(IsUNCFormat(szMachineName) ? szMachineName+2:szMachineName);
|
|
|
|
if(TRUE == IsUNCFormat(szFileName))
|
|
{
|
|
bFileInUNCFormat = TRUE;
|
|
}
|
|
|
|
szTemporaryFileName = (LPWSTR)AllocateMemory((StringLengthW(szFileName, 0) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if(NULL == szTemporaryFileName)
|
|
{
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
//if remote machine establish connection
|
|
//if( FALSE == bLocalSystem && FALSE == bFileInUNCFormat)
|
|
if( FALSE == bLocalSystem )
|
|
{
|
|
//if remote machine and wild card then display error and exit
|
|
|
|
|
|
if( ( 1 == StringLengthW( szFileName, 0 ) ) && ( 0 == StringCompare( szFileName, WILDCARD, TRUE, 0 ) ) )
|
|
|
|
{
|
|
ShowMessage( stderr, ERROR_INVALID_WILDCARD );
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
//if remote machine establish connection
|
|
bFlag = EstablishConnection( szMachineName, (LPTSTR)szUserName,
|
|
GetBufferSize( szUserName ) / sizeof(WCHAR), (LPTSTR)szPassword,
|
|
GetBufferSize( szPassword ) / sizeof(WCHAR), bNeedPassword );
|
|
|
|
//failed to establish connection
|
|
if ( FALSE == bFlag )
|
|
{
|
|
// failed in establishing n/w connection
|
|
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowMessage( stderr, GetReason() );
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szPassword);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
switch( GetLastError() )
|
|
{
|
|
case I_NO_CLOSE_CONNECTION:
|
|
bCloseConnection = FALSE;
|
|
break;
|
|
case E_LOCAL_CREDENTIALS:
|
|
case ERROR_SESSION_CREDENTIAL_CONFLICT:
|
|
{
|
|
//
|
|
// some error occured ... but can be ignored
|
|
// connection need not be disconnected
|
|
bCloseConnection= FALSE;
|
|
// show the warning message
|
|
ShowLastErrorEx(stderr, SLE_TYPE_WARNING | SLE_SYSTEM);
|
|
break;
|
|
}
|
|
default:
|
|
bCloseConnection = TRUE;
|
|
}
|
|
|
|
FREE_MEMORY(szPassword);
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW(szMachineName, 0) + StringLengthW(szFileName, 0) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
if(FALSE == IsUNCFormat(szMachineName))
|
|
{
|
|
|
|
StringCopyW( szTmpFileName, DOUBLE_QUOTE, GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
|
|
StringConcat(szTmpFileName, szMachineName, GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
}
|
|
else
|
|
{
|
|
|
|
StringCopyW( szTmpFileName, szMachineName, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
}
|
|
|
|
|
|
StringConcat(szTmpFileName, L"\\", GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
|
|
if(FALSE == IsUNCFormat(szFileName))
|
|
{
|
|
|
|
|
|
StringCopyW( szTemporaryFileName, szFileName, GetBufferSize(szTemporaryFileName) / sizeof(WCHAR) );
|
|
|
|
if( szFileName[1] == COLON )
|
|
{
|
|
szFileName[1] = DOLLOR;
|
|
}
|
|
|
|
|
|
StringConcat(szTmpFileName, szFileName, GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
|
|
if( szFileName[1] == DOLLOR )
|
|
{
|
|
szFileName[1] = COLON;
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
szTempPath = wcsrchr(szFileName,COLON); //go from the reverse direction to check for ":" . Let \\server\c:\temp
|
|
|
|
if(NULL != szTempPath)
|
|
{
|
|
szTempPath--; //Go back reverse by one step..If :\temp is obtained , by this step , we get c:\temp
|
|
|
|
if(NULL != szTempPath)
|
|
{
|
|
//ShowMessage( stderr, GetResString(IDS_IGNORE_CREDENTIALS) );
|
|
|
|
StringCopyW( szTemporaryFileName, szTempPath, GetBufferSize(szTemporaryFileName) / sizeof(WCHAR) );
|
|
|
|
if( szTemporaryFileName[1] == COLON ) // change the " : " to " $ " , so , c$\temp
|
|
{
|
|
szTemporaryFileName[1] = DOLLOR;
|
|
}
|
|
szDirTok = wcstok(szFileName,L":"); // get the taken value , like \\server\c
|
|
|
|
StringCopyW( szTmpFileName, szDirTok, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
|
|
StringConcat(szTmpFileName, szTemporaryFileName+1, GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
//attach the value, say "$\temp" to \\server\c , so that the value becomes "\\server\c$\temp"
|
|
if( szTemporaryFileName[1] == DOLLOR )//convert back the original string from dollar to colon
|
|
{
|
|
szTemporaryFileName[1] = COLON;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//ShowMessage( stderr, GetResString(IDS_IGNORE_CREDENTIALS) );
|
|
|
|
StringCopyW( szTmpFileName, szFileName, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
FREE_MEMORY(szPassword);
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW(szFileName, 0) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
|
|
if( StringLengthW( szFileName, 0 ) == 2 && szFileName[0] == L'\\' && (szFileName[1] == L'\\' || szFileName[1] == L':') )
|
|
{
|
|
ShowMessage( stderr , ERROR_PATH_NAME ) ;
|
|
ReleaseGlobals();
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
if( (StringLengthW( szFileName, 0 )) > 2 )
|
|
{
|
|
if(( SINGLE_QUOTE == szFileName[ 0 ] ) &&
|
|
( SINGLE_QUOTE == szFileName[ 1 ] ))
|
|
{
|
|
szTempChar[0] = szFileName[2];
|
|
szTempChar[1] = L'\0';
|
|
if(wcspbrk(szTempChar, CHAR_SET2) != NULL)
|
|
{
|
|
|
|
DISPLAY_MESSAGE( stderr , ERROR_PATH_NAME ) ;
|
|
ReleaseGlobals();
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
if( NULL != FindString( ( szFileName + 2 ), DOUBLE_QUOTE, 0 ) )
|
|
{
|
|
DISPLAY_MESSAGE( stderr , ERROR_PATH_NAME ) ;
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
|
|
if( (StringLengthW( szFileName, 0 ) == 1) || (StringLengthW( szFileName, 0 ) == 2))
|
|
{
|
|
if(szFileName[0] == L':')
|
|
{
|
|
DISPLAY_MESSAGE( stderr , ERROR_PATH_NAME ) ;
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
}
|
|
|
|
if(TRUE == bFileInUNCFormat)
|
|
{
|
|
szTempPath = wcsrchr(szFileName,COLON);
|
|
|
|
if(NULL != szTempPath)
|
|
{
|
|
szTempPath--;
|
|
|
|
if(NULL != szTempPath)
|
|
{
|
|
|
|
|
|
StringCopyW( szTemporaryFileName, szTempPath, GetBufferSize(szTemporaryFileName) / sizeof(WCHAR) );
|
|
|
|
if( szTemporaryFileName[1] == COLON )
|
|
{
|
|
szTemporaryFileName[1] = DOLLOR;
|
|
}
|
|
szDirTok = wcstok(szFileName, L":");
|
|
|
|
StringCopyW( szTmpFileName, szDirTok, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
|
|
StringConcat(szTmpFileName, szTemporaryFileName+1, GetBufferSize(szTmpFileName) / sizeof(WCHAR));
|
|
if( szTemporaryFileName[1] == DOLLOR )
|
|
{
|
|
szTemporaryFileName[1] = COLON;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
|
|
StringCopyW( szTmpFileName, szFileName, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
StringCopyW( szTmpFileName, szFileName, GetBufferSize(szTmpFileName) / sizeof(WCHAR) );
|
|
}
|
|
|
|
|
|
if((StringLengthW( szTmpFileName, 0 )) > 2)
|
|
{
|
|
if(wcspbrk(szTmpFileName+2,CHAR_SET3) != NULL)
|
|
{
|
|
|
|
DISPLAY_MESSAGE( stderr , ERROR_PATH_NAME ) ;
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
}//end of else loop for (FALSE == BLocalSystem)
|
|
|
|
/*Check whether * is given in order to give ownership to all the files in the directory specicied or current directory*/
|
|
|
|
|
|
if((StringLengthW( szTmpFileName, 0 )) >= 2)
|
|
{
|
|
szTempPath = wcsrchr(szTmpFileName, ch);
|
|
if(szTempPath != NULL && (*(szTempPath + 1) != L'\0'))
|
|
{
|
|
|
|
if(*(szTempPath+1) == L'*')
|
|
{
|
|
for(dwCount;;dwCount++)
|
|
{
|
|
if(*(szTempPath + dwCount) != L'\0')
|
|
{
|
|
if(*(szTempPath + dwCount) != L'*')
|
|
{
|
|
bMatchPattern = TRUE;
|
|
wszPatternString = (LPWSTR)AllocateMemory((StringLengthW(szTempPath + 1, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == wszPatternString)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
StringCopyW(wszPatternString, szTempPath + 1, GetBufferSize(wszPatternString) / sizeof(WCHAR));
|
|
|
|
if(EXIT_FAILURE == RemoveStarFromPattern(wszPatternString))
|
|
{
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
szTempPath++; ////
|
|
*(szTempPath) = '\0';
|
|
bTakeOwnAllFiles = TRUE;
|
|
}
|
|
else
|
|
{
|
|
if(-1 != FindChar2((LPCWSTR)(szTempPath + 1), L'*', TRUE, 0) &&
|
|
(-1 == FindChar2((szTempPath + 1), L'?', TRUE, 0)))
|
|
{
|
|
bMatchPattern = TRUE;
|
|
wszPatternString = (LPWSTR)AllocateMemory((StringLengthW(szTempPath + 1, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == wszPatternString)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopyW(wszPatternString, szTempPath + 1, GetBufferSize(wszPatternString) / sizeof(WCHAR));
|
|
if(EXIT_FAILURE == RemoveStarFromPattern(wszPatternString))
|
|
{
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
szTempPath++;
|
|
*(szTempPath) = '\0';
|
|
bTakeOwnAllFiles = TRUE;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
dwCount = 0;
|
|
for(dwCount;;dwCount++)
|
|
{
|
|
if(*(szTmpFileName + dwCount) != L'\0')
|
|
{
|
|
if(*(szTmpFileName + dwCount) != L'*')
|
|
{
|
|
break;
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
bCurrDirTakeOwnAllFiles = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(bCurrDirTakeOwnAllFiles == FALSE)
|
|
{
|
|
dwCount = 2;
|
|
szTempPath = wcsrchr(szTmpFileName, COLON);
|
|
if(szTempPath != NULL)
|
|
{
|
|
if((*(szTempPath + 1) != L'\0') && (*(szTempPath + 1) == L'*'))
|
|
{
|
|
for(dwCount;;dwCount++)
|
|
{
|
|
if(*(szTempPath + dwCount) != L'\0')
|
|
{
|
|
if(*(szTempPath + dwCount) != L'*')
|
|
{
|
|
bMatchPattern = TRUE;
|
|
wszPatternString = (LPWSTR)AllocateMemory((StringLengthW(szTempPath + 1, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == wszPatternString)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopyW(wszPatternString, szTempPath + 1, GetBufferSize(wszPatternString) / sizeof(WCHAR));
|
|
if(EXIT_FAILURE == RemoveStarFromPattern(wszPatternString))
|
|
{
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
bDriveCurrDirTakeOwnAllFiles = TRUE;
|
|
break;
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
szTempPath++; ////
|
|
*(szTempPath) = L'\0';
|
|
|
|
bDriveCurrDirTakeOwnAllFiles = TRUE;
|
|
}
|
|
else
|
|
{
|
|
if((-1 != FindChar2((szTempPath + 1), L'*', TRUE, 0)) &&
|
|
(-1 == FindChar2((szTempPath + 1), L'?', TRUE, 0)))
|
|
{
|
|
bMatchPattern = TRUE;
|
|
wszPatternString = (LPWSTR)AllocateMemory((StringLengthW(szTempPath + 1, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == wszPatternString)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopyW(wszPatternString, szTempPath + 1, GetBufferSize(wszPatternString) / sizeof(WCHAR));
|
|
if(EXIT_FAILURE == RemoveStarFromPattern(wszPatternString))
|
|
{
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
szTempPath++;
|
|
*(szTempPath) = L'\0';
|
|
bDriveCurrDirTakeOwnAllFiles = TRUE;
|
|
}
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(-1 != FindChar2((szTmpFileName), L'*', TRUE, 0) &&
|
|
(-1 == FindChar2((szTmpFileName + 1), L'?', TRUE, 0)))
|
|
{
|
|
bMatchPattern = TRUE;
|
|
wszPatternString = (LPWSTR)AllocateMemory((StringLengthW(szTmpFileName + 1, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == wszPatternString)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopyW(wszPatternString, szTmpFileName, GetBufferSize(wszPatternString) / sizeof(WCHAR));
|
|
if(EXIT_FAILURE == RemoveStarFromPattern(wszPatternString))
|
|
{
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
bCurrDirTakeOwnAllFiles = TRUE;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if (1 == StringLengthW( szTmpFileName, 0 ) && 0 == StringCompare( szTmpFileName, WILDCARD, TRUE, 0 ))
|
|
{
|
|
bCurrDirTakeOwnAllFiles = TRUE;
|
|
}
|
|
|
|
if((TRUE == bLocalSystem) && (FALSE == bCurrDirTakeOwnAllFiles))
|
|
{
|
|
if(wcspbrk(szTmpFileName,CHAR_SET) != NULL)
|
|
{
|
|
|
|
DISPLAY_MESSAGE( stderr, ERROR_PATH_NAME ) ;
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
/*Get the full path in order to get the ownership for the specified file*/
|
|
|
|
if((FALSE == bCurrDirTakeOwnAllFiles) || (bDriveCurrDirTakeOwnAllFiles == TRUE ))
|
|
{
|
|
|
|
dwi = GetFullPathName( szTmpFileName, 0, szFullPath, &szFilePart );
|
|
|
|
if( 0 == dwi )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
szFullPath = (LPWSTR)AllocateMemory((dwi+10) * sizeof(WCHAR));// an additional ten bytes are added for safe side in order to avoid unexpected results
|
|
|
|
if(NULL == szFullPath)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
if( 0 == GetFullPathName( szTmpFileName,dwi+10, szFullPath, &szFilePart ))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
szDispFileName = (LPWSTR)AllocateMemory((dwi + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if(NULL == szDispFileName)
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
StringCopyW( szDispFileName, szFullPath, (GetBufferSize(szDispFileName) / sizeof(WCHAR)) );
|
|
|
|
}
|
|
/*Check whether the system is NTFS or not*/
|
|
dwCnt = 0;
|
|
|
|
//dwCnt = IsNTFSFileSystem(szDispFileName, bLocalSystem, bFileInUNCFormat, bCurrDirTakeOwnAllFiles, szUserName, &bNTFSFileSystem);
|
|
dwCnt = IsNTFSFileSystem(szDispFileName, bLocalSystem, bCurrDirTakeOwnAllFiles, szUserName, &bNTFSFileSystem);
|
|
if(EXIT_FAILURE == dwCnt )
|
|
{
|
|
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
if(FALSE == bNTFSFileSystem)
|
|
{
|
|
ShowMessage(stderr, GetResString(IDS_FAT_VOLUME));
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
|
|
if(TRUE == bRecursive)
|
|
{
|
|
|
|
if( EXIT_FAILURE == TakeOwnerShipRecursive(szDispFileName, bCurrDirTakeOwnAllFiles, bAdminsOwner, szOwnerString,
|
|
bTakeOwnAllFiles, bDriveCurrDirTakeOwnAllFiles,
|
|
bMatchPattern, wszPatternString, szConfirm))
|
|
{
|
|
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//if filename is wildcard then give owner ship to all the files in
|
|
//the current directory
|
|
if( (TRUE == bCurrDirTakeOwnAllFiles) || (TRUE == bTakeOwnAllFiles ) ||(bDriveCurrDirTakeOwnAllFiles == TRUE))
|
|
{
|
|
|
|
/*Get the ownership for all the files in the specified directory*/
|
|
|
|
bFlag = TakeOwnerShipAll(szDispFileName,bCurrDirTakeOwnAllFiles,&dwFileCount,bDriveCurrDirTakeOwnAllFiles,bAdminsOwner, szOwnerString, bMatchPattern, wszPatternString);
|
|
|
|
if( FALSE == bFlag )
|
|
{
|
|
switch ( GetLastError() )
|
|
{
|
|
case ERROR_ACCESS_DENIED :
|
|
|
|
ShowMessage(stderr,GetResString(IDS_ACCESS_DENIED_ERROR));
|
|
/*ShowMessage( stderr, L"( \"" );
|
|
ShowMessage( stderr, _X(szDispFileName) );
|
|
ShowMessage( stderr, L"\" )\n" ); */
|
|
break;
|
|
case ERROR_BAD_NET_NAME :
|
|
case ERROR_BAD_NETPATH :
|
|
case ERROR_INVALID_NAME :
|
|
SetLastError( ERROR_FILE_NOT_FOUND );
|
|
SaveLastError();
|
|
default :
|
|
if(FALSE == bMatchPattern)
|
|
{
|
|
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowMessage( stderr, GetReason() );
|
|
}
|
|
else
|
|
{
|
|
ShowMessage( stdout, GetResString(IDS_NO_PATTERN_FOUND));
|
|
}
|
|
|
|
}
|
|
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
|
|
ReleaseGlobals();
|
|
|
|
return( EXIT_FAILURE );
|
|
|
|
}
|
|
|
|
|
|
}
|
|
else // give ownership to the specified file
|
|
{
|
|
|
|
/*take the owner ship of the file specified for the administrators group or the current logged on user*/
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
bFlag = TakeOwnerShip( szDispFileName);
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
bFlag = TakeOwnerShipIndividual(szDispFileName);
|
|
|
|
}
|
|
|
|
if( FALSE == bFlag )
|
|
{
|
|
|
|
if( ERROR_NOT_ALL_ASSIGNED == GetLastError() )
|
|
{
|
|
|
|
hr = StringCchPrintf(szDispFileName, (GetBufferSize(szDispFileName) / sizeof(WCHAR)), GetResString(IDS_NOT_OWNERSHIP_ERROR) , szFullPath);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
ShowMessage(stderr, szDispFileName);
|
|
|
|
}
|
|
else if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
|
|
hr = StringCchPrintf(szDispFileName, (GetBufferSize(szDispFileName) / sizeof(WCHAR)), GetResString(IDS_SHARING_VIOLATION_ERROR) , szFullPath);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
ShowMessage(stderr, szDispFileName);
|
|
|
|
}
|
|
else
|
|
{
|
|
if( ( ERROR_BAD_NET_NAME == GetLastError() ) ||
|
|
( ERROR_BAD_NETPATH == GetLastError() ) ||
|
|
( ERROR_INVALID_NAME == GetLastError() ) )
|
|
{
|
|
SetLastError( ERROR_FILE_NOT_FOUND );
|
|
SaveLastError();
|
|
}
|
|
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowMessage( stderr, GetReason() );
|
|
}
|
|
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
//if connection is established to a remote machine close it
|
|
|
|
return( EXIT_FAILURE );
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
hr = StringCchPrintf(szDispFileName, (GetBufferSize(szDispFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL, szFullPath);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
//hr = StringCchPrintf(szDispFileName, (GetBufferSize(szDispFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szOwnerString, szFullPath);
|
|
hr = StringCchPrintf(szDispFileName, (GetBufferSize(szDispFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szFullPath, szOwnerString);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_FAILURE );
|
|
}
|
|
}
|
|
|
|
ShowMessage( stdout, _X(szDispFileName) );
|
|
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_SUCCESS );
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//if connection is established to a remote machine close it
|
|
if( TRUE == bCloseConnection )
|
|
{
|
|
CloseConnection( szMachineName );
|
|
}
|
|
|
|
FREE_MEMORY(szMachineName);
|
|
FREE_MEMORY(szUserName);
|
|
FREE_MEMORY(szFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szFullPath);
|
|
FREE_MEMORY(szDispFileName);
|
|
FREE_MEMORY(wszPatternString);
|
|
ReleaseGlobals();
|
|
return( EXIT_SUCCESS );
|
|
}
|
|
|
|
|
|
BOOL
|
|
ParseCmdLine(
|
|
IN DWORD argc,
|
|
IN LPCWSTR argv[],
|
|
OUT LPWSTR* szMachineName,
|
|
OUT LPWSTR* szUserName,
|
|
OUT LPWSTR* szPassword,
|
|
OUT LPWSTR* szFileName,
|
|
OUT BOOL *pbUsage,
|
|
OUT BOOL *pbNeedPassword,
|
|
OUT BOOL *pbRecursive,
|
|
OUT BOOL *pbAdminsOwner,
|
|
OUT LPWSTR szConfirm
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
This function parses the command line arguments which are obtained as input
|
|
parameters and gets the values into the corresponding variables which are
|
|
pass by reference parameters to this function.
|
|
|
|
Arguments:
|
|
[ IN ] argc - Number of command line arguments.
|
|
[ IN ] argv - Array containing command line arguments.
|
|
[ OUT ] szMachineName - To hold machine name.
|
|
[ OUT ] szUserName - To hold the User Name.
|
|
[ OUT ] szPassword - To hold the Password.
|
|
[ OUT ] szFileName - The filename whose attributes will be set.
|
|
[ OUT ] pbUsage - usage is mentioned at command line.
|
|
[ OUT ] pbNeedPassword - To know whether the password is required or not.
|
|
[ OUT ] pbRecursive - To know whether it is recursive or not.
|
|
[ OUT ] pbAdminsOwner - to know whether ownership to be given for administrators group
|
|
|
|
Return Value:
|
|
TRUE if command parser succeeds.
|
|
FALSE if command parser fails .
|
|
--*/
|
|
{
|
|
//local varibles
|
|
BOOL bFlag = FALSE;
|
|
TCMDPARSER2 tcmdOptions[MAX_OPTIONS];
|
|
|
|
//command line options
|
|
const WCHAR* wszCmdOptionUsage = L"?" ; //CMDOPTION_USAGE
|
|
const WCHAR* wszCmdOptionServer = L"S" ; //CMDOPTION_SERVER
|
|
const WCHAR* wszCmdOptionUser = L"U" ; //CMDOPTION_USER
|
|
const WCHAR* wszCmdOptionPassword = L"P" ; //CMDOPTION_PASSWORD
|
|
const WCHAR* wszCmdOptionFilename = L"F" ; //CMDOPTION_FILENAME
|
|
const WCHAR* wszCmdOptionRecurse = L"R" ; //CMDOPTION_RECURSE
|
|
const WCHAR* wszCmdOptionAdmin = L"A" ; //CMDOPTION_ADMIN
|
|
const WCHAR* wszCmdOptionDefault = L"D" ;
|
|
|
|
WCHAR wszConfirmValues[MAX_CONFIRM_VALUE] ;
|
|
|
|
SecureZeroMemory(wszConfirmValues, MAX_CONFIRM_VALUE * sizeof(WCHAR));
|
|
|
|
StringCopy(wszConfirmValues,GetResString(IDS_YESNO),SIZE_OF_ARRAY(wszConfirmValues));
|
|
|
|
|
|
|
|
//validate input parameters
|
|
if( ( NULL == pbUsage ) || ( NULL == pbNeedPassword ) )
|
|
{
|
|
SetLastError( (DWORD)E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowLastError( stderr );
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
//Initialize the valid command line arguments
|
|
|
|
// /s option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_SERVER].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwType = CP_TYPE_TEXT;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pwszOptions = wszCmdOptionServer;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwFlags = CP2_VALUE_TRIMINPUT | CP2_ALLOCMEMORY | CP2_VALUE_NONULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pValue = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwLength = 0;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_SERVER ].pReserved3 = NULL;
|
|
|
|
// /u option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_USER].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_USER ].dwType = CP_TYPE_TEXT;
|
|
tcmdOptions[ CMD_PARSE_USER ].pwszOptions = wszCmdOptionUser;
|
|
tcmdOptions[ CMD_PARSE_USER ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_USER ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_USER ].dwFlags = CP2_VALUE_TRIMINPUT | CP2_ALLOCMEMORY | CP2_VALUE_NONULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].pValue = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].dwLength = 0;
|
|
tcmdOptions[ CMD_PARSE_USER ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_USER ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_USER ].pReserved3 = NULL;
|
|
|
|
// /p option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_PWD].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwType = CP_TYPE_TEXT;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pwszOptions = wszCmdOptionPassword;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwFlags = CP2_VALUE_OPTIONAL | CP2_ALLOCMEMORY;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pValue = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwLength = 0;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_PWD ].pReserved3 = NULL;
|
|
|
|
// /? option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_USG].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_USG ].dwType = CP_TYPE_BOOLEAN;
|
|
tcmdOptions[ CMD_PARSE_USG ].pwszOptions = wszCmdOptionUsage;
|
|
tcmdOptions[ CMD_PARSE_USG ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_USG ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_USG ].dwFlags = CP2_USAGE;
|
|
tcmdOptions[ CMD_PARSE_USG ].pValue = pbUsage;
|
|
tcmdOptions[ CMD_PARSE_USG ].dwLength = MAX_STRING_LENGTH;
|
|
tcmdOptions[ CMD_PARSE_USG ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_USG ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_USG ].pReserved3 = NULL;
|
|
|
|
// /f name
|
|
StringCopyA( tcmdOptions[CMD_PARSE_FN].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_FN ].dwType = CP_TYPE_TEXT;
|
|
tcmdOptions[ CMD_PARSE_FN ].pwszOptions = wszCmdOptionFilename;
|
|
tcmdOptions[ CMD_PARSE_FN ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_FN ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_FN ].dwFlags = CP2_VALUE_TRIMINPUT | CP2_ALLOCMEMORY | CP2_VALUE_NONULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].pValue = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].dwLength = 0;
|
|
tcmdOptions[ CMD_PARSE_FN ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_FN ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_FN ].pReserved3 = NULL;
|
|
|
|
// /r option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_RECURSE].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwType = CP_TYPE_BOOLEAN;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pwszOptions = wszCmdOptionRecurse;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwFlags = 0;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pValue = pbRecursive;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwLength = MAX_STRING_LENGTH;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_RECURSE ].pReserved3 = NULL;
|
|
|
|
// /a option
|
|
StringCopyA( tcmdOptions[CMD_PARSE_ADMIN].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwType = CP_TYPE_BOOLEAN;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pwszOptions = wszCmdOptionAdmin;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pwszValues = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwFlags = 0;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pValue = pbAdminsOwner;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwLength = MAX_STRING_LENGTH;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_ADMIN ].pReserved3 = NULL;
|
|
|
|
StringCopyA( tcmdOptions[CMD_PARSE_CONFIRM].szSignature, "PARSER2\0", 8 );
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwType = CP_TYPE_TEXT;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pwszOptions = wszCmdOptionDefault;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pwszFriendlyName = NULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pwszValues = wszConfirmValues;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwCount = 1;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwActuals = 0;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwFlags = CP2_MODE_VALUES | CP2_VALUE_TRIMINPUT | CP2_VALUE_NONULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pValue = szConfirm;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwLength = MAX_CONFIRM_VALUE;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pFunction = NULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pFunctionData = NULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].dwReserved = 0;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pReserved1 = NULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pReserved2 = NULL;
|
|
tcmdOptions[ CMD_PARSE_CONFIRM ].pReserved3 = NULL;
|
|
|
|
//parse the command line arguments
|
|
bFlag = DoParseParam2( argc, argv, -1, SIZE_OF_ARRAY( tcmdOptions ), tcmdOptions, 0 );
|
|
|
|
//if syntax of command line arguments is false display the error and exit
|
|
if( FALSE == bFlag )
|
|
{
|
|
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowMessage( stderr, GetReason() );
|
|
return( FALSE );
|
|
}
|
|
|
|
*szMachineName = (LPWSTR)tcmdOptions[CMD_PARSE_SERVER].pValue;
|
|
*szUserName = (LPWSTR)tcmdOptions[CMD_PARSE_USER].pValue;
|
|
*szPassword = (LPWSTR)tcmdOptions[CMD_PARSE_PWD].pValue;
|
|
*szFileName = (LPWSTR)tcmdOptions[CMD_PARSE_FN].pValue;
|
|
|
|
|
|
// remove trialing spaces
|
|
|
|
//if usage is specified at command line, then check whether any other
|
|
//arguments are entered at the command line and if so display syntax
|
|
//error
|
|
if( TRUE == *pbUsage )
|
|
{
|
|
if( argc > 2 )
|
|
{
|
|
ShowMessage( stderr, ERROR_SYNTAX_ERROR );
|
|
return( FALSE );
|
|
}
|
|
else
|
|
{
|
|
return (TRUE);
|
|
}
|
|
}
|
|
|
|
// check whether the password (-p) specified in the command line or not
|
|
// and also check whether '*' or empty is given for -p or not
|
|
// check the remote connectivity information
|
|
if ( *szMachineName != NULL )
|
|
{
|
|
//
|
|
// if -u is not specified, we need to allocate memory
|
|
// in order to be able to retrive the current user name
|
|
//
|
|
// case 1: -p is not at all specified
|
|
// as the value for this switch is optional, we have to rely
|
|
// on the dwActuals to determine whether the switch is specified or not
|
|
// in this case utility needs to try to connect first and if it fails
|
|
// then prompt for the password -- in fact, we need not check for this
|
|
// condition explicitly except for noting that we need to prompt for the
|
|
// password
|
|
//
|
|
// case 2: -p is specified
|
|
// but we need to check whether the value is specified or not
|
|
// in this case user wants the utility to prompt for the password
|
|
// before trying to connect
|
|
//
|
|
// case 3: -p * is specified
|
|
|
|
// user name
|
|
if ( *szUserName == NULL )
|
|
{
|
|
*szUserName = (LPWSTR) AllocateMemory( MAX_STRING_LENGTH * sizeof( WCHAR ) );
|
|
if ( *szUserName == NULL )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
// password
|
|
if ( *szPassword == NULL )
|
|
{
|
|
*pbNeedPassword = TRUE;
|
|
*szPassword = (LPWSTR)AllocateMemory( MAX_STRING_LENGTH * sizeof( WCHAR ) );
|
|
if ( *szPassword == NULL )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
// case 1
|
|
/*if ( cmdOptions[OPTION_PASSWORD].dwActuals == 0 )
|
|
{
|
|
// we need not do anything special here
|
|
}*/
|
|
if ( tcmdOptions[CMD_PARSE_PWD].pValue == NULL )
|
|
{
|
|
StringCopy( *szPassword, L"*", GetBufferSize((LPVOID)(*szPassword)));
|
|
}
|
|
else
|
|
if ( StringCompareEx( *szPassword, L"*", TRUE, 0 ) == 0 )
|
|
{
|
|
if ( ReallocateMemory( (LPVOID*)(szPassword),
|
|
MAX_STRING_LENGTH * sizeof( WCHAR ) ) == FALSE )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return( FALSE );
|
|
}
|
|
else
|
|
if(NULL == szPassword)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return( FALSE );
|
|
}
|
|
|
|
// ...
|
|
*pbNeedPassword = TRUE;
|
|
}
|
|
|
|
// case 3
|
|
|
|
}
|
|
|
|
|
|
if((0 != tcmdOptions[ CMD_PARSE_CONFIRM ].dwActuals ) && (0 == tcmdOptions[ CMD_PARSE_RECURSE ].dwActuals ) )
|
|
{
|
|
ShowMessage( stderr, GetResString(IDS_CONFIRM_ERROR ));
|
|
return( FALSE );
|
|
}
|
|
|
|
|
|
if( (StringLengthW(*szFileName, 0) == 0 ) && (0 != tcmdOptions[ CMD_PARSE_FN ].dwActuals ) )
|
|
{
|
|
ShowMessage( stderr, GetResString(IDS_NULL_FILENAME ));
|
|
return( FALSE );
|
|
}
|
|
|
|
//if default argument is not speciifed
|
|
if( ( 0 == tcmdOptions[ CMD_PARSE_FN ].dwActuals ) &&
|
|
( FALSE == *pbUsage ) )
|
|
{
|
|
ShowMessage( stderr, ERROR_SYNTAX_ERROR );
|
|
return( FALSE );
|
|
}
|
|
|
|
// return false if username is entered without machine name
|
|
if ( ( 0 != tcmdOptions[ CMD_PARSE_USER ].dwActuals ) &&
|
|
( 0 == tcmdOptions[ CMD_PARSE_SERVER ].dwActuals ) )
|
|
{
|
|
ShowMessage( stderr, ERROR_USER_WITH_NOSERVER );
|
|
return( FALSE );
|
|
}
|
|
|
|
//if password entered without username then return false
|
|
if( ( 0 == tcmdOptions[ CMD_PARSE_USER ].dwActuals ) &&
|
|
( 0 != tcmdOptions[ CMD_PARSE_PWD ].dwActuals ) )
|
|
{
|
|
ShowMessage( stderr, ERROR_PASSWORD_WITH_NUSER );
|
|
return( FALSE );
|
|
}
|
|
|
|
//if /s is entered with empty string
|
|
if( ( 0 != tcmdOptions[ CMD_PARSE_SERVER ].dwActuals != 0 ) &&
|
|
( 0 == StringLengthW( *szMachineName, 0 ) ) )
|
|
//( 0 == lstrlen( szMachineName ) ) )
|
|
{
|
|
ShowMessage( stderr, ERROR_NULL_SERVER );
|
|
return( FALSE );
|
|
}
|
|
|
|
//if /u is entered with empty string
|
|
if( ( 0 != tcmdOptions[ CMD_PARSE_USER ].dwActuals ) &&
|
|
( 0 == StringLengthW( *szUserName, 0 ) ) )
|
|
|
|
{
|
|
ShowMessage( stderr, ERROR_NULL_USER );
|
|
return( FALSE );
|
|
}
|
|
|
|
//assign the data obtained from parsing to the call by address parameters
|
|
|
|
|
|
if ( ( 0 != tcmdOptions[ CMD_PARSE_PWD ].dwActuals ) &&
|
|
( 0 == StringCompare( *szPassword, L"*", TRUE, 0 ) ) )
|
|
|
|
{
|
|
// user wants the utility to prompt for the password before trying to connect
|
|
*pbNeedPassword = TRUE;
|
|
}
|
|
else if ( 0 == tcmdOptions[ CMD_PARSE_PWD ].dwActuals &&
|
|
( 0 != tcmdOptions[ CMD_PARSE_SERVER ].dwActuals || 0 != tcmdOptions[ CMD_PARSE_USER ].dwActuals ) )
|
|
{
|
|
// /s, /u is specified without password ...
|
|
// utility needs to try to connect first and if it fails then prompt for the password
|
|
*pbNeedPassword = TRUE;
|
|
|
|
StringCopyW( *szPassword, NULL_U_STRING, GetBufferSize(*szPassword) / sizeof(WCHAR));
|
|
}
|
|
|
|
return( TRUE );
|
|
}
|
|
|
|
VOID
|
|
DisplayUsage(
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
This function displays the usage of takeown utility.
|
|
|
|
Arguments:
|
|
None.
|
|
|
|
Return Value:
|
|
VOID
|
|
--*/
|
|
{
|
|
DWORD dwIndex = 0;
|
|
//redirect the usage to the console
|
|
for( dwIndex = IDS_USAGE_BEGINING; dwIndex <= IDS_USAGE_ENDING; dwIndex++ )
|
|
{
|
|
ShowMessage( stdout, GetResString( dwIndex ) );
|
|
}
|
|
return;
|
|
}
|
|
|
|
BOOL
|
|
TakeOwnerShip(
|
|
IN LPCWSTR lpszFileName
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
This routine takes the ownership of the specified file
|
|
|
|
Arguments:
|
|
[ IN ] lpszFileName - File name for whose ownership has to be taken.
|
|
|
|
Return Value:
|
|
TRUE if owner ship of the specified file has been taken
|
|
else FALSE
|
|
--*/
|
|
{
|
|
//local variables
|
|
SECURITY_DESCRIPTOR SecurityDescriptor;
|
|
PSECURITY_DESCRIPTOR pSd = NULL;
|
|
PACL pDacl;
|
|
HANDLE hFile;
|
|
PSID pAliasAdminsSid = NULL;
|
|
SID_IDENTIFIER_AUTHORITY SepNtAuthority = SECURITY_NT_AUTHORITY;
|
|
|
|
HANDLE hTokenHandle = NULL;
|
|
BOOL bResult = TRUE;
|
|
BOOL bInvalidFileHandle = FALSE;
|
|
|
|
//check for valid input parameters
|
|
if( lpszFileName == NULL )
|
|
{
|
|
SetLastError( (DWORD) E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
//allocate and initialise sid
|
|
bResult = AllocateAndInitializeSid(
|
|
&SepNtAuthority,
|
|
2,
|
|
SECURITY_BUILTIN_DOMAIN_RID,
|
|
DOMAIN_ALIAS_RID_ADMINS,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
&pAliasAdminsSid
|
|
);
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
return( FALSE );
|
|
}
|
|
|
|
//get the token of the current process
|
|
bResult = GetTokenHandle( &hTokenHandle );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
|
|
// Attempt to put a NULL Dacl on the object
|
|
bResult = InitializeSecurityDescriptor( &SecurityDescriptor,
|
|
SECURITY_DESCRIPTOR_REVISION );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
if( 0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
return( FALSE );
|
|
}
|
|
//Get the handle of the file or directory
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
|
|
//try once again it may be a directory
|
|
if( INVALID_HANDLE_VALUE != hFile )
|
|
{
|
|
//get the DACL for the currently existing file or directory
|
|
if( 0 != GetSecurityInfo( hFile, SE_FILE_OBJECT, DACL_SECURITY_INFORMATION, NULL,
|
|
NULL, &pDacl, NULL, &pSd ) )
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
return( FALSE );
|
|
}
|
|
|
|
// set the security descriptor to acl
|
|
bResult = SetSecurityDescriptorDacl ( &SecurityDescriptor,
|
|
TRUE, pDacl, FALSE );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
return( FALSE );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
bInvalidFileHandle = TRUE;
|
|
|
|
}
|
|
|
|
// Attempt to make Administrator the owner of the file.
|
|
|
|
bResult = SetSecurityDescriptorOwner ( &SecurityDescriptor,
|
|
pAliasAdminsSid, FALSE );
|
|
|
|
|
|
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
return( FALSE );
|
|
}
|
|
|
|
//set the file security to adminsitrator owner
|
|
bResult = SetFileSecurity( lpszFileName, OWNER_SECURITY_INFORMATION,
|
|
&SecurityDescriptor );
|
|
|
|
if( TRUE == bResult )
|
|
{
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( TRUE );
|
|
}
|
|
|
|
// Assert TakeOwnership privilege for current process, then try again
|
|
bResult = AssertTakeOwnership( hTokenHandle );
|
|
|
|
if( FALSE == bResult )
|
|
{
|
|
//SaveLastError();
|
|
if(TRUE == bInvalidFileHandle)
|
|
{
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
if( INVALID_HANDLE_VALUE == hFile )
|
|
{
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
//CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
//Now try to set ownership security privilege for the file
|
|
bResult = SetFileSecurity( lpszFileName, OWNER_SECURITY_INFORMATION,
|
|
&SecurityDescriptor );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
if(TRUE == bInvalidFileHandle)
|
|
{
|
|
//Check out whether it is an invalid file or file does not exist
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
if( INVALID_HANDLE_VALUE == hFile )
|
|
{
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
//CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
return( FALSE );
|
|
}
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
|
|
CloseHandle( hFile );
|
|
|
|
if(0 == CloseHandle( hTokenHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
return( TRUE );
|
|
}
|
|
|
|
BOOL
|
|
GetTokenHandle(
|
|
OUT PHANDLE hTokenHandle
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
Get the token handle of the current process.
|
|
|
|
Arguments:
|
|
[ OUT ] hTokenHandle - handle to the current token.
|
|
|
|
Return Value:
|
|
TRUE if successful in getting the token
|
|
else FALSE
|
|
--*/
|
|
{
|
|
//local variables
|
|
BOOL bFlag = TRUE;
|
|
HANDLE hProcessHandle = NULL;
|
|
|
|
//check for valid input arguments
|
|
if( hTokenHandle == NULL )
|
|
{
|
|
SetLastError( (DWORD) E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
//open the current process
|
|
hProcessHandle = OpenProcess( PROCESS_QUERY_INFORMATION,
|
|
FALSE, GetCurrentProcessId() );
|
|
|
|
//if unable to open the current process
|
|
if ( NULL == hProcessHandle )
|
|
{
|
|
SaveLastError();
|
|
return( FALSE );
|
|
}
|
|
|
|
//open the token of the current process
|
|
bFlag = OpenProcessToken ( hProcessHandle,
|
|
TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY,
|
|
hTokenHandle );
|
|
|
|
if ( FALSE == bFlag )
|
|
{
|
|
SaveLastError();
|
|
CloseHandle( hProcessHandle );
|
|
return FALSE;
|
|
}
|
|
if( 0 == CloseHandle( hProcessHandle ))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
return( TRUE );
|
|
}
|
|
|
|
BOOL
|
|
AssertTakeOwnership(
|
|
IN HANDLE hTokenHandle
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
This routine asserts the takeownership privilege to the current process
|
|
|
|
Arguments:
|
|
[ IN ] hTokenHandle - Token handle of the current process.
|
|
|
|
Return Value:
|
|
TRUE if successful in asserting the takeownership privilege to current process
|
|
else FALSE
|
|
--*/
|
|
{
|
|
//local variables
|
|
LUID TakeOwnershipValue;
|
|
TOKEN_PRIVILEGES TokenPrivileges;
|
|
BOOL bResult = TRUE;
|
|
|
|
|
|
//check for valid input arguments
|
|
if( hTokenHandle == NULL )
|
|
{
|
|
SetLastError( (DWORD) E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
// First, assert TakeOwnership privilege
|
|
bResult = LookupPrivilegeValue( NULL, SE_TAKE_OWNERSHIP_NAME,
|
|
&TakeOwnershipValue );
|
|
if ( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
return( FALSE );
|
|
}
|
|
|
|
// Set up the privilege set we will need
|
|
TokenPrivileges.PrivilegeCount = 1;
|
|
TokenPrivileges.Privileges[0].Luid = TakeOwnershipValue;
|
|
TokenPrivileges.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
|
|
|
|
//adjust the privlige to this new privilege
|
|
(VOID) AdjustTokenPrivileges (
|
|
hTokenHandle,
|
|
FALSE,
|
|
&TokenPrivileges,
|
|
sizeof( TOKEN_PRIVILEGES ),
|
|
NULL,
|
|
NULL
|
|
);
|
|
|
|
if ( NO_ERROR != GetLastError() )
|
|
{
|
|
SaveLastError();
|
|
return( FALSE );
|
|
}
|
|
return( TRUE );
|
|
}
|
|
|
|
BOOL
|
|
TakeOwnerShipAll(IN LPWSTR lpszFileName,
|
|
IN BOOL bCurrDirTakeOwnAllFiles,
|
|
IN PDWORD dwFileCount,
|
|
IN BOOL bDriveCurrDirTakeOwnAllFiles,
|
|
IN BOOL bAdminsOwner,
|
|
IN LPWSTR szOwnerString,
|
|
BOOL bMatchPattern,
|
|
LPWSTR wszPatternString)
|
|
|
|
|
|
/*++
|
|
Routine Description:
|
|
This routine takes the owner ship of the all the files in the
|
|
current directory
|
|
|
|
Arguments:
|
|
[ IN ] lpszFileName : The path name to which ownership for the files in the path to be given
|
|
[ IN ] bCurrDirTakeOwnAllFiles : To determine whether ownership to be given for current directory files
|
|
[ IN ] dwFileCount : To determine whether there is not even a sigle file found in the specified path
|
|
[ IN ] bDriveCurrDirTakeOwnAllFiles : To determine whether ownership to be given for files specified in the path
|
|
[ IN ] bAdminsOwner : To ddetermine whether ownership to be given for administrators group
|
|
[ IN ] dwUserName : Logged on user name
|
|
[ IN ] szOwnerString : Logged on user name in Sam Compatible format
|
|
[ IN ] bLogonDomainAdmin : Indicates whether the logged on user is domain administrator or not
|
|
|
|
|
|
Return Value:
|
|
TRUE if owner ship of the files in the current directory is successful
|
|
else FALSE
|
|
--*/
|
|
{
|
|
//local variables
|
|
WIN32_FIND_DATA FindFileData;
|
|
BOOL bFlag = TRUE;
|
|
DWORD dwRet = 0;
|
|
HANDLE hHandle = NULL;
|
|
WCHAR szFileName[MAX_RES_STRING + 3*EXTRA_MEM] ;
|
|
WCHAR wszTempMessage[3*MAX_STRING_LENGTH] ;
|
|
|
|
LPWSTR szDir = NULL;
|
|
LPWSTR szTakeownFile = NULL;
|
|
LPWSTR szTmpFileName = NULL;
|
|
LPWSTR wszFormedMessage = NULL;
|
|
LPWSTR lpNextTok = NULL;
|
|
//LPWSTR szDirStart = NULL;
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
|
|
SecureZeroMemory(szFileName, (MAX_RES_STRING + 3*EXTRA_MEM) * sizeof(WCHAR));
|
|
SecureZeroMemory(wszTempMessage, (3 * MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if(FALSE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
|
|
//ASSIGN_MEMORY(szDir,WCHAR,(StringLengthW(lpszFileName, 0)) + 20);
|
|
szDir = (LPWSTR)AllocateMemory((StringLengthW(lpszFileName, 0) + 20) * sizeof(WCHAR));
|
|
if(NULL == szDir)
|
|
{
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
szTakeownFile = (LPWSTR)AllocateMemory((StringLengthW(lpszFileName, 0) + MAX_STRING_LENGTH + 20) * sizeof(WCHAR));
|
|
if(NULL == szTakeownFile)
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
return FALSE;
|
|
}
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW(lpszFileName, 0) + (2 * MAX_STRING_LENGTH) + 20) * sizeof(WCHAR));
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if(TRUE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
dwRet = GetCurrentDirectory( 0, szDir );
|
|
if( 0 == dwRet )
|
|
{
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
szDir = (LPWSTR)AllocateMemory((dwRet + 20) * sizeof(WCHAR));
|
|
if(NULL == szDir)
|
|
{
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
dwRet = GetCurrentDirectory( dwRet + 20, szDir );
|
|
if( 0 == dwRet )
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
return FALSE;
|
|
}
|
|
|
|
szTakeownFile = (LPWSTR)AllocateMemory((StringLengthW(szDir, 0) + MAX_STRING_LENGTH + 20) * sizeof(WCHAR));
|
|
|
|
if(NULL == szTakeownFile)
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
return FALSE;
|
|
}
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW(szDir, 0) + (2 * MAX_STRING_LENGTH) + 20) * sizeof(WCHAR));
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
return FALSE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
StringCopy( szDir, lpszFileName, (GetBufferSize(szDir) / sizeof(WCHAR)) );
|
|
|
|
}
|
|
/*Attach "*.*" at the end of the path to get all the files*/
|
|
|
|
|
|
if(StringLengthW(szDir, 0) != 0 && FALSE == bMatchPattern)
|
|
{
|
|
if( *(szDir + StringLengthW(szDir, 0) - 1) != L'\\' )
|
|
{
|
|
|
|
StringConcat(szDir, ALL_FILES, GetBufferSize(szDir)/sizeof(TCHAR));
|
|
}
|
|
else
|
|
{
|
|
|
|
StringConcat(szDir,L"*.*" , (GetBufferSize(szDir) / sizeof(WCHAR)));
|
|
}
|
|
}
|
|
else
|
|
{
|
|
StringConcat(szDir, L"\\", (GetBufferSize(szDir) / sizeof(WCHAR)));
|
|
StringConcat(szDir, wszPatternString, (GetBufferSize(szDir) / sizeof(WCHAR)));
|
|
}
|
|
|
|
if( INVALID_HANDLE_VALUE != ( hHandle = FindFirstFile( szDir, &FindFileData ) ) )
|
|
{
|
|
|
|
StringCopy( szFileName, FindFileData.cFileName, SIZE_OF_ARRAY(szFileName) );
|
|
|
|
|
|
if( ( 0 != StringCompare( szFileName, DOT, TRUE, 0 ) ) &&
|
|
( 0 != StringCompare( szFileName, DOTS, TRUE, 0 ) ) )
|
|
{
|
|
(*dwFileCount)= (*dwFileCount) + 1;
|
|
|
|
if(FALSE == bCurrDirTakeOwnAllFiles && FALSE == bDriveCurrDirTakeOwnAllFiles)
|
|
{
|
|
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s%s", lpszFileName,szFileName);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return FALSE;
|
|
}
|
|
|
|
}
|
|
else
|
|
if(TRUE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
|
|
StringCopy( szTakeownFile, szFileName, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)) );
|
|
}
|
|
else
|
|
{
|
|
if( *(lpszFileName + StringLengthW(lpszFileName, 0) - 1) != L'\\' )
|
|
{
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s\\%s", lpszFileName,szFileName);
|
|
}
|
|
else
|
|
{
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s%s", lpszFileName,szFileName);
|
|
}
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
bFlag = TakeOwnerShip( szTakeownFile);
|
|
}
|
|
else
|
|
{
|
|
|
|
bFlag = TakeOwnerShipIndividual(szTakeownFile);
|
|
}
|
|
|
|
if( FALSE == bFlag )
|
|
{
|
|
if( ERROR_NOT_ALL_ASSIGNED == GetLastError())
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_NOT_OWNERSHIP_INFO), szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
}
|
|
else if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_SHARING_VIOLATION_INFO) , szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
}
|
|
else
|
|
{
|
|
|
|
wszFormedMessage = (LPWSTR)AllocateMemory((StringLengthW(szTakeownFile, 0) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if ( wszFormedMessage == NULL )
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
//lstrcpy(wszTempMessage, GetReason());
|
|
StringCopy( wszTempMessage, GetReason(), SIZE_OF_ARRAY(wszTempMessage) );
|
|
lpNextTok = _tcstok(wszTempMessage, L".");
|
|
ShowMessage(stdout,wszTempMessage);
|
|
|
|
//hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), GetResString(IDS_ON_FILE_FOLDER), szTakeownFile);
|
|
hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), L". ( \"%s\" )\n", szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
ShowMessage(stderr, wszFormedMessage);
|
|
FREE_MEMORY(wszFormedMessage);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL, szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
//hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szOwnerString, szTakeownFile);
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szTakeownFile, szOwnerString);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
ShowMessage( stdout, _X(szTmpFileName) );
|
|
}
|
|
}
|
|
|
|
bFlag = FindNextFile( hHandle, &FindFileData );
|
|
while( TRUE == bFlag )
|
|
{
|
|
//lstrcpy( szFileName, FindFileData.cFileName );
|
|
StringCopy( szFileName, FindFileData.cFileName, SIZE_OF_ARRAY(szFileName) );
|
|
//if ( ( 0 != lstrcmp( szFileName, DOT ) ) &&
|
|
// ( 0 != lstrcmp( szFileName, DOTS ) ) )
|
|
if ( ( 0 != StringCompare( szFileName, DOT, TRUE, 0 ) ) &&
|
|
( 0 != StringCompare( szFileName, DOTS, TRUE, 0 ) ) )
|
|
{
|
|
(*dwFileCount)= (*dwFileCount) +1;
|
|
if(FALSE == bCurrDirTakeOwnAllFiles && FALSE == bDriveCurrDirTakeOwnAllFiles)
|
|
{
|
|
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s%s", lpszFileName,szFileName);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return FALSE;
|
|
}
|
|
|
|
}
|
|
else
|
|
if(TRUE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
|
|
StringCopy( szTakeownFile, szFileName, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)) );
|
|
}
|
|
else
|
|
{
|
|
|
|
if( *(lpszFileName + StringLengthW(lpszFileName, 0) - 1) != L'\\' )
|
|
{
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s\\%s", lpszFileName,szFileName);
|
|
}
|
|
else
|
|
{
|
|
hr = StringCchPrintf(szTakeownFile, (GetBufferSize(szTakeownFile) / sizeof(WCHAR)), L"%s%s", lpszFileName,szFileName);
|
|
}
|
|
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
bFlag = TakeOwnerShip( szTakeownFile);
|
|
}
|
|
else
|
|
{
|
|
|
|
bFlag = TakeOwnerShipIndividual(szTakeownFile);
|
|
}
|
|
|
|
if( FALSE == bFlag )
|
|
{
|
|
|
|
if( ( GetLastError() == ERROR_NOT_ALL_ASSIGNED ))
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_NOT_OWNERSHIP_INFO), szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
|
|
}
|
|
else if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_SHARING_VIOLATION_INFO), szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
}
|
|
else
|
|
{
|
|
if( ( ERROR_BAD_NET_NAME == GetLastError() ) ||
|
|
( ERROR_BAD_NETPATH == GetLastError() ) ||
|
|
( ERROR_INVALID_NAME == GetLastError() ) )
|
|
{
|
|
SetLastError( ERROR_FILE_NOT_FOUND );
|
|
SaveLastError();
|
|
}
|
|
|
|
|
|
wszFormedMessage = (LPWSTR)AllocateMemory((StringLengthW(szTakeownFile, 0) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if ( wszFormedMessage == NULL )
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage( stdout, L"\n" );
|
|
ShowMessage( stdout, TAG_INFORMATION );
|
|
ShowMessage( stdout, SPACE_CHAR );
|
|
|
|
StringCopy( wszTempMessage, GetReason(), SIZE_OF_ARRAY(wszTempMessage) );
|
|
lpNextTok = _tcstok(wszTempMessage, L".");
|
|
ShowMessage(stdout,wszTempMessage);
|
|
|
|
//hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), GetResString(IDS_ON_FILE_FOLDER), szTakeownFile);
|
|
|
|
hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), L". ( \"%s\" )\n", szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
ShowMessage(stdout, wszFormedMessage);
|
|
FREE_MEMORY(wszFormedMessage);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL, szTakeownFile);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
//hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szOwnerString, szTakeownFile);
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szTakeownFile, szOwnerString);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
ShowMessage( stdout, _X(szTmpFileName) );
|
|
}
|
|
}
|
|
|
|
bFlag = FindNextFile( hHandle, &FindFileData );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( FALSE );
|
|
}
|
|
|
|
if(0 == *dwFileCount)
|
|
{
|
|
if(FALSE == bMatchPattern)
|
|
{
|
|
ShowMessage( stdout, GetResString(IDS_NO_FILES_AVAILABLE));
|
|
}
|
|
else
|
|
{
|
|
ShowMessage( stdout, GetResString(IDS_NO_PATTERN_FOUND));
|
|
}
|
|
}
|
|
|
|
CLOSE_FILE_HANDLE( hHandle ) ;
|
|
FREE_MEMORY(szDir);
|
|
FREE_MEMORY(szTakeownFile);
|
|
FREE_MEMORY(szTmpFileName);
|
|
return( TRUE );
|
|
}
|
|
|
|
|
|
DWORD
|
|
IsLogonDomainAdmin(IN LPWSTR szOwnerString,
|
|
OUT PBOOL pbLogonDomainAdmin)
|
|
/*++
|
|
Routine Description:
|
|
This function Checks whether the logged on user is domain administrator or not
|
|
|
|
Arguments:
|
|
[ IN ] szOwnerString : The logged on user
|
|
[ OUT ] pbLogonDomainAdmin: Indicates whether Domain admin or not
|
|
|
|
Return Value:
|
|
EXIT_FAIL : On failure
|
|
EXIT_SUCC : On success
|
|
--*/
|
|
|
|
{
|
|
WCHAR szSystemName[MAX_SYSTEMNAME] = NULL_U_STRING;
|
|
WCHAR szOwnerStringTemp[(2 * MAX_STRING_LENGTH) + 5] = NULL_U_STRING;
|
|
DWORD dwMemory = MAX_SYSTEMNAME;
|
|
LPWSTR szToken = NULL;
|
|
|
|
|
|
SecureZeroMemory(szSystemName, MAX_SYSTEMNAME * sizeof(WCHAR));
|
|
SecureZeroMemory(szOwnerStringTemp, ((2 * MAX_STRING_LENGTH) + 5) * sizeof(WCHAR));
|
|
|
|
StringCopy( szOwnerStringTemp, szOwnerString, SIZE_OF_ARRAY(szOwnerStringTemp) );
|
|
|
|
if( 0 == GetComputerName(szSystemName,&dwMemory))
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
return EXIT_FAIL;
|
|
}
|
|
|
|
szToken = wcstok(szOwnerStringTemp,L"\\");
|
|
|
|
if(NULL == szToken )
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
SetLastError(IDS_INVALID_USERNAME);
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAIL;
|
|
}
|
|
|
|
//if(lstrcmpi(szSystemName,szToken) == 0 )
|
|
if(StringCompare( szSystemName, szToken, TRUE, 0 ) == 0 )
|
|
{
|
|
|
|
*pbLogonDomainAdmin = FALSE;
|
|
}
|
|
else
|
|
{
|
|
*pbLogonDomainAdmin = TRUE;
|
|
}
|
|
|
|
return EXIT_SUCC;
|
|
}
|
|
|
|
|
|
BOOL
|
|
TakeOwnerShipRecursive(IN LPWSTR lpszFileName,
|
|
IN BOOL bCurrDirTakeOwnAllFiles,
|
|
IN BOOL bAdminsOwner,
|
|
IN LPWSTR szOwnerString,
|
|
IN BOOL bTakeOwnAllFiles,
|
|
IN BOOL bDriveCurrDirTakeOwnAllFiles,
|
|
IN BOOL bMatchPattern,
|
|
IN LPWSTR wszPatternString,
|
|
IN LPWSTR szConfirm)
|
|
/*++
|
|
Routine Description:
|
|
This function gives ownership recursively to all the files in the path specified
|
|
|
|
Arguments:
|
|
[ IN ] lpszFileName : The path to search the files recursively
|
|
[ IN ] bCurrDirTakeOwnAllFiles: Indicates current directory files or not
|
|
[ IN ] bAdminsOwner : Indicates whether to give ownership to the administrators group
|
|
[ IN ] dwUserName : Logged on user name
|
|
[ IN ] szOwnerString : Logged on user name in Sam Compatible format
|
|
[ IN ] bLogonDomainAdmin : Indicates whether the logged on user is domain administrator or not
|
|
|
|
Return Value:
|
|
EXIT_FAILURE : On failure
|
|
EXIT_SUCCESS : On success
|
|
--*/
|
|
|
|
{
|
|
DWORD dwRet = 0;
|
|
DWORD dwSize = MAX_RES_STRING;
|
|
BOOL bFlag = FALSE;
|
|
|
|
|
|
//WCHAR szDir[2*MAX_STRING_LENGTH] = NULL_U_STRING;
|
|
LPWSTR szDir = NULL;
|
|
LPWSTR szTempDirectory = NULL;
|
|
DWORD dwRetval = 1;
|
|
DWORD dwAttr = 1;
|
|
HRESULT hr;
|
|
BOOL bFilesNone = TRUE;
|
|
|
|
if(FALSE == bCurrDirTakeOwnAllFiles )
|
|
{
|
|
dwAttr = GetFileAttributes(lpszFileName);
|
|
if(0xffffffff == dwAttr)
|
|
{
|
|
if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
ShowMessage(stderr,GetResString(IDS_INVALID_DIRECTORY));
|
|
|
|
}
|
|
else
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
return EXIT_FAILURE;
|
|
}
|
|
if( !(dwAttr&FILE_ATTRIBUTE_DIRECTORY) )
|
|
{
|
|
ShowMessage(stderr,GetResString(IDS_INVALID_DIRECTORY));
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
szDir = (LPWSTR)AllocateMemory((StringLengthW(lpszFileName, 0) + BOUNDARYVALUE) * sizeof(WCHAR));
|
|
if(NULL == szDir)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopy( szDir, lpszFileName, GetBufferSize(szDir) / sizeof(WCHAR) );
|
|
|
|
|
|
}
|
|
else //else if(TRUE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
szDir = (LPWSTR)AllocateMemory((MAX_PATH + BOUNDARYVALUE) * sizeof(WCHAR));
|
|
if(NULL == szDir)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
dwRet = GetCurrentDirectory( dwSize, szDir );
|
|
if( 0 == dwRet )
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
}
|
|
|
|
if(FALSE == bCurrDirTakeOwnAllFiles && FALSE == bTakeOwnAllFiles &&
|
|
FALSE == bDriveCurrDirTakeOwnAllFiles && FALSE == bMatchPattern)
|
|
{
|
|
|
|
szTempDirectory = (LPWSTR)AllocateMemory((StringLengthW(szDir, 0) + (2 * MAX_STRING_LENGTH)) * sizeof(WCHAR));
|
|
|
|
if(NULL == szTempDirectory)
|
|
{
|
|
//DisplayErrorMsg(GetLastError());
|
|
FREE_MEMORY(szDir);
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
//bFlag = TakeOwnerShip( lpszFileName);
|
|
bFlag = TakeOwnerShip( szDir);
|
|
}
|
|
else
|
|
{
|
|
|
|
bFlag = TakeOwnerShipIndividual(szDir);
|
|
|
|
}
|
|
|
|
if( FALSE == bFlag )
|
|
{
|
|
|
|
if( ERROR_NOT_ALL_ASSIGNED == GetLastError()) // || (ERROR_INVALID_HANDLE == GetLastError()))
|
|
{
|
|
|
|
hr = StringCchPrintf(szTempDirectory, (GetBufferSize(szTempDirectory) / sizeof(WCHAR)), GetResString(IDS_NOT_OWNERSHIP_ERROR) , szDir);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szTempDirectory);
|
|
FREE_MEMORY(szDir);
|
|
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
ShowMessage(stderr, szTempDirectory);
|
|
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
return EXIT_FAILURE;
|
|
|
|
|
|
}
|
|
else if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
|
|
hr = StringCchPrintf(szTempDirectory, (GetBufferSize(szTempDirectory) / sizeof(WCHAR)), GetResString(IDS_SHARING_VIOLATION_ERROR) , szDir);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szTempDirectory);
|
|
FREE_MEMORY(szDir);
|
|
|
|
return( EXIT_FAILURE );
|
|
}
|
|
|
|
ShowMessage(stderr, szTempDirectory);
|
|
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
else
|
|
{
|
|
ShowMessage( stderr, ERROR_STRING );
|
|
ShowMessage( stderr, SPACE_CHAR );
|
|
ShowMessage( stderr, GetReason() );
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
hr = StringCchPrintf(szTempDirectory, (GetBufferSize(szTempDirectory) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL, szDir);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//hr = StringCchPrintf(szTempDirectory, (GetBufferSize(szTempDirectory) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szOwnerString, szDir );
|
|
hr = StringCchPrintf(szTempDirectory, (GetBufferSize(szTempDirectory) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szDir, szOwnerString);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
|
|
ShowMessage( stdout, _X(szTempDirectory) );
|
|
FREE_MEMORY( szTempDirectory ) ;
|
|
|
|
}
|
|
}
|
|
|
|
if( TRUE == Push( szDir ) )
|
|
{ // Push the current directory .
|
|
|
|
dwRetval = GetMatchedFiles( bAdminsOwner,szOwnerString, bMatchPattern, wszPatternString, &bFilesNone, szConfirm );
|
|
|
|
if((TRUE == dwRetval) || (EXIT_CANCELED == dwRetval) )
|
|
{
|
|
if(TRUE == bFilesNone)
|
|
{
|
|
if((TRUE == bCurrDirTakeOwnAllFiles || TRUE == bTakeOwnAllFiles ||
|
|
TRUE == bDriveCurrDirTakeOwnAllFiles) && FALSE == bMatchPattern)
|
|
{
|
|
ShowMessage(stdout, GetResString(IDS_NO_FILES_AVAILABLE));
|
|
}
|
|
else
|
|
if((TRUE == bCurrDirTakeOwnAllFiles || TRUE == bTakeOwnAllFiles ||
|
|
TRUE == bDriveCurrDirTakeOwnAllFiles) && TRUE == bMatchPattern)
|
|
{
|
|
ShowMessage(stdout, GetResString(IDS_NO_PATTERN_FOUND));
|
|
|
|
}
|
|
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_SUCCESS ;
|
|
}
|
|
else
|
|
{
|
|
//FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_SUCCESS ;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//FREE_MEMORY( szTempDirectory ) ;
|
|
FREE_MEMORY(szDir);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
DWORD GetMatchedFiles(IN BOOL bAdminsOwner,
|
|
IN LPWSTR szOwnerString,
|
|
IN BOOL bMatchPattern,
|
|
IN LPWSTR wszPatternString,
|
|
IN OUT PBOOL pbFilesNone,
|
|
IN LPWSTR szConfirm)
|
|
|
|
|
|
/*++
|
|
Routine Description:
|
|
This function takes care of getting the files and giving the ownership
|
|
|
|
Arguments:
|
|
|
|
[ IN ] bAdminsOwner : Indicates whether to give ownership to the administrators group
|
|
[ IN ] szOwnerString : Logged on user name in Sam Compatible format
|
|
[ IN ] bLogonDomainAdmin : Indicates whether the logged on user is domain administrator or not
|
|
[ IN ] bMatchPattern : Whether pattern matching exists
|
|
[ IN ] wszPatternString : The pattern string used for pattern match
|
|
[ IN ] pbFilesNone : Whether there are any files existing or not
|
|
|
|
Return Value:
|
|
EXIT_FAILURE : On failure
|
|
EXIT_SUCCESS : On success
|
|
--*/
|
|
|
|
{
|
|
//LPWSTR lpszSlashAvailLast = NULL;
|
|
BOOL bACLChgPermGranted = FALSE;
|
|
DWORD dwRetval = 1;
|
|
LPWSTR lpszTempPathName = NULL;
|
|
DWORD dwMem = 0;
|
|
|
|
//ASSIGN_MEMORY( g_lpszFileToSearch , TCHAR , MAX_STRING_LENGTH ) ;
|
|
g_lpszFileToSearch = (LPTSTR)AllocateMemory((MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if( NULL == g_lpszFileToSearch )
|
|
{ // Memory allocation failed .
|
|
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FALSE ;
|
|
}
|
|
|
|
lpszTempPathName = (LPWSTR)AllocateMemory((MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if( NULL == lpszTempPathName )
|
|
{ // Memory allocation failed .
|
|
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
return FALSE ;
|
|
}
|
|
|
|
// Loop until data strycture( stack) has no item left in it .
|
|
while( NULL != g_pPathName )
|
|
{
|
|
|
|
if( FALSE == Pop( ) )
|
|
{ // Control should come here only when linkedlist have no node to POP .
|
|
FREE_MEMORY( g_lpszFileToSearch ) ; // Error message is already displayed .
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
return FALSE ;
|
|
}
|
|
|
|
|
|
dwMem = (StringLength(g_lpszFileToSearch, 0) + EXTRA_MEM ) * sizeof(WCHAR);
|
|
if((DWORD)GetBufferSize(lpszTempPathName) < (dwMem))
|
|
{
|
|
if(FALSE == ReallocateMemory((LPVOID*)&lpszTempPathName,( dwMem) ))
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(lpszTempPathName);
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
return FALSE ;
|
|
}
|
|
else
|
|
if(NULL == lpszTempPathName)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(lpszTempPathName);
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
return FALSE ;
|
|
}
|
|
}
|
|
|
|
StringCopy( lpszTempPathName, g_lpszFileToSearch, GetBufferSize(lpszTempPathName) / sizeof(WCHAR) );
|
|
|
|
|
|
if( *(g_lpszFileToSearch+StringLengthW(g_lpszFileToSearch, 0) - 1) != L'\\' )
|
|
|
|
{
|
|
|
|
StringConcat(g_lpszFileToSearch, _T( "\\" ), GetBufferSize(g_lpszFileToSearch)/sizeof(TCHAR));
|
|
}
|
|
|
|
|
|
StringConcat(g_lpszFileToSearch, _T( "*.*" ), GetBufferSize(g_lpszFileToSearch)/sizeof(TCHAR));
|
|
|
|
/*Store all the subdirectories in the stack*/
|
|
|
|
|
|
dwRetval = StoreSubDirectory( lpszTempPathName, &bACLChgPermGranted, szOwnerString, bMatchPattern,
|
|
wszPatternString, szConfirm, bAdminsOwner ) ;
|
|
|
|
if(FAILURE == dwRetval )
|
|
{
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
FREE_MEMORY(lpszTempPathName);
|
|
return FALSE ;
|
|
}
|
|
else if( EXIT_CANCELED == dwRetval )
|
|
{
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
FREE_MEMORY(lpszTempPathName);
|
|
return EXIT_CANCELED ;
|
|
}
|
|
|
|
/*Get the ownership for the files or directories in the current folder only*/
|
|
|
|
|
|
if( FALSE == GetOwnershipForFiles(lpszTempPathName, bAdminsOwner, szOwnerString,
|
|
bMatchPattern, wszPatternString, pbFilesNone))
|
|
{
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
FREE_MEMORY(lpszTempPathName);
|
|
return FALSE ;
|
|
}
|
|
}
|
|
|
|
FREE_MEMORY( g_lpszFileToSearch ) ;
|
|
FREE_MEMORY(lpszTempPathName);
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
DWORD
|
|
StoreSubDirectory(IN LPTSTR lpszPathName,
|
|
IN PBOOL pbACLChgPermGranted,
|
|
IN LPWSTR szOwnerString,
|
|
IN BOOL bMatchPattern,
|
|
IN LPWSTR wszPatternString,
|
|
IN LPWSTR szConfirm,
|
|
IN BOOL bAdminsOwner)
|
|
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Find and store subdirectories present in a directory matching criteria
|
|
file was created between specified date or not .
|
|
|
|
Arguments:
|
|
|
|
[ IN ] lpszPathName : Contains path of a directory from where files matching
|
|
a criteria are to be displayed .
|
|
[ IN ] pbACLChgPermGranted : To check whether ACLs has to be changed to give full permission.
|
|
[ IN ] szOwnerString : Logged on user name in Sam Compatible format.
|
|
[ IN ] bLogonDomainAdmin : Indicates whether the logged on user is domain administrator or not.
|
|
[ IN ] bMatchPattern : Whether pattern matching is supported or not
|
|
[ IN ] wszPatternString : The pattern string used for pattern matching
|
|
|
|
|
|
Return value:
|
|
|
|
SUCCESS : On Success
|
|
FAILURE : On Failure
|
|
EXIT_CANCELED : On Exiting Immediately
|
|
|
|
--*/
|
|
|
|
{
|
|
HANDLE hFindFile ;
|
|
WIN32_FIND_DATA wfdFindFile ;
|
|
HANDLE hInput = 0;// Stores the input handle device
|
|
DWORD dwBytesRead = 0;// Stores number of byes read from console
|
|
DWORD dwMode = 0;// Stores mode for input device
|
|
BOOL bSuccess = FALSE; // Stores return value
|
|
WCHAR chTmp[MAX_RES_STRING] ;
|
|
WCHAR ch = NULL_U_CHAR;
|
|
LPWSTR lpszDispMsg = NULL;
|
|
LPWSTR lpszDispMsg2 = NULL;
|
|
DWORD dwCount = 0;
|
|
DWORD dwMem = 0;
|
|
HRESULT hr;
|
|
BOOL bNTFSFileSystem = FALSE;
|
|
BOOL bIndirectionInputWithZeroLength = FALSE;
|
|
BOOL bIndirectionInput = FALSE;
|
|
//WCHAR szTemp[MAX_STRING_LENGTH] = NULL_U_STRING;
|
|
LPWSTR lpszTempStr = NULL;
|
|
|
|
|
|
SecureZeroMemory(chTmp, MAX_RES_STRING * sizeof( WCHAR ));
|
|
|
|
SecureZeroMemory(&wfdFindFile, sizeof( WIN32_FIND_DATA ));
|
|
|
|
if( INVALID_HANDLE_VALUE != ( hFindFile = FindFirstFile( g_lpszFileToSearch , &wfdFindFile ) ) )
|
|
{
|
|
do // Loop until files are present in the directory to display .
|
|
{
|
|
// Check again whether obtained handle points to a directory or file .
|
|
// If directory then check whether files in subdir are to be displayed .
|
|
if( 0 != ( wfdFindFile.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY ) )
|
|
{
|
|
// Is single dot "." present or Is double dot ".." present .
|
|
if( ( 0 != _tcsicmp( wfdFindFile.cFileName , DOT ) ) &&
|
|
( 0 != _tcsicmp( wfdFindFile.cFileName , DOTS ) ) )
|
|
{
|
|
|
|
dwMem = ( StringLengthW( lpszPathName, 0 ) + StringLengthW( wfdFindFile.cFileName, 0 ) + EXTRA_MEM );
|
|
// Reallocate memory .
|
|
|
|
if(((DWORD)GetBufferSize(g_lpszFileToSearch)) < (dwMem * sizeof(WCHAR)))
|
|
{
|
|
|
|
if(FALSE == ReallocateMemory((LPVOID*)&g_lpszFileToSearch,( dwMem) * sizeof(WCHAR) ))
|
|
{
|
|
//ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC));
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
}
|
|
else
|
|
if(NULL == g_lpszFileToSearch)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
StringCopy( g_lpszFileToSearch, lpszPathName, (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)) );
|
|
|
|
|
|
//if((NULL != g_lpszFileToSearch) &&(*(g_lpszFileToSearch+lstrlen(g_lpszFileToSearch)-1)) != L'\\' )
|
|
if((NULL != g_lpszFileToSearch) &&(*(g_lpszFileToSearch + StringLengthW(g_lpszFileToSearch, 0) - 1)) != L'\\' )
|
|
|
|
{
|
|
|
|
StringConcat(g_lpszFileToSearch, L"\\", (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)));
|
|
}
|
|
|
|
|
|
StringConcat(g_lpszFileToSearch, wfdFindFile.cFileName, (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)));
|
|
|
|
if(EXIT_SUCCESS == IsNTFSFileSystem2(g_lpszFileToSearch, &bNTFSFileSystem))
|
|
{
|
|
if(FALSE == bNTFSFileSystem)
|
|
{
|
|
continue;
|
|
}
|
|
}
|
|
|
|
lpszTempStr = (LPWSTR)AllocateMemory((StringLengthW(wfdFindFile.cFileName, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == lpszTempStr)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
}
|
|
|
|
if( FindString( wszPatternString, L".",0) != NULL && (FindString(wfdFindFile.cFileName, L".",0)== NULL) )
|
|
{
|
|
|
|
StringCopy( lpszTempStr, wfdFindFile.cFileName, GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
StringConcat( lpszTempStr, L".", GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
}
|
|
else
|
|
{
|
|
StringCopy( lpszTempStr, wfdFindFile.cFileName, GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
}
|
|
|
|
if((FALSE == bMatchPattern) || ((TRUE == bMatchPattern) && (TRUE == MatchPattern(wszPatternString, lpszTempStr))))
|
|
{
|
|
|
|
|
|
if( (FALSE == TakeOwnerShipIndividual(g_lpszFileToSearch)))
|
|
{
|
|
FREE_MEMORY(lpszTempStr);
|
|
continue;
|
|
}
|
|
else
|
|
{
|
|
// Copy current path name and store it .
|
|
if( FALSE == Push( g_lpszFileToSearch ) )
|
|
{ // Control comes here when memory allocation fails .
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
FREE_MEMORY(lpszTempStr);
|
|
return FAILURE ;
|
|
} // Push Is Over .
|
|
|
|
FREE_MEMORY(lpszTempStr);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if( FALSE == Push( g_lpszFileToSearch ) )
|
|
{ // Control comes here when memory allocation fails .
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
FREE_MEMORY(lpszTempStr);
|
|
return FAILURE ;
|
|
} // Push I
|
|
|
|
FREE_MEMORY(lpszTempStr);
|
|
|
|
}
|
|
|
|
} // If
|
|
else
|
|
{ // If obtained directory is A "." or ".." ,
|
|
continue ;
|
|
}
|
|
|
|
}
|
|
}while( 0 != FindNextFile( hFindFile , &wfdFindFile ) ) ; // Continue till no files are present to display.
|
|
}
|
|
else
|
|
{
|
|
if(0 == StringLengthW(szConfirm, 0))
|
|
{
|
|
if(FALSE == *pbACLChgPermGranted) // Check whether permission for change of ACL is already granted
|
|
{
|
|
|
|
lpszDispMsg = (LPWSTR)AllocateMemory((StringLengthW( lpszPathName, 0 ) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if( NULL == lpszDispMsg ) // Check is memory allocation is successful or not .
|
|
{ // Memory allocation is not successful .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FAILURE ;
|
|
}
|
|
|
|
|
|
lpszDispMsg2 = (LPWSTR)AllocateMemory((StringLengthW( lpszPathName, 0 ) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
if( NULL == lpszDispMsg2 ) // Check is memory allocation is successful or not .
|
|
{ // Memory allocation is not successful .
|
|
FREE_MEMORY(lpszDispMsg);
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FAILURE ;
|
|
}
|
|
|
|
|
|
hr = StringCchPrintf(lpszDispMsg, (GetBufferSize(lpszDispMsg) / sizeof(WCHAR)), GIVE_FULL_PERMISSIONS, lpszPathName );
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(lpszDispMsg);
|
|
return FAILURE;
|
|
}
|
|
|
|
|
|
hr = StringCchPrintf(lpszDispMsg2, (GetBufferSize(lpszDispMsg2) / sizeof(WCHAR)), GIVE_FULL_PERMISSIONS2, lpszPathName );
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(lpszDispMsg);
|
|
return FAILURE;
|
|
}
|
|
|
|
do
|
|
{
|
|
if(FALSE == bIndirectionInputWithZeroLength)
|
|
{
|
|
if(0 == dwCount)//Give a message asking the user for change of ACLs
|
|
{
|
|
ShowMessage(stdout,_X(lpszDispMsg));
|
|
ShowMessage(stdout,_X(lpszDispMsg2));
|
|
}
|
|
else
|
|
{
|
|
ShowMessage(stdout,L"\n\n");
|
|
ShowMessage(stdout,_X(lpszDispMsg2));
|
|
}
|
|
}
|
|
|
|
dwCount+= 1;
|
|
|
|
hInput = GetStdHandle( STD_INPUT_HANDLE );
|
|
|
|
if( INVALID_HANDLE_VALUE == hInput)
|
|
{
|
|
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
// Set Reason for error in memory
|
|
|
|
return FAILURE;
|
|
}
|
|
|
|
// Get console mode, so we can change the input mode
|
|
bSuccess = GetConsoleMode( hInput, &dwMode );
|
|
if ( TRUE == bSuccess)
|
|
{
|
|
// turn off line input and echo
|
|
dwMode &= ~( ENABLE_LINE_INPUT | ENABLE_ECHO_INPUT );
|
|
bSuccess = SetConsoleMode( hInput, dwMode );
|
|
if (FALSE == bSuccess)
|
|
{
|
|
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
// Set Reason for error in memory
|
|
|
|
return FAILURE;
|
|
|
|
}
|
|
// Flush the buffer initially
|
|
if ( FlushConsoleInputBuffer( hInput ) == FALSE )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
// Set Reason for error in memory
|
|
|
|
return FAILURE;
|
|
}
|
|
}
|
|
|
|
|
|
if ( ReadFile(hInput, &ch, 1, &dwBytesRead, NULL) == FALSE )
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
return FAILURE;
|
|
}
|
|
|
|
|
|
|
|
if( ( hInput != (HANDLE)0x0000000F )&&( hInput != (HANDLE)0x00000003 ) && ( hInput != INVALID_HANDLE_VALUE ) )
|
|
{
|
|
|
|
bIndirectionInput = TRUE;
|
|
|
|
}
|
|
|
|
|
|
hr = StringCchPrintf(chTmp, (SIZE_OF_ARRAY(chTmp)), L"%c" , ch );
|
|
if(FAILED(hr))
|
|
{
|
|
|
|
return FAILURE;
|
|
}
|
|
|
|
|
|
if( TRUE == bIndirectionInput)
|
|
{
|
|
if( chTmp[0] == L'\n' || chTmp[0] == L'\r'|| chTmp[0] == L'\t')
|
|
{
|
|
bIndirectionInputWithZeroLength = TRUE;
|
|
continue;
|
|
}
|
|
else
|
|
{
|
|
bIndirectionInputWithZeroLength = FALSE;
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
ShowMessage(stdout,_X(chTmp));
|
|
}while(0 != dwBytesRead && !(((StringCompare( chTmp, LOWER_YES, TRUE, 0 ) == 0) || (StringCompare( chTmp, LOWER_NO, TRUE, 0 ) == 0) || (StringCompare( chTmp, LOWER_CANCEL, TRUE, 0 ) == 0))));
|
|
|
|
|
|
FREE_MEMORY(lpszDispMsg);
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
StringCopy( chTmp, LOWER_YES, SIZE_OF_ARRAY(chTmp) );
|
|
dwBytesRead =2;
|
|
|
|
}
|
|
}
|
|
else
|
|
{
|
|
StringCopy( chTmp, szConfirm, SIZE_OF_ARRAY(chTmp) );
|
|
dwBytesRead =2;
|
|
|
|
}
|
|
|
|
|
|
if(0 != dwBytesRead && (StringCompare( chTmp, LOWER_YES, TRUE, 0 ) == 0) )
|
|
{
|
|
*pbACLChgPermGranted = TRUE;
|
|
/*if Permission for granting ACLS are obtained , then give the full permission*/
|
|
|
|
if(TRUE == AddAccessRights(lpszPathName, 0xF0FFFFFF, szOwnerString, bAdminsOwner))
|
|
{
|
|
if( INVALID_HANDLE_VALUE != ( hFindFile = FindFirstFile( g_lpszFileToSearch , &wfdFindFile ) ) )
|
|
{
|
|
|
|
do // Loop until files are present in the directory to display .
|
|
{
|
|
// Check again whether obtained handle points to a directory or file .
|
|
// If directory then check whether files in subdir are to be displayed .
|
|
if( 0 != ( wfdFindFile.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY ) )
|
|
{
|
|
// Is single dot "." present or Is double dot ".." present .
|
|
if( ( 0 != _tcsicmp( wfdFindFile.cFileName , DOT ) ) &&
|
|
( 0 != _tcsicmp( wfdFindFile.cFileName , DOTS ) ) )
|
|
{
|
|
|
|
dwMem = ( StringLengthW( lpszPathName, 0 ) + StringLengthW( wfdFindFile.cFileName, 0 ) + EXTRA_MEM );
|
|
// Reallocate memory .
|
|
|
|
if( (DWORD)GetBufferSize(g_lpszFileToSearch) < (dwMem * sizeof(WCHAR)))
|
|
{
|
|
|
|
if( FALSE == ReallocateMemory((LPVOID*)&g_lpszFileToSearch,
|
|
( StringLengthW( lpszPathName, 0 ) + StringLengthW( wfdFindFile.cFileName, 0 ) + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
|
|
}
|
|
else
|
|
if(NULL == g_lpszFileToSearch)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
StringCopy( g_lpszFileToSearch, lpszPathName, (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)) );
|
|
|
|
|
|
if((NULL != g_lpszFileToSearch) && (*(g_lpszFileToSearch + StringLengthW(g_lpszFileToSearch, 0) - 1)) != L'\\' )
|
|
{
|
|
|
|
StringConcat(g_lpszFileToSearch, L"\\", (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)));
|
|
}
|
|
|
|
StringConcat(g_lpszFileToSearch, wfdFindFile.cFileName, GetBufferSize(g_lpszFileToSearch)/sizeof(TCHAR));
|
|
|
|
// Copy current path name and store it .
|
|
if( FALSE == Push( g_lpszFileToSearch ) )
|
|
{ // Control comes here when memory allocation fails .
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FAILURE ;
|
|
} // Push Is Over .
|
|
|
|
} // If
|
|
else
|
|
{ // If obtained directory is A "." or ".." ,
|
|
continue ;
|
|
}
|
|
}
|
|
}while( 0 != FindNextFile( hFindFile , &wfdFindFile ) ) ; // Continue till no files are present to display.
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
ShowMessage(stderr, L"\n");
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return FAILURE;
|
|
}
|
|
|
|
}
|
|
else
|
|
if(0 == StringLengthW(szConfirm, 0))
|
|
{
|
|
if(0 != dwBytesRead && (StringCompare( chTmp, LOWER_CANCEL, TRUE, 0 ) == 0) )
|
|
{
|
|
ShowMessage(stdout,L"\n");
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return EXIT_CANCELED;
|
|
}
|
|
else
|
|
{
|
|
ShowMessage(stdout,L"\n");
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return SUCCESS ;
|
|
}
|
|
|
|
BOOL GetOwnershipForFiles( IN LPWSTR lpszPathName,
|
|
IN BOOL bAdminsOwner,
|
|
IN LPWSTR szOwnerString,
|
|
IN BOOL bMatchPattern,
|
|
IN LPWSTR wszPatternString,
|
|
IN OUT PBOOL pbFilesNone)
|
|
|
|
|
|
/*++
|
|
Routine Description:
|
|
This function gives the ownership for the files specified in the path
|
|
|
|
Arguments:
|
|
[ IN ] lpszPathName : The path to search the files for giving ownership
|
|
|
|
[ IN ] bAdminsOwner : Indicates whether to give ownership to the administrators group
|
|
[ IN ] dwUserName : Logged on user name
|
|
[ IN ] szOwnerString : Logged on user name in Sam Compatible format
|
|
[ IN ] bLogonDomainAdmin : Indicates whether the logged on user is domain administrator or not
|
|
|
|
Return Value:
|
|
FALSE : On failure
|
|
TRUE : On success
|
|
--*/
|
|
|
|
{
|
|
|
|
HANDLE hFindFile = NULL ; // Handle to a file .
|
|
WIN32_FIND_DATA wfdFindFile ; // Structure keeping information about the found file .
|
|
BOOL bTakeOwnerShipError = FALSE;
|
|
BOOL bFlag = TRUE;
|
|
BOOL bNTFSFileSystem = FALSE;
|
|
|
|
LPWSTR szTmpFileName = NULL;
|
|
|
|
|
|
WCHAR wszTempMessage[3*MAX_STRING_LENGTH] ;
|
|
|
|
LPWSTR szTemporaryFileName = NULL;
|
|
|
|
LPWSTR lpNextTok = NULL;
|
|
LPWSTR wszFormedMessage = NULL;
|
|
|
|
long dwMem = 0;
|
|
HRESULT hr;
|
|
LPWSTR lpszTempStr = NULL;
|
|
|
|
SecureZeroMemory(wszTempMessage, (3*MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
|
|
szTemporaryFileName = (LPWSTR)AllocateMemory((StringLengthW(lpszPathName, 0) + EXTRA_MEM)* sizeof(WCHAR));
|
|
if(NULL == szTemporaryFileName)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return FALSE ;
|
|
}
|
|
|
|
StringCopy( szTemporaryFileName, lpszPathName, GetBufferSize(szTemporaryFileName) / sizeof(WCHAR));
|
|
|
|
StringConcat(lpszPathName, L"\\", GetBufferSize(lpszPathName) / sizeof(WCHAR));
|
|
|
|
StringConcat(lpszPathName, L"*.*", GetBufferSize(lpszPathName) / sizeof(WCHAR));
|
|
|
|
SecureZeroMemory(&wfdFindFile, sizeof( WIN32_FIND_DATA ));
|
|
// From here onwards directory and file information should be displayed .
|
|
|
|
if( INVALID_HANDLE_VALUE != ( hFindFile = FindFirstFile( lpszPathName , &wfdFindFile ) ) )
|
|
{
|
|
do // Loop until files are present in the directory to display .
|
|
{
|
|
// Check again whether obtained handle points to a directory or file .
|
|
// If directory then check whether files in subdir are to be displayed .
|
|
if( 0 != ( wfdFindFile.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY ) )
|
|
{
|
|
// Is single dot "." present or Is double dot ".." present .
|
|
if( ( 0 == _tcsicmp( wfdFindFile.cFileName , DOT ) ) ||
|
|
( 0 == _tcsicmp( wfdFindFile.cFileName , DOTS ) ) )
|
|
{
|
|
continue ;
|
|
}
|
|
}
|
|
|
|
// Execute a command specified at command prompt .
|
|
// Reallocate memory .
|
|
|
|
dwMem = ( StringLengthW( g_lpszFileToSearch, 0) + StringLengthW( wfdFindFile.cFileName, 0 ) + EXTRA_MEM );
|
|
|
|
|
|
if(((DWORD)GetBufferSize(g_lpszFileToSearch)) < (dwMem * sizeof(WCHAR)))
|
|
{
|
|
|
|
if(FALSE == ReallocateMemory((LPVOID*)&g_lpszFileToSearch,
|
|
( StringLengthW( g_lpszFileToSearch, 0 ) + StringLengthW( wfdFindFile.cFileName, 0 ) + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return FALSE ;
|
|
}
|
|
else
|
|
if(NULL == g_lpszFileToSearch)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return FALSE ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
StringCopy( g_lpszFileToSearch, szTemporaryFileName, (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)) );
|
|
|
|
|
|
if((NULL != g_lpszFileToSearch) && (*(g_lpszFileToSearch + StringLengthW(g_lpszFileToSearch, 0) - 1)) != L'\\' )
|
|
{
|
|
|
|
StringConcat(g_lpszFileToSearch, L"\\", (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)) );
|
|
}
|
|
|
|
StringConcat(g_lpszFileToSearch, wfdFindFile.cFileName, (GetBufferSize(g_lpszFileToSearch) / sizeof(TCHAR)) );
|
|
|
|
lpszTempStr = (LPWSTR)AllocateMemory((StringLengthW(wfdFindFile.cFileName, 0) + 10) * sizeof(WCHAR));
|
|
if(NULL == lpszTempStr)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return FAILURE ;
|
|
}
|
|
|
|
if( FindString( wszPatternString, L".",0) != NULL && (FindString(wfdFindFile.cFileName, L".",0)== NULL) )
|
|
{
|
|
|
|
StringCopy( lpszTempStr, wfdFindFile.cFileName, GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
StringConcat( lpszTempStr, L".", GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
}
|
|
else
|
|
{
|
|
StringCopy( lpszTempStr, wfdFindFile.cFileName, GetBufferSize(lpszTempStr) / sizeof(WCHAR) );
|
|
}
|
|
|
|
if((FALSE == bMatchPattern) || ((TRUE == bMatchPattern) && (TRUE == MatchPattern(wszPatternString, lpszTempStr))))
|
|
{
|
|
|
|
FREE_MEMORY(lpszTempStr);
|
|
|
|
*pbFilesNone = FALSE;
|
|
if(EXIT_SUCCESS == IsNTFSFileSystem2(g_lpszFileToSearch, &bNTFSFileSystem))
|
|
{
|
|
if(FALSE == bNTFSFileSystem)
|
|
{
|
|
wszFormedMessage = (LPWSTR)AllocateMemory((StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR));
|
|
if( NULL == wszFormedMessage )
|
|
{ // Reallocation failed .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
|
|
hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), GetResString(IDS_FAT_VOLUME_INFO), _X(g_lpszFileToSearch));
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY( wszFormedMessage ) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE;
|
|
}
|
|
|
|
ShowMessage(stdout, wszFormedMessage);
|
|
|
|
FREE_MEMORY(wszFormedMessage);
|
|
|
|
continue;
|
|
}
|
|
}
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
bFlag = TakeOwnerShip( g_lpszFileToSearch);
|
|
}
|
|
else
|
|
{
|
|
|
|
bFlag = TakeOwnerShipIndividual(g_lpszFileToSearch);
|
|
|
|
}
|
|
|
|
|
|
if( FALSE == bFlag && bTakeOwnerShipError == FALSE )
|
|
{
|
|
|
|
if( ERROR_NOT_ALL_ASSIGNED == GetLastError()) // || (ERROR_INVALID_HANDLE == GetLastError()))
|
|
{
|
|
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR));
|
|
if( NULL == szTmpFileName )
|
|
{ // Reallocation failed .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
dwMem = ( StringLengthW( g_lpszFileToSearch, 0) + MAX_RES_STRING + EXTRA_MEM );
|
|
|
|
if((DWORD)GetBufferSize(szTmpFileName) < dwMem * sizeof(WCHAR))
|
|
{
|
|
|
|
if(FALSE == ReallocateMemory((LPVOID*)&szTmpFileName,( StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
else
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_NOT_OWNERSHIP_INFO), g_lpszFileToSearch);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
|
|
}
|
|
else if(ERROR_SHARING_VIOLATION == GetLastError())
|
|
{
|
|
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR));
|
|
if( NULL == szTmpFileName )
|
|
{ // Reallocation failed .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
dwMem = ( StringLengthW( g_lpszFileToSearch, 0) + MAX_RES_STRING + EXTRA_MEM );
|
|
|
|
if((DWORD)GetBufferSize(szTmpFileName) < dwMem * sizeof(WCHAR))
|
|
{
|
|
|
|
if( FALSE == ReallocateMemory((LPVOID*)&szTmpFileName,
|
|
( StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
|
|
}
|
|
else
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), GetResString(IDS_SHARING_VIOLATION_INFO), g_lpszFileToSearch);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return( FALSE );
|
|
}
|
|
|
|
ShowMessage(stdout, szTmpFileName);
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
wszFormedMessage = (LPWSTR)AllocateMemory((StringLengthW( g_lpszFileToSearch, 0 ) + MAX_STRING_LENGTH) * sizeof(WCHAR));
|
|
if(NULL == wszFormedMessage)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE;
|
|
}
|
|
ShowMessage( stdout, L"\n" );
|
|
ShowMessage( stdout, TAG_INFORMATION );
|
|
ShowMessage( stdout, SPACE_CHAR );
|
|
|
|
StringCopy( wszTempMessage, GetReason(), SIZE_OF_ARRAY(wszTempMessage) );
|
|
lpNextTok = _tcstok(wszTempMessage, L".");
|
|
ShowMessage(stdout,wszTempMessage);
|
|
|
|
//hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), GetResString(IDS_ON_FILE_FOLDER), _X(g_lpszFileToSearch) );
|
|
|
|
hr = StringCchPrintf(wszFormedMessage, (GetBufferSize(wszFormedMessage) / sizeof(WCHAR)), L". ( \"%s\" )\n", _X(g_lpszFileToSearch));
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY( wszFormedMessage ) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE;
|
|
}
|
|
ShowMessage(stdout, wszFormedMessage);
|
|
FREE_MEMORY(wszFormedMessage);
|
|
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
|
|
szTmpFileName = (LPWSTR)AllocateMemory((StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR));
|
|
if( NULL == szTmpFileName )
|
|
{ // Reallocation failed .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
|
|
dwMem = ( StringLengthW( g_lpszFileToSearch, 0) + MAX_RES_STRING + EXTRA_MEM );
|
|
|
|
if((DWORD)GetBufferSize(szTmpFileName) < dwMem * sizeof(WCHAR))
|
|
{
|
|
if(FALSE == ReallocateMemory((LPVOID*)&szTmpFileName,( StringLengthW( g_lpszFileToSearch, 0 ) + MAX_RES_STRING + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
}
|
|
else
|
|
if(NULL == szTmpFileName)
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
FREE_MEMORY(szTmpFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE ;
|
|
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL,g_lpszFileToSearch );
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, szOwnerString, g_lpszFileToSearch );
|
|
hr = StringCchPrintf(szTmpFileName, (GetBufferSize(szTmpFileName) / sizeof(WCHAR)), TAKEOWN_SUCCESSFUL_USER, g_lpszFileToSearch, szOwnerString);
|
|
if(FAILED(hr))
|
|
{
|
|
SetLastError(HRESULT_CODE(hr));
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
ShowMessage( stdout, _X(szTmpFileName) );
|
|
|
|
}
|
|
}
|
|
|
|
FREE_MEMORY(lpszTempStr);
|
|
|
|
} while( 0 != FindNextFile( hFindFile , &wfdFindFile ) ) ; // Continue till no files are present to display.
|
|
|
|
if( GetLastError() != ERROR_NO_MORE_FILES ) // If error occurs , check is error other than NOMOREFILES .
|
|
{ // If error is other than NOMOREFILES then display ERROR .
|
|
SaveLastError();
|
|
ShowMessage( stderr , GetReason() ) ;
|
|
CLOSE_FILE_HANDLE( hFindFile ) ;
|
|
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return FALSE ;
|
|
}
|
|
}
|
|
|
|
CLOSE_FILE_HANDLE( hFindFile ) ; // Close open find file handle .
|
|
g_pFollowPathName = NULL ;
|
|
|
|
FREE_MEMORY(szTmpFileName);
|
|
FREE_MEMORY(szTemporaryFileName);
|
|
return TRUE ;
|
|
}
|
|
|
|
BOOL
|
|
Push(
|
|
IN LPTSTR szPathName )
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Store the path of obtained subdirectory .
|
|
|
|
Arguments:
|
|
|
|
[ IN ] szPathName : Contains path of a subdirectory .
|
|
|
|
Return value:
|
|
|
|
TRUE if succedded in storing a path else FALSE if failed to get memory.
|
|
|
|
--*/
|
|
{
|
|
// Get a temporary variable .
|
|
PStore_Path_Name pAddPathName ;
|
|
// Assign memory To Temporary Variable .
|
|
|
|
pAddPathName = (PStore_Path_Name)AllocateMemory((1) * sizeof(struct __STORE_PATH_NAME ));
|
|
|
|
if( NULL == pAddPathName ) // Check is memory allocation is successful or not .
|
|
{ // Memory allocation is successful .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FALSE ;
|
|
}
|
|
// Assign memory to string variable which is going to store full path name of a valid directory .
|
|
|
|
pAddPathName->pszDirName = (LPTSTR)AllocateMemory((StringLengthW( szPathName, 0 ) + EXTRA_MEM) * sizeof( WCHAR ));
|
|
|
|
if( NULL == pAddPathName->pszDirName )// Check is memory allocation was successful or not .
|
|
{ // Memory allocation was unsuccessful .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
FREE_MEMORY( pAddPathName ) ;
|
|
return FALSE ;
|
|
}
|
|
// Copy path name to memory allocated string variable .
|
|
|
|
StringCopy(( LPTSTR ) pAddPathName->pszDirName, szPathName, (GetBufferSize(pAddPathName->pszDirName) / sizeof(WCHAR)) );
|
|
|
|
pAddPathName->NextNode = NULL ; // Assign null , had only one subdirectory stored .
|
|
|
|
|
|
// Check global variable is NULL or not .
|
|
if( NULL == g_pPathName )
|
|
{ // Add memory to store path of subdirectory .
|
|
g_pPathName = pAddPathName ;
|
|
g_pFollowPathName = g_pPathName ;
|
|
}
|
|
else
|
|
{
|
|
if( NULL == g_pFollowPathName )
|
|
{ // Store first obtained subdirectory .
|
|
pAddPathName->NextNode = g_pPathName ;
|
|
g_pPathName = pAddPathName ;
|
|
g_pFollowPathName = g_pPathName ;
|
|
}
|
|
else
|
|
{
|
|
// Stroe subdirectory in the middle
|
|
pAddPathName->NextNode = g_pFollowPathName->NextNode ;
|
|
g_pFollowPathName->NextNode = pAddPathName ;
|
|
g_pFollowPathName = pAddPathName ;
|
|
}
|
|
}
|
|
|
|
return TRUE ;
|
|
}
|
|
|
|
BOOL
|
|
Pop(
|
|
void )
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
Get a subdirectory which has to be searched for a file matching a user
|
|
specified criteria .
|
|
|
|
Arguments:
|
|
|
|
Return value:
|
|
|
|
TRUE if successful in getting a path else FALSE if failed to get memory or
|
|
if no path is stored .
|
|
|
|
--*/
|
|
{
|
|
// Linked list has more than 1 node .
|
|
PStore_Path_Name pDelPathName = g_pPathName ;
|
|
|
|
// Check whether linked list is having any nodes .
|
|
if( NULL == g_pPathName )
|
|
{ // No nodes present , return False ,
|
|
// Should not happen ever . Control should not come here .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FALSE ;
|
|
}
|
|
|
|
// Realloc memory and give buffer space in which path name can fix .
|
|
|
|
if((DWORD)GetBufferSize( g_lpszFileToSearch) < ((StringLengthW( g_pPathName->pszDirName, 0 ) + EXTRA_MEM) * sizeof(WCHAR)))
|
|
{
|
|
if(FALSE == ReallocateMemory((LPVOID*)g_lpszFileToSearch, ( StringLengthW( g_pPathName->pszDirName, 0 ) + EXTRA_MEM ) * sizeof(WCHAR) ))
|
|
{
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FALSE ;
|
|
}
|
|
else
|
|
if( NULL == g_lpszFileToSearch )
|
|
{ // Memory reallocation failed .
|
|
ShowMessage( stderr , GetResString(IDS_ERROR_MEMORY_ALLOC)) ;
|
|
return FALSE ;
|
|
}
|
|
}
|
|
|
|
// Check linked list has only one node .
|
|
if( NULL == g_pPathName->NextNode )
|
|
{ // List has only one node .
|
|
// Memory allocation successful . Copy pathname to the buffer .
|
|
|
|
StringCopy(g_lpszFileToSearch, g_pPathName->pszDirName, (GetBufferSize(g_lpszFileToSearch) / sizeof(WCHAR)) );
|
|
g_pFollowPathName = NULL ; // Formality , better practice to assign NULL .
|
|
// Free node . Linked list is now empty .
|
|
FREE_MEMORY( g_pPathName->pszDirName ) ;
|
|
FREE_MEMORY( g_pPathName ) ;
|
|
return TRUE;
|
|
}
|
|
|
|
g_pPathName = pDelPathName->NextNode ;
|
|
// Memory allocation successful . Copy pathname to the buffer .
|
|
|
|
StringCopy(g_lpszFileToSearch, pDelPathName->pszDirName, (GetBufferSize(g_lpszFileToSearch) / sizeof(WCHAR)) );
|
|
// Free node .
|
|
FREE_MEMORY( pDelPathName->pszDirName ) ;
|
|
FREE_MEMORY( pDelPathName ) ;
|
|
return TRUE ;
|
|
}
|
|
|
|
BOOL
|
|
TakeOwnerShipIndividual(
|
|
IN LPCTSTR lpszFileName
|
|
)
|
|
/*++
|
|
Routine Description:
|
|
This routine takes the ownership of the specified file
|
|
|
|
Arguments:
|
|
[ IN ] lpszFileName - File name for whose ownership has to be taken.
|
|
[ IN ] lpszUserName - User Name in the Sam compatible format.
|
|
[ IN ] dwUserName - Logged on user name.
|
|
[ IN ] bLogonDomainAdmin - To know whether the logged on user is Domain admin or not.
|
|
|
|
Return Value:
|
|
TRUE if owner ship of the specified file has been taken
|
|
else FALSE
|
|
--*/
|
|
{
|
|
//local variables
|
|
SECURITY_DESCRIPTOR SecurityDescriptor;
|
|
PSECURITY_DESCRIPTOR pSd = NULL;
|
|
//PSID pAliasAdminsSid = NULL;
|
|
//SID_IDENTIFIER_AUTHORITY SepNtAuthority = SECURITY_NT_AUTHORITY;
|
|
PACL pDacl;
|
|
HANDLE hFile;
|
|
HANDLE hTokenHandle = NULL;
|
|
BOOL bResult = TRUE;
|
|
BOOL bInvalidFileHandle = FALSE;
|
|
|
|
PSID pSid = NULL;
|
|
|
|
PTOKEN_USER pTokUser = NULL;
|
|
DWORD dwTokLen = 0;
|
|
|
|
|
|
|
|
|
|
//check for valid input parameters
|
|
if( lpszFileName == NULL )
|
|
{
|
|
SetLastError( (DWORD) E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
FREE_MEMORY(pTokUser);
|
|
CloseHandle( hTokenHandle );
|
|
return FALSE;
|
|
}
|
|
|
|
//get the token of the current process
|
|
bResult = GetTokenHandle( &hTokenHandle );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
return( FALSE );
|
|
}
|
|
|
|
|
|
GetTokenInformation(hTokenHandle,TokenUser,NULL,0,&dwTokLen);
|
|
|
|
if(0 == dwTokLen)
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
CloseHandle( hTokenHandle );
|
|
return( FALSE );
|
|
}
|
|
|
|
pTokUser = (TOKEN_USER*)AllocateMemory(dwTokLen );
|
|
|
|
if( pTokUser == NULL )
|
|
{
|
|
SetLastError( (DWORD) E_OUTOFMEMORY );
|
|
SaveLastError();
|
|
CloseHandle( hTokenHandle );
|
|
return FALSE;
|
|
}
|
|
|
|
if(!GetTokenInformation(hTokenHandle,TokenUser,pTokUser,dwTokLen,&dwTokLen))
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
CloseHandle( hTokenHandle );
|
|
return( FALSE );
|
|
}
|
|
|
|
// Attempt to put a NULL Dacl on the object
|
|
bResult = InitializeSecurityDescriptor( &SecurityDescriptor,
|
|
SECURITY_DESCRIPTOR_REVISION );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
CloseHandle( hTokenHandle );
|
|
FREE_MEMORY(pSid);
|
|
return( FALSE );
|
|
}
|
|
//Get the handle of the file or directory
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
|
|
//try once again it may be a directory
|
|
if( INVALID_HANDLE_VALUE != hFile )
|
|
{
|
|
|
|
//get the DACL for the currently existing file or directory
|
|
if( 0 != GetSecurityInfo( hFile, SE_FILE_OBJECT, DACL_SECURITY_INFORMATION, NULL,
|
|
NULL, &pDacl, NULL, &pSd ) )
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
|
|
CloseHandle( hFile );
|
|
CloseHandle( hTokenHandle );
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
|
|
// set the security descriptor to acl
|
|
bResult = SetSecurityDescriptorDacl ( &SecurityDescriptor,
|
|
TRUE, pDacl, FALSE );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
CloseHandle( hFile );
|
|
CloseHandle( hTokenHandle );
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
bInvalidFileHandle = TRUE;
|
|
}
|
|
|
|
|
|
bResult = SetSecurityDescriptorOwner ( &SecurityDescriptor,
|
|
pTokUser->User.Sid, FALSE );
|
|
|
|
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
CloseHandle( hTokenHandle );
|
|
CloseHandle( hFile );
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
//set the file security to adminsitrator owner
|
|
bResult = SetFileSecurity( lpszFileName, OWNER_SECURITY_INFORMATION,
|
|
&SecurityDescriptor );
|
|
|
|
if( TRUE == bResult )
|
|
{
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
CloseHandle( hTokenHandle );
|
|
CloseHandle( hFile );
|
|
return( TRUE );
|
|
}
|
|
|
|
// Assert TakeOwnership privilege for current process, then try again
|
|
bResult = AssertTakeOwnership( hTokenHandle );
|
|
|
|
if( FALSE == bResult )
|
|
{
|
|
|
|
if(TRUE == bInvalidFileHandle)
|
|
{
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
if( INVALID_HANDLE_VALUE == hFile )
|
|
{
|
|
if( ( ERROR_BAD_NET_NAME == GetLastError() ) ||
|
|
( ERROR_BAD_NETPATH == GetLastError() ) ||
|
|
( ERROR_INVALID_NAME == GetLastError() ) )
|
|
{
|
|
FREE_MEMORY(pTokUser);
|
|
SetLastError(ERROR_INVALID_NAME);
|
|
|
|
|
|
}
|
|
else if( ERROR_SHARING_VIOLATION == GetLastError() )
|
|
{
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
SetLastError(ERROR_SHARING_VIOLATION);
|
|
|
|
|
|
}
|
|
else
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(pTokUser);
|
|
}
|
|
|
|
CloseHandle( hTokenHandle );
|
|
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
switch (GetLastError())
|
|
{
|
|
case ERROR_NOT_ALL_ASSIGNED:
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_NOT_ALL_ASSIGNED);
|
|
break;
|
|
case ERROR_SHARING_VIOLATION:
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_SHARING_VIOLATION);
|
|
break;
|
|
case ERROR_BAD_NET_NAME :
|
|
case ERROR_BAD_NETPATH :
|
|
case ERROR_INVALID_NAME : FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_BAD_NET_NAME);
|
|
break;
|
|
|
|
default : FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
break;
|
|
}
|
|
|
|
CloseHandle( hTokenHandle );
|
|
CloseHandle( hFile );
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
//Now try to set ownership security privilege for the file
|
|
bResult = SetFileSecurity( lpszFileName, OWNER_SECURITY_INFORMATION,
|
|
&SecurityDescriptor );
|
|
if( FALSE == bResult )
|
|
{
|
|
SaveLastError();
|
|
|
|
if(TRUE == bInvalidFileHandle)
|
|
{
|
|
//Check out whether it is an invalid file or file does not exist
|
|
hFile = CreateFile( lpszFileName, READ_CONTROL , FILE_SHARE_READ, NULL,
|
|
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
|
|
if( INVALID_HANDLE_VALUE == hFile )
|
|
{
|
|
if( ( ERROR_BAD_NET_NAME == GetLastError() ) ||
|
|
( ERROR_BAD_NETPATH == GetLastError() ) ||
|
|
( ERROR_INVALID_NAME == GetLastError() ) )
|
|
{
|
|
FREE_MEMORY(pTokUser);
|
|
SetLastError(ERROR_INVALID_NAME);
|
|
}
|
|
else if( ERROR_SHARING_VIOLATION == GetLastError() )
|
|
{
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
SetLastError(ERROR_SHARING_VIOLATION);
|
|
|
|
}
|
|
else
|
|
{
|
|
SaveLastError();
|
|
FREE_MEMORY(pTokUser);
|
|
|
|
}
|
|
|
|
CloseHandle( hTokenHandle );
|
|
|
|
return( FALSE );
|
|
}
|
|
}
|
|
|
|
switch (GetLastError())
|
|
{
|
|
case ERROR_NOT_ALL_ASSIGNED:
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_NOT_ALL_ASSIGNED);
|
|
break;
|
|
case ERROR_SHARING_VIOLATION:
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_SHARING_VIOLATION);
|
|
break;
|
|
case ERROR_BAD_NET_NAME :
|
|
case ERROR_BAD_NETPATH :
|
|
case ERROR_INVALID_NAME : FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
SetLastError(ERROR_BAD_NET_NAME);
|
|
break;
|
|
|
|
default : FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
break;
|
|
}
|
|
|
|
|
|
CloseHandle( hTokenHandle );
|
|
CloseHandle( hFile );
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
return( FALSE );
|
|
}
|
|
|
|
if(NULL != pSd)
|
|
{
|
|
LocalFree( pSd );
|
|
}
|
|
|
|
FREE_MEMORY(pTokUser);
|
|
FREE_MEMORY(pSid);
|
|
|
|
CloseHandle( hTokenHandle );
|
|
CloseHandle( hFile );
|
|
return( TRUE );
|
|
}
|
|
|
|
BOOL
|
|
AddAccessRights(IN WCHAR *lpszFileName,
|
|
IN DWORD dwAccessMask,
|
|
IN LPWSTR dwUserName,
|
|
IN BOOL bAdminsOwner)
|
|
/*++
|
|
Routine Description:
|
|
This routine takes the ownership of the specified file
|
|
|
|
Arguments:
|
|
[ IN ] lpszFileName - Directory name for whom access permissions has to be granted.
|
|
[ IN ] dwAccessMask - Access Mask for giving the permissions.
|
|
[ IN ] dwUserName - User Name in the Sam compatible format.
|
|
|
|
|
|
Return Value:
|
|
TRUE if owner ship of the specified file has been taken
|
|
else FALSE
|
|
--*/
|
|
|
|
{
|
|
|
|
// SID variables.
|
|
SID_NAME_USE snuType;
|
|
WCHAR * szDomain = NULL;
|
|
DWORD cbDomain = 0;
|
|
PSID pUserSID = NULL;
|
|
DWORD cbUserSID = 0;
|
|
|
|
// File SD variables.
|
|
PSECURITY_DESCRIPTOR pFileSD = NULL;
|
|
DWORD cbFileSD = 0;
|
|
|
|
// New SD variables.
|
|
PSECURITY_DESCRIPTOR pNewSD = NULL;
|
|
|
|
// ACL variables.
|
|
PACL pACL = NULL;
|
|
BOOL fDaclPresent;
|
|
BOOL fDaclDefaulted;
|
|
ACL_SIZE_INFORMATION AclInfo;
|
|
|
|
// New ACL variables.
|
|
PACL pNewACL = NULL;
|
|
DWORD cbNewACL = 0;
|
|
|
|
// Assume function will fail.
|
|
BOOL fResult = FALSE;
|
|
BOOL fAPISuccess ;
|
|
BOOL bResult = FALSE;
|
|
ACCESS_ALLOWED_ACE *pace = NULL;
|
|
WORD acesize = 0;
|
|
|
|
PSID pAliasAdminsSid = NULL;
|
|
SID_IDENTIFIER_AUTHORITY SepNtAuthority = SECURITY_NT_AUTHORITY;
|
|
|
|
dwAccessMask = 0;
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
//allocate and initialise sid
|
|
bResult = AllocateAndInitializeSid(
|
|
&SepNtAuthority,
|
|
2,
|
|
SECURITY_BUILTIN_DOMAIN_RID,
|
|
DOMAIN_ALIAS_RID_ADMINS,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
&pAliasAdminsSid
|
|
);
|
|
}
|
|
|
|
//
|
|
// Get the actual size of SID for current user.
|
|
//
|
|
pUserSID = NULL;
|
|
cbUserSID = 0;
|
|
|
|
fAPISuccess = LookupAccountName( NULL, dwUserName,
|
|
pUserSID, &cbUserSID, szDomain, &cbDomain, &snuType);
|
|
|
|
|
|
// Since the buffer size is too small..API fails with insufficient buffer.
|
|
// If the error code is other than ERROR_INSUFFICIENT_BUFFER, then return failure.
|
|
|
|
if ( (FALSE == fAPISuccess) && (GetLastError() != ERROR_INSUFFICIENT_BUFFER) )
|
|
{
|
|
SaveLastError();
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
// allocate pUserSID with the actual size i.e.,cbUserSID
|
|
pUserSID = (PSID)AllocateMemory(cbUserSID);
|
|
|
|
if(NULL == pUserSID)
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
|
|
szDomain = (WCHAR*)AllocateMemory(cbDomain*sizeof(WCHAR));
|
|
|
|
if(NULL == szDomain)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
fAPISuccess = LookupAccountName( NULL, dwUserName,
|
|
pUserSID, &cbUserSID, szDomain, &cbDomain, &snuType);
|
|
|
|
if(0 == fAPISuccess)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
//
|
|
// Get security descriptor (SD) for file.
|
|
//
|
|
fAPISuccess = GetFileSecurity(lpszFileName,
|
|
DACL_SECURITY_INFORMATION, pFileSD, 0, &cbFileSD);
|
|
|
|
// API should have failed with insufficient buffer.
|
|
|
|
|
|
if(0 != cbFileSD)
|
|
{
|
|
pFileSD = (PSECURITY_DESCRIPTOR)AllocateMemory(cbFileSD);
|
|
|
|
if(NULL == pFileSD)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
|
|
fAPISuccess = GetFileSecurity(lpszFileName,
|
|
DACL_SECURITY_INFORMATION, pFileSD, cbFileSD, &cbFileSD);
|
|
if (!fAPISuccess)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
}
|
|
|
|
//
|
|
// Initialize new SD.
|
|
//
|
|
|
|
pNewSD = (PSECURITY_DESCRIPTOR)AllocateMemory(cbFileSD); // Should be same size as FileSD.
|
|
|
|
if (!pNewSD)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
if (!InitializeSecurityDescriptor(pNewSD,
|
|
SECURITY_DESCRIPTOR_REVISION))
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
//
|
|
// Get DACL from SD.
|
|
//
|
|
if (!GetSecurityDescriptorDacl(pFileSD, &fDaclPresent, &pACL,
|
|
&fDaclDefaulted))
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
//
|
|
// Get size information for DACL.
|
|
//
|
|
AclInfo.AceCount = 0; // Assume NULL DACL.
|
|
AclInfo.AclBytesFree = 0;
|
|
AclInfo.AclBytesInUse = sizeof(ACL);
|
|
|
|
// If not NULL DACL, gather size information from DACL.
|
|
if (fDaclPresent && pACL)
|
|
{
|
|
|
|
if(!GetAclInformation(pACL, &AclInfo,
|
|
sizeof(ACL_SIZE_INFORMATION), AclSizeInformation))
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
|
|
}
|
|
}
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
|
|
pace = (ACCESS_ALLOWED_ACE*)AllocateMemory(sizeof(ACCESS_ALLOWED_ACE) + GetLengthSid(pAliasAdminsSid) - sizeof(DWORD));
|
|
if(NULL == pace)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
return FALSE;
|
|
}
|
|
memcpy(&pace->SidStart, pAliasAdminsSid, GetLengthSid(pAliasAdminsSid));
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
pace = (ACCESS_ALLOWED_ACE*)AllocateMemory(sizeof(ACCESS_ALLOWED_ACE) + GetLengthSid(pUserSID) - sizeof(DWORD));
|
|
|
|
if(NULL == pace)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
memcpy(&pace->SidStart,pUserSID,GetLengthSid(pUserSID));
|
|
|
|
}
|
|
|
|
|
|
pace->Mask = 2032127;
|
|
|
|
pace->Header.AceType = ACCESS_ALLOWED_ACE_TYPE;
|
|
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
acesize = (WORD) (sizeof(ACCESS_ALLOWED_ACE) + GetLengthSid(pAliasAdminsSid) - sizeof(DWORD));
|
|
}
|
|
else
|
|
{
|
|
acesize = (WORD) (sizeof(ACCESS_ALLOWED_ACE) + GetLengthSid(pUserSID) - sizeof(DWORD) );
|
|
}
|
|
pace->Header.AceSize = acesize;
|
|
pace->Header.AceFlags = INHERIT_ONLY_ACE | OBJECT_INHERIT_ACE;
|
|
//pace->Header.AceFlags = OBJECT_INHERIT_ACE ;
|
|
|
|
|
|
|
|
//
|
|
// Compute size needed for the new ACL.
|
|
//
|
|
if(TRUE == bAdminsOwner)
|
|
{
|
|
cbNewACL = AclInfo.AclBytesInUse + sizeof(ACCESS_ALLOWED_ACE)
|
|
+ GetLengthSid(pAliasAdminsSid) - sizeof(DWORD) + 100;
|
|
}
|
|
else
|
|
{
|
|
cbNewACL = AclInfo.AclBytesInUse + sizeof(ACCESS_ALLOWED_ACE)
|
|
+ GetLengthSid(pUserSID) - sizeof(DWORD) + 100;
|
|
}
|
|
|
|
|
|
|
|
//
|
|
// Allocate memory for new ACL.
|
|
//
|
|
|
|
pNewACL = (PACL) AllocateMemory(cbNewACL);
|
|
|
|
if (!pNewACL)
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
//
|
|
// Initialize the new ACL.
|
|
//
|
|
if(!InitializeAcl(pNewACL, cbNewACL, ACL_REVISION))
|
|
{
|
|
|
|
SaveLastError();
|
|
//heapfree(pUserSID);
|
|
FreeMemory(&pUserSID);
|
|
//heapfree(szDomain);
|
|
FreeMemory(&szDomain);
|
|
//heapfree(pFileSD);
|
|
FreeMemory(pFileSD);
|
|
//heapfree(pNewSD);
|
|
FreeMemory(pNewSD);
|
|
//heapfree(pNewACL);
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
if(!AddAce(pNewACL,
|
|
ACL_REVISION,
|
|
0xffffffff,
|
|
pace,
|
|
pace->Header.AceSize))
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
pace->Header.AceFlags = CONTAINER_INHERIT_ACE ;
|
|
|
|
if(!AddAce(pNewACL,
|
|
pNewACL->AclRevision,
|
|
//ACL_REVISION,
|
|
0xffffffff,
|
|
pace,
|
|
pace->Header.AceSize))
|
|
{
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
//
|
|
// Set the new DACL to the file SD.
|
|
//
|
|
if (!SetSecurityDescriptorDacl(pNewSD, TRUE, pNewACL,
|
|
FALSE))
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
|
|
}
|
|
|
|
//
|
|
// Set the SD to the File.
|
|
//
|
|
if (!SetFileSecurity(lpszFileName, DACL_SECURITY_INFORMATION,
|
|
pNewSD))
|
|
{
|
|
|
|
SaveLastError();
|
|
|
|
FreeMemory(&pUserSID);
|
|
|
|
FreeMemory(&szDomain);
|
|
|
|
FreeMemory(pFileSD);
|
|
|
|
FreeMemory(pNewSD);
|
|
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
|
|
}
|
|
|
|
fResult = TRUE;
|
|
|
|
//
|
|
// Free allocated memory
|
|
//
|
|
|
|
if (pUserSID)
|
|
{
|
|
|
|
FreeMemory(&pUserSID);
|
|
}
|
|
|
|
if (szDomain)
|
|
{
|
|
|
|
FreeMemory(&szDomain);
|
|
}
|
|
|
|
if (pFileSD)
|
|
{
|
|
|
|
FreeMemory(pFileSD);
|
|
}
|
|
|
|
if (pNewSD)
|
|
{
|
|
|
|
FreeMemory(pNewSD);
|
|
}
|
|
|
|
if (pNewACL)
|
|
{
|
|
|
|
FreeMemory((LPVOID*)pNewACL);
|
|
}
|
|
|
|
if(NULL != pAliasAdminsSid)
|
|
{
|
|
FreeSid( pAliasAdminsSid );
|
|
}
|
|
|
|
return fResult;
|
|
}
|
|
|
|
|
|
DWORD
|
|
IsNTFSFileSystem(IN LPWSTR lpszPath,
|
|
BOOL bLocalSystem,
|
|
//BOOL bFileInUNCFormat,
|
|
BOOL bCurrDirTakeOwnAllFiles,
|
|
LPWSTR szUserName,
|
|
OUT PBOOL pbNTFSFileSystem)
|
|
/*++
|
|
Routine Description:
|
|
This routine finds whether Persistant ACLs are available are not
|
|
Arguments:
|
|
[ IN ] lpszPath - Path for which to find for Persistant ACLs.
|
|
[ IN ] bLocalSystem - Information whether local system or not
|
|
[ IN ] bFileInUNCFormat - whether file in UNC format or not
|
|
[ IN ] bCurrDirTakeOwnAllFiles - Whether takeown applied for curr directory
|
|
[ IN ] szUserName - user name
|
|
[ IN ] pbNTFSFileSystem - To know whether Persistant ACLs are available
|
|
|
|
|
|
Return Value:
|
|
EXIT_SUCCESS if the Function is passed
|
|
EXIT_FAILURE if the function fails
|
|
--*/
|
|
{
|
|
|
|
|
|
DWORD dwi = 0;
|
|
LPWSTR lpszTempDrive = NULL;
|
|
|
|
if(TRUE == bCurrDirTakeOwnAllFiles)
|
|
{
|
|
dwi = GetCurrentDirectory( 0, lpszTempDrive );
|
|
if( 0 == dwi )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
lpszTempDrive = (LPWSTR)AllocateMemory((dwi + 20) * sizeof(WCHAR));
|
|
if(NULL == lpszTempDrive)
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
dwi = GetCurrentDirectory( dwi + 10, lpszTempDrive );
|
|
if( 0 == dwi )
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
FREE_MEMORY(lpszTempDrive);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
|
|
dwi = StringLengthW(lpszPath, 0);
|
|
|
|
|
|
lpszTempDrive = (LPWSTR)AllocateMemory((dwi + 20) * sizeof(WCHAR));
|
|
if(NULL == lpszTempDrive)
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
StringCopy( lpszTempDrive, lpszPath, (GetBufferSize(lpszTempDrive) / sizeof(WCHAR)) );
|
|
|
|
}
|
|
|
|
|
|
if((TRUE == bLocalSystem) && (StringLengthW( szUserName, 0 ) != 0))
|
|
{
|
|
ShowMessage( stderr, IGNORE_LOCALCREDENTIALS );
|
|
|
|
/*if(FALSE == bFileInUNCFormat)
|
|
{
|
|
ShowMessage( stderr, IGNORE_LOCALCREDENTIALS );
|
|
}
|
|
else
|
|
{
|
|
ShowMessage( stderr, GetResString(IDS_IGNORE_CREDENTIALS) );
|
|
}*/
|
|
}
|
|
|
|
/*if((FALSE == bLocalSystem) && TRUE == bFileInUNCFormat)
|
|
{
|
|
ShowMessage( stderr, GetResString(IDS_IGNORE_CREDENTIALS) );
|
|
}*/
|
|
|
|
if(EXIT_FAILURE == IsNTFSFileSystem2(lpszTempDrive, pbNTFSFileSystem))
|
|
{
|
|
FREE_MEMORY(lpszTempDrive);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
FREE_MEMORY(lpszTempDrive);
|
|
|
|
return EXIT_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
DWORD
|
|
IsNTFSFileSystem2(IN LPWSTR lpszTempDrive,
|
|
OUT PBOOL pbNTFSFileSystem)
|
|
/*++
|
|
Routine Description:
|
|
This routine finds whether Persistant ACLs are available are not
|
|
Arguments:
|
|
[ IN ] lpszPath - Path for which to find for Persistant ACLs.
|
|
[ IN ] bLocalSystem - Information whether local system or not
|
|
[ IN ] bFileInUNCFormat - whether file in UNC format or not
|
|
[ IN ] bCurrDirTakeOwnAllFiles - Whether takeown applied for curr directory
|
|
[ IN ] szUserName - user name
|
|
[ IN ] pbNTFSFileSystem - To know whether Persistant ACLs are available
|
|
|
|
|
|
Return Value:
|
|
EXIT_SUCCESS if the function is passed
|
|
EXIT_FAILURE if the function fails
|
|
--*/
|
|
{
|
|
DWORD dwSysFlags = 0;
|
|
LPWSTR lpszMountPath = NULL;
|
|
WCHAR wszFileSysNameBuf[FILESYSNAMEBUFSIZE] ;
|
|
DWORD dwi = 0;
|
|
LPWSTR lpszTempPath = NULL;
|
|
|
|
SecureZeroMemory(wszFileSysNameBuf, FILESYSNAMEBUFSIZE * sizeof(WCHAR));
|
|
|
|
lpszTempPath = (LPWSTR)AllocateMemory((StringLengthW(lpszTempDrive, 0) + 10) * sizeof(WCHAR));
|
|
|
|
if(NULL == lpszTempPath)
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
StringCopy(lpszTempPath, lpszTempDrive, (GetBufferSize(lpszTempPath) / sizeof(WCHAR)));
|
|
|
|
StringConcat(lpszTempPath, L"\\\\", (GetBufferSize(lpszTempPath) / sizeof(WCHAR)) );
|
|
|
|
|
|
lpszMountPath = (LPWSTR)AllocateMemory((StringLengthW(lpszTempPath, 0) + 10) * sizeof(WCHAR));
|
|
|
|
if(NULL == lpszMountPath)
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
FREE_MEMORY(lpszTempPath);
|
|
return EXIT_FAILURE;
|
|
}
|
|
|
|
|
|
if(0 == GetVolumePathName( lpszTempPath, lpszMountPath, StringLengthW(lpszTempPath, 0)))
|
|
{
|
|
|
|
if( ( ERROR_BAD_NET_NAME == GetLastError() ) ||
|
|
( ERROR_BAD_NETPATH == GetLastError() ) ||
|
|
( ERROR_INVALID_NAME == GetLastError() ) )
|
|
{
|
|
SetLastError( ERROR_FILE_NOT_FOUND );
|
|
SaveLastError();
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL);
|
|
}
|
|
else
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
}
|
|
|
|
|
|
|
|
FREE_MEMORY(lpszMountPath);
|
|
FREE_MEMORY(lpszTempPath);
|
|
return EXIT_FAILURE;
|
|
|
|
};
|
|
|
|
|
|
dwi = GetVolumeInformation(lpszMountPath,NULL,0,NULL,NULL,&dwSysFlags,wszFileSysNameBuf,FILESYSNAMEBUFSIZE);
|
|
|
|
if(dwi == 0)
|
|
{
|
|
|
|
if( GetLastError() == ERROR_DIR_NOT_ROOT )
|
|
{
|
|
|
|
FREE_MEMORY(lpszMountPath);
|
|
FREE_MEMORY(lpszTempPath);
|
|
return EXIT_SUCCESS;
|
|
}
|
|
else
|
|
{
|
|
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_SYSTEM);
|
|
|
|
FREE_MEMORY(lpszMountPath);
|
|
FREE_MEMORY(lpszTempPath);
|
|
return EXIT_FAILURE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if((dwSysFlags & FS_PERSISTENT_ACLS) == FS_PERSISTENT_ACLS)
|
|
{
|
|
*pbNTFSFileSystem = TRUE;
|
|
}
|
|
|
|
FREE_MEMORY(lpszMountPath);
|
|
FREE_MEMORY(lpszTempPath);
|
|
return EXIT_SUCCESS;
|
|
}
|
|
|
|
}
|
|
|
|
DWORD RemoveStarFromPattern( IN OUT LPWSTR szPattern )
|
|
/*++
|
|
Routine Description:
|
|
This routine helps to remove the stars if there are more than one star available in pattern
|
|
Arguments:
|
|
[ IN OUT ] szPattern - Pattern to remove stars
|
|
|
|
|
|
Return Value:
|
|
EXIT_SUCCESS if the stars are removed
|
|
EXIT_FAILURE if the function fails
|
|
|
|
--*/
|
|
{
|
|
LPWSTR szTempPattern = NULL;
|
|
DWORD i = 0;
|
|
DWORD j = 0;
|
|
|
|
szTempPattern = (LPWSTR) AllocateMemory((StringLengthW(szPattern,0)+1)*sizeof(WCHAR) );
|
|
if( NULL == szTempPattern )
|
|
{
|
|
ShowLastErrorEx(stderr, SLE_TYPE_ERROR | SLE_INTERNAL );
|
|
return (EXIT_FAILURE);
|
|
}
|
|
|
|
while( szPattern[i] )
|
|
{
|
|
if( szPattern[i] == L'*' )
|
|
{
|
|
for(;szPattern[i]==L'*' && szPattern[i];i++);
|
|
szTempPattern[j] = L'*';
|
|
|
|
}
|
|
else
|
|
{
|
|
szTempPattern[j] = szPattern[i++];
|
|
}
|
|
j++;
|
|
}
|
|
szTempPattern[j]=0;
|
|
|
|
StringCopy( szPattern, szTempPattern, StringLengthW(szPattern,0)+1 );
|
|
FreeMemory(&szTempPattern);
|
|
return (EXIT_SUCCESS);
|
|
}
|
|
|