// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "sandbox/win/src/restricted_token_utils.h" #include "sandbox/win/tools/finder/finder.h" #define PARAM_IS(y) (argc > i) && (_wcsicmp(argv[i], y) == 0) void PrintUsage(wchar_t *application_name) { wprintf(L"\n\nUsage: \n %ls --token type --object ob1 [ob2 ob3] " L"--access ac1 [ac2 ac3] [--log filename]", application_name); wprintf(L"\n\n Token Types : \n\tLOCKDOWN \n\tRESTRICTED " L"\n\tLIMITED_USER \n\tINTERACTIVE_USER \n\tNON_ADMIN \n\tUNPROTECTED"); wprintf(L"\n Object Types: \n\tREG \n\tFILE \n\tKERNEL"); wprintf(L"\n Access Types: \n\tR \n\tW \n\tALL"); wprintf(L"\n\nSample: \n %ls --token LOCKDOWN --object REG FILE KERNEL " L"--access R W ALL", application_name); } int wmain(int argc, wchar_t* argv[]) { // Extract the filename from the path. wchar_t *app_name = wcsrchr(argv[0], L'\\'); if (!app_name) { app_name = argv[0]; } else { app_name++; } // parameters to read ATL::CString log_file; sandbox::TokenLevel token_type = sandbox::USER_LOCKDOWN; DWORD object_type = 0; DWORD access_type = 0; // no arguments if (argc == 1) { PrintUsage(app_name); return -1; } // parse command line. for (int i = 1; i < argc; ++i) { if (PARAM_IS(L"--token")) { i++; if (argc > i) { if (PARAM_IS(L"LOCKDOWN")) { token_type = sandbox::USER_LOCKDOWN; } else if (PARAM_IS(L"RESTRICTED")) { token_type = sandbox::USER_RESTRICTED; } else if (PARAM_IS(L"LIMITED_USER")) { token_type = sandbox::USER_LIMITED; } else if (PARAM_IS(L"INTERACTIVE_USER")) { token_type = sandbox::USER_INTERACTIVE; } else if (PARAM_IS(L"NON_ADMIN")) { token_type = sandbox::USER_NON_ADMIN; } else if (PARAM_IS(L"USER_RESTRICTED_SAME_ACCESS")) { token_type = sandbox::USER_RESTRICTED_SAME_ACCESS; } else if (PARAM_IS(L"UNPROTECTED")) { token_type = sandbox::USER_UNPROTECTED; } else { wprintf(L"\nAbord. Invalid token type \"%ls\"", argv[i]); PrintUsage(app_name); return -1; } } } else if (PARAM_IS(L"--object")) { bool is_object = true; do { i++; if (PARAM_IS(L"REG")) { object_type |= kScanRegistry; } else if (PARAM_IS(L"FILE")) { object_type |= kScanFileSystem; } else if (PARAM_IS(L"KERNEL")) { object_type |= kScanKernelObjects; } else { is_object = false; } } while(is_object); i--; } else if (PARAM_IS(L"--access")) { bool is_access = true; do { i++; if (PARAM_IS(L"R")) { access_type |= kTestForRead; } else if (PARAM_IS(L"W")) { access_type |= kTestForWrite; } else if (PARAM_IS(L"ALL")) { access_type |= kTestForAll; } else { is_access = false; } } while(is_access); i--; } else if (PARAM_IS(L"--log")) { i++; if (argc > i) { log_file = argv[i]; } else { wprintf(L"\nAbord. No log file specified"); PrintUsage(app_name); return -1; } } else { wprintf(L"\nAbord. Unrecognized parameter \"%ls\"", argv[i]); PrintUsage(app_name); return -1; } } // validate parameters if (0 == access_type) { wprintf(L"\nAbord, Access type not specified"); PrintUsage(app_name); return -1; } if (0 == object_type) { wprintf(L"\nAbord, Object type not specified"); PrintUsage(app_name); return -1; } // Open log file FILE * file_output; if (log_file.GetLength()) { errno_t err = _wfopen_s(&file_output, log_file, L"w"); if (err) { wprintf(L"\nAbord, Cannot open file \"%ls\"", log_file.GetBuffer()); return -1; } } else { file_output = stdout; } Finder finder_obj; finder_obj.Init(token_type, object_type, access_type, file_output); finder_obj.Scan(); fclose(file_output); return 0; }