/* 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 library is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the license, or (at * your option) any later version. * * This library 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 Lesser * General Public License for more details. You should have received a copy * of the GNU Lesser 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 * LESSER 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: * * tracing.c * * Abstract: * * Likewise Security and Authentication Subsystem (LSASS) * * Tracing API * * Authors: Krishna Ganugapati (krishnag@likewisesoftware.com) * Sriram Nambakam (snambakam@likewisesoftware.com) */ #include "client.h" DWORD LsaSetTraceFlags( HANDLE hLsaConnection, PLSA_TRACE_INFO pTraceFlagArray, DWORD dwNumFlags ) { DWORD dwError = 0; PLSA_CLIENT_CONNECTION_CONTEXT pContext = (PLSA_CLIENT_CONNECTION_CONTEXT)hLsaConnection; LSA_IPC_SET_TRACE_INFO_REQ setTraceinfoReq; PLSA_IPC_ERROR pError = NULL; LWMsgMessage request = LWMSG_MESSAGE_INITIALIZER; LWMsgMessage response = LWMSG_MESSAGE_INITIALIZER; setTraceinfoReq.dwNumFlags = dwNumFlags; setTraceinfoReq.pTraceFlagArray = pTraceFlagArray; request.tag = LSA_Q_SET_TRACE_INFO; request.object = &setTraceinfoReq; dwError = MAP_LWMSG_ERROR(lwmsg_assoc_send_message_transact( pContext->pAssoc, &request, &response)); BAIL_ON_LSA_ERROR(dwError); switch (response.tag) { case LSA_R_SET_TRACE_INFO_SUCCESS: // response.object == NULL break; case LSA_R_SET_TRACE_INFO_FAILURE: pError = (PLSA_IPC_ERROR) response.object; dwError = pError->dwError; BAIL_ON_LSA_ERROR(dwError); break; default: dwError = EINVAL; BAIL_ON_LSA_ERROR(dwError); } cleanup: return dwError; error: if (response.object) { lwmsg_assoc_free_message(pContext->pAssoc, &response); } goto cleanup; } DWORD LsaEnumTraceFlags( HANDLE hLsaConnection, PLSA_TRACE_INFO* ppTraceFlagArray, PDWORD pdwNumFlags ) { DWORD dwError = 0; PLSA_CLIENT_CONNECTION_CONTEXT pContext = (PLSA_CLIENT_CONNECTION_CONTEXT)hLsaConnection; // Do not free pResultList and pError PLSA_TRACE_INFO_LIST pResultList = NULL; PLSA_IPC_ERROR pError = NULL; LWMsgMessage request = LWMSG_MESSAGE_INITIALIZER; LWMsgMessage response = LWMSG_MESSAGE_INITIALIZER; request.tag = LSA_Q_ENUM_TRACE_INFO; request.object = NULL; dwError = MAP_LWMSG_ERROR(lwmsg_assoc_send_message_transact( pContext->pAssoc, &request, &response)); BAIL_ON_LSA_ERROR(dwError); switch (response.tag) { case LSA_R_ENUM_TRACE_INFO_SUCCESS: pResultList = (PLSA_TRACE_INFO_LIST)response.object; *ppTraceFlagArray = pResultList->pTraceInfoArray; pResultList->pTraceInfoArray = NULL; *pdwNumFlags = pResultList->dwNumFlags; pResultList->dwNumFlags = 0; break; case LSA_R_ENUM_TRACE_INFO_FAILURE: pError = (PLSA_IPC_ERROR) response.object; dwError = pError->dwError; BAIL_ON_LSA_ERROR(dwError); break; default: dwError = EINVAL; BAIL_ON_LSA_ERROR(dwError); } cleanup: if (response.object) { lwmsg_assoc_free_message(pContext->pAssoc, &response); } return dwError; error: *pdwNumFlags = 0; *ppTraceFlagArray = NULL; goto cleanup; } DWORD LsaGetTraceFlag( HANDLE hLsaConnection, DWORD dwTraceFlag, PLSA_TRACE_INFO* ppTraceFlag ) { DWORD dwError = 0; PLSA_CLIENT_CONNECTION_CONTEXT pContext = (PLSA_CLIENT_CONNECTION_CONTEXT)hLsaConnection; PLSA_TRACE_INFO_LIST pResult = NULL; PLSA_IPC_ERROR pError = NULL; LWMsgMessage request = LWMSG_MESSAGE_INITIALIZER; LWMsgMessage response = LWMSG_MESSAGE_INITIALIZER; request.tag = LSA_Q_GET_TRACE_INFO; request.object = &dwTraceFlag; dwError = MAP_LWMSG_ERROR(lwmsg_assoc_send_message_transact( pContext->pAssoc, &request, &response)); BAIL_ON_LSA_ERROR(dwError); switch (response.tag) { case LSA_R_GET_TRACE_INFO_SUCCESS: pResult = (PLSA_TRACE_INFO_LIST) response.object; if (pResult->dwNumFlags != 1) { dwError = LW_ERROR_INTERNAL; BAIL_ON_LSA_ERROR(dwError); } *ppTraceFlag = pResult->pTraceInfoArray; pResult->pTraceInfoArray = NULL; pResult->dwNumFlags = 0; break; case LSA_R_GET_TRACE_INFO_FAILURE: pError = (PLSA_IPC_ERROR) response.object; dwError = pError->dwError; BAIL_ON_LSA_ERROR(dwError); break; default: dwError = EINVAL; BAIL_ON_LSA_ERROR(dwError); } cleanup: return dwError; error: if (response.object) { lwmsg_assoc_free_message(pContext->pAssoc, &response); } goto cleanup; }