/* Editor Settings: expandtabs and use 4 spaces for indentation * ex: set softtabstop=4 tabstop=8 expandtab shiftwidth=4: * * -*- mode: c, c-basic-offset: 4 -*- */ /* * Copyright Likewise Software 2004-2008 * All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or (at * your option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. You should have received a copy of the GNU General * Public License along with this program. If not, see * . * * LIKEWISE SOFTWARE MAKES THIS SOFTWARE AVAILABLE UNDER OTHER LICENSING * TERMS AS WELL. IF YOU HAVE ENTERED INTO A SEPARATE LICENSE AGREEMENT * WITH LIKEWISE SOFTWARE, THEN YOU MAY ELECT TO USE THE SOFTWARE UNDER THE * TERMS OF THAT SOFTWARE LICENSE AGREEMENT INSTEAD OF THE TERMS OF THE GNU * GENERAL PUBLIC LICENSE, NOTWITHSTANDING THE ABOVE NOTICE. IF YOU * HAVE QUESTIONS, OR WISH TO REQUEST A COPY OF THE ALTERNATE LICENSING * TERMS OFFERED BY LIKEWISE SOFTWARE, PLEASE CONTACT LIKEWISE SOFTWARE AT * license@likewisesoftware.com */ /* * Copyright (C) Likewise Software. All rights reserved. * * Module Name: * * main.c * * Abstract: * * Likewise Security and Authentication Subsystem (LSASS) * * Test Program for exercising LsaAllocSecurityIdentifierFromBinary * * Authors: Brian Dunstan (bdunstan@likewisesoftware.com) * */ #define _POSIX_PTHREAD_SEMANTICS 1 #include "config.h" #include "lsasystem.h" #include "lsadef.h" #include "lsa/lsa.h" #include "lwmem.h" #include "lwstr.h" #include "lwsecurityidentifier.h" #include "lsautils.h" DWORD ParseArgs( int argc, char* argv[], PSTR* ppszSIDHexStr ); VOID ShowUsage(); int main( int argc, char* argv[] ) { DWORD dwError = 0; PSTR pszSIDHexStr = NULL; PSTR pszSIDStr = NULL; UCHAR* pucSIDByteArr = NULL; DWORD dwSIDByteCount = 0; PLSA_SECURITY_IDENTIFIER pSID = NULL; dwError = ParseArgs(argc, argv, &pszSIDHexStr); BAIL_ON_LSA_ERROR(dwError); printf("Converting hex SID string: \"%s\"\n", pszSIDHexStr); dwError = LsaHexStrToByteArray( pszSIDHexStr, NULL, &pucSIDByteArr, &dwSIDByteCount); BAIL_ON_LSA_ERROR(dwError); dwError = LsaAllocSecurityIdentifierFromBinary( pucSIDByteArr, dwSIDByteCount, &pSID); BAIL_ON_LSA_ERROR(dwError); printf("LsaAllocSecurityIdentifierFromBinary() successful\n"); dwError = LsaGetSecurityIdentifierString(pSID, &pszSIDStr); BAIL_ON_LSA_ERROR(dwError); printf("LsaGetSecurityIdentifierString() returns: \"%s\"\n", pszSIDStr); cleanup: LW_SAFE_FREE_STRING(pszSIDHexStr); LW_SAFE_FREE_STRING(pszSIDStr); LW_SAFE_FREE_MEMORY(pucSIDByteArr); if (pSID) { LsaFreeSecurityIdentifier(pSID); } return (dwError); error: fprintf(stderr, "Failed to convert SID. Error code [%u]\n", dwError); goto cleanup; } DWORD ParseArgs( int argc, char* argv[], PSTR* ppszSIDHexStr ) { typedef enum { PARSE_MODE_OPEN = 0 } ParseMode; DWORD dwError = 0; int iArg = 1; PSTR pszArg = NULL; PSTR pszSIDHexStr = NULL; ParseMode parseMode = PARSE_MODE_OPEN; do { pszArg = argv[iArg++]; if (pszArg == NULL || *pszArg == '\0') { break; } switch (parseMode) { case PARSE_MODE_OPEN: if ((strcmp(pszArg, "--help") == 0) || (strcmp(pszArg, "-h") == 0)) { ShowUsage(); exit(0); } else { dwError = LwAllocateString(pszArg, &pszSIDHexStr); BAIL_ON_LSA_ERROR(dwError); } break; } } while (iArg < argc); if (LW_IS_NULL_OR_EMPTY_STR(pszSIDHexStr)) { fprintf(stderr, "Please specify a hex string, i.e. 01FA020101.\n"); ShowUsage(); exit(1); } *ppszSIDHexStr = pszSIDHexStr; cleanup: return dwError; error: LW_SAFE_FREE_STRING(pszSIDHexStr); *ppszSIDHexStr = NULL; goto cleanup; } void ShowUsage() { printf("Usage: test-lsa_alloc_security_identifier_from_binary \n"); }