2020-09-30 16:53:55 +02:00

2803 lines
85 KiB
C++

//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 2000 - 2001.
//
// File: headers.h
//
// Contents:
//
// History: 07-26-2001 Hiteshr Created
//
//----------------------------------------------------------------------------
#include "headers.h"
//+----------------------------------------------------------------------------
// Function:IsValidStoreType
// Synopsis:Vaildates the store type
//-----------------------------------------------------------------------------
BOOL IsValidStoreType(ULONG lStoreType)
{
if((lStoreType == AZ_ADMIN_STORE_XML) ||
(lStoreType == AZ_ADMIN_STORE_AD))
return TRUE;
return FALSE;
}
//+----------------------------------------------------------------------------
// Function: AddColumnToListView
// Synopsis: Add Columns to Listview and set column width according to
// percentage specified in the COL_FOR_LV
// Arguments:IN pListCtrl: ListCtrl pointer
// IN pColForLV: Column Infomration Array
//
// Returns:
//-----------------------------------------------------------------------------
VOID
AddColumnToListView(IN CListCtrl* pListCtrl,
IN COL_FOR_LV* pColForLV)
{
if(!pListCtrl || !pColForLV)
{
ASSERT(pListCtrl);
ASSERT(pColForLV);
}
UINT iTotal = 0;
RECT rc;
pListCtrl->GetClientRect(&rc);
for( UINT iCol = 0; pColForLV[iCol].idText != LAST_COL_ENTRY_IDTEXT; ++iCol)
{
CString strHeader;
VERIFY(strHeader.LoadString(pColForLV[iCol].idText));
LV_COLUMN col;
col.mask = LVCF_FMT | LVCF_TEXT | LVCF_SUBITEM | LVCF_WIDTH;
col.fmt = LVCFMT_LEFT;
col.pszText = (LPWSTR)(LPCTSTR)strHeader;
col.iSubItem = iCol;
col.cx = (rc.right * pColForLV[iCol].iPercent) / 100;
pListCtrl->InsertColumn(iCol,&col);
iTotal += col.cx;
}
}
//+----------------------------------------------------------------------------
// Function: BaseAzInListCtrl
// Synopsis: Checks if Object of type eObjectTypeAz named strName is
// in the Listview. If its present, returns
// its index else returns -1.
// Arguments:IN pListCtrl: ListCtrl pointer
// IN strName: string to search for
// IN eObjectTypeAz Compare the object of this type only
//
// Returns: If its present, returns its index else returns -1
//-----------------------------------------------------------------------------
int
BaseAzInListCtrl(IN CListCtrl* pListCtrl,
IN const CString& strName,
IN OBJECT_TYPE_AZ eObjectTypeAz)
{
if(!pListCtrl)
{
ASSERT(pListCtrl);
return -1;
}
int iCount = pListCtrl->GetItemCount();
for( int i = 0; i < iCount; ++i)
{
CBaseAz* pBaseAz = (CBaseAz*)pListCtrl->GetItemData(i);
if(pBaseAz)
{
if((pBaseAz->GetObjectType() == eObjectTypeAz) &&
(pBaseAz->GetName() == strName))
return i;
}
}
return -1;
}
//+----------------------------------------------------------------------------
// Function: AddBaseAzFromListToListCtrl
// Synopsis: Take the items from List and Add them to ListCtrl. Doesn't
// add the items which are already in ListCtrl
// Arguments:listBaseAz: List of items
// pListCtrl: ListControl Pointer
// uiFlags : Column Info
// bCheckDuplicate: Check for duplicate items
// Returns: The index of the new item if it is successful; otherwise, -1
// NOTE: Function assume the Order of column is Name, Type and Description
//-----------------------------------------------------------------------------
void
AddBaseAzFromListToListCtrl(IN CList<CBaseAz*, CBaseAz*>& listBaseAz,
IN CListCtrl* pListCtrl,
IN UINT uiFlags,
IN BOOL bCheckDuplicate)
{
//Remember index of selected item
int iFirstSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED);
POSITION pos = listBaseAz.GetHeadPosition();
for (int i = 0; i < listBaseAz.GetCount(); i++)
{
CBaseAz* pBaseAz = listBaseAz.GetNext(pos);
//Check if item is in ListControl
if(!bCheckDuplicate ||
BaseAzInListCtrl(pListCtrl,
pBaseAz->GetName(),
pBaseAz->GetObjectType()) == -1)
{
VERIFY( AddBaseAzToListCtrl(pListCtrl,
pListCtrl->GetItemCount(),
pBaseAz,
uiFlags) != -1);
}
}
//Restore Selection
if(pListCtrl->GetItemCount() <= iFirstSelectedItem)
--iFirstSelectedItem;
SelectListCtrlItem(pListCtrl, iFirstSelectedItem);
}
//+----------------------------------------------------------------------------
// Function: AddActionItemFromListToListCtrl
// Synopsis: Take the Actions items from List and Add them to ListCtrl.
// Arguments:listBaseAz: List of items
// pListCtrl: ListControl Pointer
// uiFlags : Column Info
// bCheckDuplicate: Check for duplicate items
// Returns: The index of the new item if it is successful; otherwise, -1
// NOTE: Function assume the Order of column is Name, Type and Description
//-----------------------------------------------------------------------------
void
AddActionItemFromListToListCtrl(IN CList<ActionItem*, ActionItem*>& listActionItem,
IN CListCtrl* pListCtrl,
IN UINT uiFlags,
IN BOOL bCheckDuplicate)
{
//Remember index of selected item
int iFirstSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED);
POSITION pos = listActionItem.GetHeadPosition();
for (int i = 0; i < listActionItem.GetCount(); i++)
{
ActionItem* pActionItem = listActionItem.GetNext(pos);
if(pActionItem->action == ACTION_REMOVE ||
pActionItem->action == ACTION_REMOVED)
continue;
//Check if item is in ListControl
if(!bCheckDuplicate ||
BaseAzInListCtrl(pListCtrl,
(pActionItem->m_pMemberAz)->GetName(),
(pActionItem->m_pMemberAz)->GetObjectType()) == -1)
{
VERIFY( AddActionItemToListCtrl(pListCtrl,
pListCtrl->GetItemCount(),
pActionItem,
uiFlags) != -1);
}
}
//Restore Selection
if(pListCtrl->GetItemCount() <= iFirstSelectedItem)
--iFirstSelectedItem;
SelectListCtrlItem(pListCtrl, iFirstSelectedItem);
}
//+----------------------------------------------------------------------------
// Function: AddActionItemFromMapToListCtrl
// Synopsis: Take the Actions items from Map and Add them to ListCtrl.
// Arguments:listBaseAz: List of items
// pListCtrl: ListControl Pointer
// uiFlags : Column Info
// bCheckDuplicate: Check for duplicate items
// Returns: The index of the new item if it is successful; otherwise, -1
// NOTE: Function assume the Order of column is Name, Type and Description
//-----------------------------------------------------------------------------
void
AddActionItemFromMapToListCtrl(IN ActionMap& mapActionItem,
IN CListCtrl* pListCtrl,
IN UINT uiFlags,
IN BOOL bCheckDuplicate)
{
//Remember index of selected item
int iFirstSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED);
for (ActionMap::iterator it = mapActionItem.begin();
it != mapActionItem.end();
++it)
{
ActionItem* pActionItem = (*it).second;
if(pActionItem->action == ACTION_REMOVE ||
pActionItem->action == ACTION_REMOVED)
continue;
//Check if item is in ListControl
if(!bCheckDuplicate ||
BaseAzInListCtrl(pListCtrl,
(pActionItem->m_pMemberAz)->GetName(),
(pActionItem->m_pMemberAz)->GetObjectType()) == -1)
{
VERIFY( AddActionItemToListCtrl(pListCtrl,
pListCtrl->GetItemCount(),
pActionItem,
uiFlags) != -1);
}
}
//Restore Selection
if(pListCtrl->GetItemCount() <= iFirstSelectedItem)
--iFirstSelectedItem;
SelectListCtrlItem(pListCtrl, iFirstSelectedItem);
}
//+----------------------------------------------------------------------------
// Function: AddBaseAzToListCtrl
// Synopsis: Adds a new item to ListCtrl.
// Arguments:pListCtrl: ListControl Pointer
// iIndex: Index at which to Add
// pBaseAz: Item to add
// uiFlags: column info
// Returns: The index of the new item if it is successful; otherwise, -1
//-----------------------------------------------------------------------------
int
AddBaseAzToListCtrl(IN CListCtrl* pListCtrl,
IN int iIndex,
IN CBaseAz* pBaseAz,
IN UINT uiFlags)
{
if(!pListCtrl || !pBaseAz)
{
ASSERT(pListCtrl);
ASSERT(pBaseAz);
return -1;
}
//Add Name and Item Data
CString strName = pBaseAz->GetName();
int iNewIndex = pListCtrl->InsertItem(LVIF_TEXT|LVIF_STATE|LVIF_PARAM|LVIF_IMAGE,
iIndex,strName,0,0,
pBaseAz->GetImageIndex(),
(LPARAM)pBaseAz);
if(iNewIndex == -1)
return iNewIndex;
int iCol = 1;
if(uiFlags & COL_TYPE )
{
CString strType = pBaseAz->GetType();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strType);
iCol++;
}
if(uiFlags & COL_PARENT_TYPE)
{
CString strParentType = pBaseAz->GetParentType();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strParentType);
iCol++;
}
if(uiFlags & COL_DESCRIPTION)
{
//Add Description
CString strDesc = pBaseAz->GetDescription();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strDesc);
}
return iNewIndex;
}
//+----------------------------------------------------------------------------
// Function: AddActionItemToListCtrl
// Synopsis: Adds a new item to ListCtrl.
// Arguments:pListCtrl: ListControl Pointer
// iIndex: Index at which to Add
// pActionItem: Item to add
// uiFlags: column info
// Returns: The index of the new item if it is successful; otherwise, -1
//-----------------------------------------------------------------------------
int
AddActionItemToListCtrl(IN CListCtrl* pListCtrl,
IN int iIndex,
IN ActionItem* pActionItem,
IN UINT uiFlags)
{
if(!pListCtrl || !pActionItem)
{
ASSERT(pListCtrl);
ASSERT(pActionItem);
return -1;
}
CBaseAz* pBaseAz = pActionItem->m_pMemberAz;
//Add Name and Item Data
CString strName = pBaseAz->GetName();
int iNewIndex = pListCtrl->InsertItem(LVIF_TEXT|LVIF_STATE|LVIF_PARAM|LVIF_IMAGE,
iIndex,
strName,
0,0,
pBaseAz->GetImageIndex(),
(LPARAM)pActionItem);
if(iNewIndex == -1)
return iNewIndex;
int iCol = 1;
if(uiFlags & COL_TYPE )
{
CString strType = pBaseAz->GetType();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strType);
iCol++;
}
if(uiFlags & COL_PARENT_TYPE)
{
CString strParentType = pBaseAz->GetParentType();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strParentType);
iCol++;
}
if(uiFlags & COL_DESCRIPTION)
{
//Add Description
CString strDesc = pBaseAz->GetDescription();
pListCtrl->SetItemText(iNewIndex,
iCol,
(LPWSTR)(LPCTSTR)strDesc);
}
return iNewIndex;
}
//+----------------------------------------------------------------------------
// Function: EnableButtonIfSelectedInListCtrl
// Synopsis: Enables the button if something is selected in Listctrl
// Arguments:
// Returns: TRUE if Enabled the button, FALSE if didn't.
//-----------------------------------------------------------------------------
BOOL
EnableButtonIfSelectedInListCtrl(IN CListCtrl * pListCtrl,
IN CButton* pButton)
{
if(!pListCtrl || !pButton)
{
ASSERT(pListCtrl);
ASSERT(pButton);
return FALSE;
}
int nSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED);
if (nSelectedItem != -1)
{
pButton->EnableWindow(TRUE);
return TRUE;
}
else
{
if(pButton->GetFocus() == pButton)
pListCtrl->SetFocus();
pButton->EnableWindow(FALSE);
return FALSE;
}
}
//+----------------------------------------------------------------------------
// Function: DeleteSelectedRows
// Synopsis: Deletes the selected rows
//-----------------------------------------------------------------------------
void
DeleteSelectedRows(IN CListCtrl* pListCtrl)
{
//Remember the Position of first selected entry.
//In the end set the position back to it
int iFirstSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED);
int iSelectedItem = -1;
while( (iSelectedItem = pListCtrl->GetNextItem(-1, LVIS_SELECTED)) != -1)
{
pListCtrl->DeleteItem(iSelectedItem);
}
if(pListCtrl->GetItemCount() <= iFirstSelectedItem)
--iFirstSelectedItem;
SelectListCtrlItem(pListCtrl, iFirstSelectedItem);
}
//+----------------------------------------------------------------------------
// Function: SelectListCtrlItem
// Synopsis: Select the item in List Ctrl and mark it visible
//-----------------------------------------------------------------------------
void
SelectListCtrlItem(IN CListCtrl* pListCtrl,
IN int iSelected)
{
if(iSelected == -1)
iSelected = 0;
pListCtrl->SetItemState(iSelected,
LVIS_SELECTED| LVIS_FOCUSED,
LVIS_SELECTED| LVIS_FOCUSED);
pListCtrl->EnsureVisible(iSelected,FALSE);
}
//+----------------------------------------------------------------------------
// Function: AddBaseAzItemsFromListCtrlToList
// Synopsis: Add items from ListCtrl to List
//-----------------------------------------------------------------------------
VOID
AddBaseAzItemsFromListCtrlToList(IN CListCtrl* pListCtrl,
OUT CList<CBaseAz*,CBaseAz*>& listBaseAz)
{
if(!pListCtrl)
{
ASSERT(pListCtrl);
return;
}
int iCount = pListCtrl->GetItemCount();
for( int i = 0; i < iCount; ++i)
{
CBaseAz* pBaseAz = (CBaseAz*)pListCtrl->GetItemData(i);
listBaseAz.AddTail(pBaseAz);
}
}
//+----------------------------------------------------------------------------
// Synopsis: Gets long value from Edit box
// Returns: FALSE if edit box is empty. Assumes only numeric can be entered
// in edit box
//-----------------------------------------------------------------------------
GetLongValue(CEdit& refEdit, LONG& reflValue, HWND hWnd)
{
CString strValue;
refEdit.GetWindowText(strValue);
if(strValue.IsEmpty())
{
reflValue = 0;
return TRUE;
}
return ConvertStringToLong(strValue, reflValue, hWnd);
}
//+----------------------------------------------------------------------------
// Synopsis: Sets long value in Edit box
//-----------------------------------------------------------------------------
VOID SetLongValue(CEdit* pEdit, LONG lValue)
{
//Maximum required size for _itow is 33.
//When radix is 2, 32 char for 32bits + NULL terminator
WCHAR buffer[33];
_ltow(lValue,buffer,10);
pEdit->SetWindowText(buffer);
return;
}
//+----------------------------------------------------------------------------
// Synopsis: Converts a sid in binary format to a sid in string format
//-----------------------------------------------------------------------------
BOOL ConvertSidToStringSid(IN PSID pSid, OUT CString* pstrSid)
{
if(!pSid || !pstrSid)
{
ASSERT(pSid);
ASSERT(pstrSid);
return FALSE;
}
LPWSTR pszSid = NULL;
if(ConvertSidToStringSid(pSid, &pszSid))
{
ASSERT(pszSid);
*pstrSid = pszSid;
LocalFree(pszSid);
return TRUE;
}
return FALSE;
}
//+----------------------------------------------------------------------------
// Synopsis: Converts a sid in string format to sid in binary format
//-----------------------------------------------------------------------------
BOOL ConvertStringSidToSid(IN const CString& strSid, OUT PSID *ppSid)
{
if(!ppSid)
{
ASSERT(ppSid);
return FALSE;
}
return ::ConvertStringSidToSid((LPCTSTR)strSid,ppSid);
}
//+----------------------------------------------------------------------------
// Function:GetStringSidFromSidCachecAz
// Synopsis:Gets the string sid from CSidCacheAz object
//-----------------------------------------------------------------------------
BOOL
GetStringSidFromSidCachecAz(CBaseAz* pBaseAz,
CString* pstrStringSid)
{
if(!pBaseAz || !pstrStringSid)
{
ASSERT(pBaseAz);
ASSERT(pstrStringSid);
return FALSE;
}
CSidCacheAz *pSidCacheAz = dynamic_cast<CSidCacheAz*>(pBaseAz);
if(!pSidCacheAz)
{
ASSERT(pSidCacheAz);
return FALSE;
}
return ConvertSidToStringSid(pSidCacheAz->GetSid(), pstrStringSid);
}
//+----------------------------------------------------------------------------
// Function: AddAzObjectNodesToList
// Synopsis: Adds the nodes for object of type eObjectType to the Container
// node.
// Arguments:IN eObjectType: Type of object
// IN listAzChildObject: List of objects to be added
// IN pContainerNode: Container in snapin to which new nodes will
// be added.
// Returns:
//-----------------------------------------------------------------------------
HRESULT
AddAzObjectNodesToList(IN OBJECT_TYPE_AZ eObjectType,
IN CList<CBaseAz*, CBaseAz*>& listAzChildObject,
IN CBaseContainerNode* pContainerNode)
{
if(!pContainerNode)
{
ASSERT(pContainerNode);
return E_POINTER;
}
switch (eObjectType)
{
case APPLICATION_AZ:
return ADD_APPLICATION_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
case SCOPE_AZ:
return ADD_SCOPE_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
case GROUP_AZ:
return ADD_GROUP_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
case TASK_AZ:
return ADD_TASK_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
case ROLE_AZ:
return ADD_ROLE_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
case OPERATION_AZ:
return ADD_OPERATION_FUNCTION::DoEnum(listAzChildObject,pContainerNode);
}
ASSERT(FALSE);
return E_UNEXPECTED;
}
//
//Error Handling and Message Display Routines
//
VOID
vFormatString(CString &strOutput, UINT nIDPrompt, va_list *pargs)
{
CString strFormat;
if(!strFormat.LoadString(nIDPrompt))
return;
LPWSTR pszResult = NULL;
if(FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_STRING,
strFormat,
0,
0,
(LPTSTR)&pszResult,
1,
pargs) && pszResult)
{
strOutput = pszResult;
LocalFree(pszResult);
}
return;
}
VOID
FormatString(CString &strOutput, UINT nIDPrompt, ...)
{
CString strFormat;
if(!strFormat.LoadString(nIDPrompt))
return;
va_list args;
va_start(args, nIDPrompt);
LPWSTR pszResult = NULL;
if(FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_STRING,
strFormat,
0,
0,
(LPTSTR)&pszResult,
1,
&args))
{
strOutput = pszResult;
LocalFree(pszResult);
}
va_end(args);
return;
}
VOID
GetSystemError(CString &strOutput, DWORD dwErr)
{
LPWSTR pszErrorMsg = NULL;
if( FormatMessage (FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM,
NULL,
dwErr,
MAKELANGID (LANG_NEUTRAL, SUBLANG_DEFAULT),
(LPWSTR) &pszErrorMsg,
0,
NULL) && pszErrorMsg)
{
strOutput = pszErrorMsg;
LocalFree(pszErrorMsg);
}
else
{
strOutput.Format(L"<0x%08x>",dwErr);
}
return;
}
int DisplayMessageBox(HWND hWnd,
const CString& strMessage,
UINT uStyle)
{
CThemeContextActivator activator;
CString strTitle;
strTitle.LoadString(IDS_SNAPIN_NAME);
return ::MessageBox(hWnd, strMessage, strTitle, uStyle|MB_TASKMODAL);
}
int FormatAndDisplayMessageBox(HWND hWnd,
UINT uStyle,
UINT nIDPrompt,
va_list &args)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
CThemeContextActivator activator;
CString strMessage;
vFormatString(strMessage,nIDPrompt,&args);
int iReturn = 0;
if(!strMessage.IsEmpty())
iReturn = DisplayMessageBox(hWnd, strMessage,uStyle);
va_end(args);
return iReturn;
}
void
DisplayError(HWND hWnd, UINT nIDPrompt, ...)
{
va_list args;
va_start(args, nIDPrompt);
FormatAndDisplayMessageBox(hWnd, MB_OK | MB_ICONERROR,nIDPrompt,args);
va_end(args);
}
void
DisplayInformation(HWND hWnd, UINT nIDPrompt, ...)
{
va_list args;
va_start(args, nIDPrompt);
FormatAndDisplayMessageBox(hWnd, MB_OK | MB_ICONINFORMATION,nIDPrompt,args);
va_end(args);
}
void
DisplayWarning(HWND hWnd, UINT nIDPrompt, ...)
{
va_list args;
va_start(args, nIDPrompt);
FormatAndDisplayMessageBox(hWnd, MB_OK | MB_ICONWARNING, nIDPrompt,args);
va_end(args);
}
int
DisplayConfirmation(HWND hwnd, UINT nIDPrompt,...)
{
va_list args;
va_start(args, nIDPrompt);
int iReturn = FormatAndDisplayMessageBox(hwnd, MB_YESNO | MB_ICONEXCLAMATION,nIDPrompt,args);
va_end(args);
return iReturn;
}
BOOL
IsDeleteConfirmed(HWND hwndOwner,
CBaseAz& refBaseAz)
{
CString strType = refBaseAz.GetType();
strType.MakeLower();
return IDYES == DisplayConfirmation(hwndOwner,
IDS_DELETE_CONFIRMATION,
(LPCTSTR)strType,
(LPCTSTR)refBaseAz.GetName());
}
//
//Error Map for object types containing some common error info for
//each object type
//
ErrorMap ERROR_MAP[] =
{
{ ADMIN_MANAGER_AZ,
IDS_TYPE_ADMIN_MANAGER,
IDS_ADMIN_MANAGER_NAME_EXIST,
IDS_ADMIN_MANAGER_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
{ APPLICATION_AZ,
IDS_TYPE_APPLICATION,
IDS_APPLICATION_NAME_EXIST,
IDS_APPLICATION_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
{ SCOPE_AZ,
IDS_TYPE_SCOPE,
IDS_SCOPE_NAME_EXIST,
IDS_SCOPE_NAME_INVAILD,
L"",
},
{ GROUP_AZ,
IDS_TYPE_GROUP,
IDS_GROUP_NAME_EXIST,
IDS_GROUP_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
{ TASK_AZ,
IDS_TYPE_TASK,
IDS_TASK_OP_ALREADY_EXIST,
IDS_TASK_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
{ ROLE_AZ,
IDS_TYPE_ROLE,
IDS_ROLE_NAME_EXIST,
IDS_ROLE_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
{ OPERATION_AZ,
IDS_TYPE_OPERATION,
IDS_TASK_OP_ALREADY_EXIST,
IDS_OPERATION_NAME_INVAILD,
L"\\ / : * ? \" < > | [tab]",
},
};
ErrorMap *GetErrorMap(OBJECT_TYPE_AZ eObjectType)
{
for(int i = 0; i < ARRAYLEN(ERROR_MAP); ++i)
{
if(ERROR_MAP[i].eObjectType == eObjectType)
return ERROR_MAP + i;
}
return NULL;
}
//+----------------------------------------------------------------------------
// Function: GetLSAConnection
// Synopsis: Wrapper for LsaOpenPolicy
//-----------------------------------------------------------------------------
LSA_HANDLE
GetLSAConnection(IN const CString& strServer,
IN DWORD dwAccessDesired)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetLSAConnection)
LSA_OBJECT_ATTRIBUTES oa;
SECURITY_QUALITY_OF_SERVICE sqos;
sqos.Length = sizeof(SECURITY_QUALITY_OF_SERVICE);
sqos.ImpersonationLevel = SecurityImpersonation;
sqos.ContextTrackingMode = SECURITY_DYNAMIC_TRACKING;
sqos.EffectiveOnly = FALSE;
InitializeObjectAttributes(&oa, NULL, 0, NULL, NULL);
oa.SecurityQualityOfService = &sqos;
LSA_UNICODE_STRING uszServer = {0};
LSA_UNICODE_STRING *puszServer = NULL;
if (!strServer.IsEmpty() &&
RtlCreateUnicodeString(&uszServer, (LPCTSTR)strServer))
{
puszServer = &uszServer;
}
LSA_HANDLE hPolicy = NULL;
LsaOpenPolicy(puszServer, &oa, dwAccessDesired, &hPolicy);
if (puszServer)
RtlFreeUnicodeString(puszServer);
return hPolicy;
}
//+----------------------------------------------------------------------------
// Function:GetFileName
// Synopsis:Displays FileOpen dialog box and return file selected by user
// Arguments:hwndOwner : owner window
// bOpen: File must exist
// nIDTitle : title of open dialog box
// pszFilter : filter
// strFileName : gets selected file name
//
//-----------------------------------------------------------------------------
BOOL
GetFileName(IN HWND hwndOwner,
IN BOOL bOpen,
IN INT nIDTitle,
IN const CString& strInitFolderPath,
IN LPCTSTR pszFilter,
IN OUT CString& strFileName)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetFileName)
OPENFILENAME of;
ZeroMemory(&of,sizeof(OPENFILENAME));
WCHAR szFilePathBuffer[MAX_PATH];
ZeroMemory(szFilePathBuffer,sizeof(szFilePathBuffer));
of.lStructSize = sizeof(OPENFILENAME);
of.hwndOwner = hwndOwner;
of.lpstrFilter = pszFilter;
of.nFilterIndex = 1;
of.lpstrFile = szFilePathBuffer;
of.nMaxFile = MAX_PATH;
of.lpstrInitialDir = (LPCWSTR)strInitFolderPath;
if(nIDTitle)
{
CString strTitle;
if(strTitle.LoadString(nIDTitle))
of.lpstrTitle = (LPWSTR)(LPCTSTR)strTitle;
}
of.Flags = OFN_HIDEREADONLY;
if(bOpen)
of.Flags |= (OFN_FILEMUSTEXIST |OFN_PATHMUSTEXIST);
if(GetOpenFileName(&of))
{
strFileName = of.lpstrFile;
return TRUE;
}
return FALSE;
}
int ServerBrowseCallbackProc(HWND hwnd, UINT uMsg, LPARAM /*lParam*/, LPARAM lpData)
{
switch (uMsg)
{
case BFFM_INITIALIZED:
SendMessage(hwnd, BFFM_SETEXPANDED, TRUE, lpData);
SendMessage(hwnd, BFFM_SETSELECTION, TRUE, lpData);
break;
}
return 0;
}
//+----------------------------------------------------------------------------
// Function:GetFolderName
// Synopsis:Displays Folder selection dialog box and return folder selected
// by user
// Arguments:hwndOwner : owner window
// nIDTitle : title of dialog box
// strInitBrowseRoot : location of the root folder from which to
// start browsing
// strFolderName : gets selected file name
//-----------------------------------------------------------------------------
BOOL
GetFolderName(IN HWND hwndOwner,
IN INT nIDTitle,
IN const CString& strInitBrowseRoot,
IN OUT CString& strFolderName)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetFolderName)
BROWSEINFO bi;
ZeroMemory(&bi,sizeof(bi));
WCHAR szBuffer[MAX_PATH];
szBuffer[0] = 0;
CString strTitle;
VERIFY(strTitle.LoadString(nIDTitle));
bi.hwndOwner = hwndOwner;
bi.pszDisplayName = szBuffer;
bi.ulFlags = BIF_RETURNONLYFSDIRS | BIF_USENEWUI;
bi.lpszTitle = strTitle;
bi.lpfn = ServerBrowseCallbackProc;
bi.lParam = (LPARAM)(LPCWSTR)strInitBrowseRoot;
LPITEMIDLIST pidl = SHBrowseForFolder(&bi);
if(pidl)
{
WCHAR szFolderPath[MAX_PATH];
if(SHGetPathFromIDList(pidl,szFolderPath))
{
PathAddBackslash(szFolderPath);
strFolderName = szFolderPath;
}
}
return !strFolderName.IsEmpty();
}
//+----------------------------------------------------------------------------
// Function:GetADContainerPath
// Synopsis:Displays a dialog box to allow for selecting a AD container
//-----------------------------------------------------------------------------
BOOL
GetADContainerPath(HWND hWndOwner,
ULONG nIDCaption,
ULONG nIDTitle,
CString& strPath,
CADInfo& refAdInfo)
{
AFX_MANAGE_STATE(AfxGetStaticModuleState());
TRACE_FUNCTION_EX(DEB_SNAPIN,GetADContainerPath)
HRESULT hr = refAdInfo.GetRootDSE();
CHECK_HRESULT(hr);
if(FAILED(hr))
{
DisplayError(hWndOwner,IDS_CANNOT_ACCESS_AD);
return FALSE;
}
CString strRootDomainPath;
if(!refAdInfo.GetRootDomainDn().IsEmpty())
{
if(!refAdInfo.GetRootDomainDCName().IsEmpty())
{
strRootDomainPath = L"LDAP://" +
refAdInfo.GetRootDomainDCName() +
L"/" +
refAdInfo.GetRootDomainDn();
}
else
{
strRootDomainPath = L"LDAP://" + refAdInfo.GetRootDomainDn();
}
}
DSBROWSEINFOW dsbrowse;
ZeroMemory(&dsbrowse,sizeof(dsbrowse));
dsbrowse.cbStruct = sizeof(dsbrowse);
//Set Root of search to forest root
if(!strRootDomainPath.IsEmpty())
dsbrowse.pszRoot = (LPCTSTR)strRootDomainPath;
//Construct the path to which tree will expand on opening of
//dialog box
CString strInitialPath;
GetDefaultADContainerPath(refAdInfo,TRUE,TRUE,strInitialPath);
WCHAR szPath[MAX_PATH];
ZeroMemory(szPath,sizeof(szPath));
if(!strInitialPath.IsEmpty() && MAX_PATH > strInitialPath.GetLength())
{
wcscpy(szPath,(LPCTSTR)strInitialPath);
}
dsbrowse.hwndOwner = hWndOwner;
CString strCaption;
if(nIDCaption)
{
strCaption.LoadString(nIDCaption);
dsbrowse.pszCaption = strCaption;
}
CString strTitle;
if(nIDTitle)
{
strTitle.LoadString(nIDTitle);
dsbrowse.pszTitle = strTitle;
}
dsbrowse.pszPath = szPath;
dsbrowse.cchPath = MAX_PATH;
dsbrowse.dwFlags = DSBI_ENTIREDIRECTORY|DSBI_RETURN_FORMAT|DSBI_INCLUDEHIDDEN|DSBI_EXPANDONOPEN;
dsbrowse.dwReturnFormat = ADS_FORMAT_X500_NO_SERVER;
BOOL bRet = FALSE;
BOOL iRet = 0;
iRet = DsBrowseForContainer(&dsbrowse);
if(IDOK == iRet)
{
//Path contains LDAP:// string which we don't want
size_t nLen = wcslen(g_szLDAP);
if(_wcsnicmp(dsbrowse.pszPath,g_szLDAP,nLen) == 0 )
strPath = (dsbrowse.pszPath + nLen);
else
strPath = dsbrowse.pszPath;
bRet = TRUE;
}
else if (-1 == iRet)
{
Dbg(DEB_SNAPIN, "DsBrowseForContainer Failed\n");
DisplayError(hWndOwner,IDS_CANNOT_ACCESS_AD);
}
return bRet;
}
//+----------------------------------------------------------------------------
// Function:CompareBaseAzObjects
// Synopsis:Compares two baseaz objects for equivalance. If two pAzA and pAzB
// are two different instances of same coreaz object, they are equal
//-----------------------------------------------------------------------------
BOOL
CompareBaseAzObjects(CBaseAz* pAzA, CBaseAz* pAzB)
{
if(pAzA == pAzB)
return TRUE;
if(!pAzA || !pAzB)
return FALSE;
if(!(pAzA->GetObjectType() == pAzB->GetObjectType() &&
pAzA->GetName() == pAzB->GetName()))
return FALSE;
//If object if of type AdminManager, it must be same node
if(pAzA->GetObjectType() == ADMIN_MANAGER_AZ)
return (pAzA == pAzB);
//Two objects with same name and object type can exist under different
//parent-> Check if their parents are same->
if(pAzA->GetParentAz()->GetName() == pAzB->GetParentAz()->GetName())
return TRUE;
return FALSE;
}
//+----------------------------------------------------------------------------
//
//Below Code maps dialog box id to Help Map
//Ported from DNS Manager
//
//-----------------------------------------------------------------------------
#include "HelpMap.H"
#define BEGIN_HELP_MAP(map) static DWORD_PTR map[] = {
#define HELP_MAP_ENTRY(x) x, (DWORD_PTR)&g_aHelpIDs_##x ,
#define END_HELP_MAP 0, 0 };
#define NEXT_HELP_MAP_ENTRY(p) ((p)+2)
#define MAP_ENTRY_DLG_ID(p) (*p)
#define MAP_ENTRY_TABLE(p) ((DWORD*)(*(p+1)))
#define IS_LAST_MAP_ENTRY(p) (MAP_ENTRY_DLG_ID(p) == 0)
BEGIN_HELP_MAP(AuthManContextHelpMap)
HELP_MAP_ENTRY(IDD_ADD_GROUP)
HELP_MAP_ENTRY(IDD_ADD_OPERATION)
HELP_MAP_ENTRY(IDD_ADD_ROLE_DEFINITION)
HELP_MAP_ENTRY(IDD_ADD_TASK)
HELP_MAP_ENTRY(IDD_ADMIN_MANAGER_ADVANCED_PROPERTY)
HELP_MAP_ENTRY(IDD_ADMIN_MANAGER_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_APPLICATION_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_AUDIT)
HELP_MAP_ENTRY(IDD_GROUP_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_GROUP_LDAP_QUERY)
HELP_MAP_ENTRY(IDD_GROUP_MEMBER)
HELP_MAP_ENTRY(IDD_GROUP_NON_MEMBER)
HELP_MAP_ENTRY(IDD_NEW_APPLICATION)
HELP_MAP_ENTRY(IDD_NEW_AUTHORIZATION_STORE)
HELP_MAP_ENTRY(IDD_NEW_GROUP)
HELP_MAP_ENTRY(IDD_NEW_OPERATION)
HELP_MAP_ENTRY(IDD_NEW_ROLE_DEFINITION)
HELP_MAP_ENTRY(IDD_NEW_SCOPE)
HELP_MAP_ENTRY(IDD_NEW_TASK)
HELP_MAP_ENTRY(IDD_OPEN_AUTHORIZATION_STORE)
HELP_MAP_ENTRY(IDD_OPERATION_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_ROLE_DEFINITION_PROPERTY)
HELP_MAP_ENTRY(IDD_SCOPE_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_ROLE_DEFINITION_PROPERTY)
HELP_MAP_ENTRY(IDD_SECURITY)
HELP_MAP_ENTRY(IDD_TASK_DEFINITION_PROPERTY)
HELP_MAP_ENTRY(IDD_TASK_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_ROLE_DEFINITION_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_ROLE_GENERAL_PROPERTY)
HELP_MAP_ENTRY(IDD_ROLE_DEF_DIALOG)
HELP_MAP_ENTRY(IDD_BROWSE_AD_STORE)
HELP_MAP_ENTRY(IDD_SCRIPT)
HELP_MAP_ENTRY(IDD_ADD_ROLE_DEFINITION_1)
END_HELP_MAP
//+----------------------------------------------------------------------------
// Function:FindDialogContextTopic
// Synopsis:Finds the helpmap for a given dialog id
//-----------------------------------------------------------------------------
BOOL
FindDialogContextTopic(IN UINT nDialogID,
OUT DWORD_PTR* pMap)
{
if(!pMap)
{
ASSERT(pMap);
return FALSE;
}
const DWORD_PTR* pMapEntry = AuthManContextHelpMap;
while (!IS_LAST_MAP_ENTRY(pMapEntry))
{
if (nDialogID == MAP_ENTRY_DLG_ID(pMapEntry))
{
DWORD_PTR pTable = (DWORD_PTR)MAP_ENTRY_TABLE(pMapEntry);
ASSERT(pTable);
*pMap = pTable;
return TRUE;
}
pMapEntry = NEXT_HELP_MAP_ENTRY(pMapEntry);
}
return FALSE;
}
//+----------------------------------------------------------------------------
// Function:CanReadOneProperty
// Synopsis:Function tries to read IsWriteable property. If that fails displays
// an error message. This is used before adding property pages.
// if we cannot read IsWritable property,thereisn't much hope.
//-----------------------------------------------------------------------------
BOOL CanReadOneProperty(LPCWSTR pszName,
CBaseAz* pBaseAz)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,CanReadOneProperty)
if(!pBaseAz)
{
ASSERT(pBaseAz);
return FALSE;
}
BOOL bWrite;
HRESULT hr = pBaseAz->IsWritable(bWrite);
if(SUCCEEDED(hr))
{
return TRUE;
}
else
{
if(hr == HRESULT_FROM_WIN32(ERROR_INVALID_HANDLE))
{
DisplayError(NULL,
IDS_PROP_ERROR_OBJECT_DELETED,
pszName);
}
else
{
//Display Generic Error
CString strError;
GetSystemError(strError, hr);
DisplayError(NULL,
IDS_GENERIC_PROP_DISPLAY_ERROR,
(LPCWSTR)strError,
pszName);
}
return FALSE;
}
}
//+----------------------------------------------------------------------------
// Function: ListCompareProc
// Synopsis: Comparison function used by list control
//-----------------------------------------------------------------------------
int CALLBACK
ListCompareProc(LPARAM lParam1,
LPARAM lParam2,
LPARAM lParamSort)
{
int iResult = CSTR_EQUAL;
if(!lParam1 || !lParam2 || !lParamSort)
{
ASSERT(lParam1);
ASSERT(lParam2);
ASSERT(lParamSort);
return iResult;
}
CompareInfo *pCompareInfo = (CompareInfo*)lParamSort;
CBaseAz* pBaseAz1 = NULL;
CBaseAz* pBaseAz2 = NULL;
if(pCompareInfo->bActionItem)
{
pBaseAz1 = ((ActionItem*)lParam1)->m_pMemberAz;
pBaseAz2 = ((ActionItem*)lParam2)->m_pMemberAz;
}
else
{
pBaseAz1 = (CBaseAz*)lParam1;
pBaseAz2 = (CBaseAz*)lParam2;
}
CString str1;
CString str2;
int iColType = -1;
int iColParentType = -1;
int iColDescription = -1;
int iCol = 1;
if(pCompareInfo->uiFlags & COL_TYPE )
{
iColType = iCol++;
}
if(pCompareInfo->uiFlags & COL_PARENT_TYPE)
{
iColParentType = iCol++;
}
if(pCompareInfo->uiFlags & COL_DESCRIPTION)
{
iColDescription = iCol++;
}
if (pBaseAz1 && pBaseAz2)
{
if(pCompareInfo->iColumn == 0)
{
str1 = pBaseAz1->GetName();
str2 = pBaseAz2->GetName();
}
else if(pCompareInfo->iColumn == iColType)
{
str1 = pBaseAz1->GetType();
str2 = pBaseAz2->GetType();
}
else if(pCompareInfo->iColumn == iColDescription)
{
str1 = pBaseAz1->GetDescription();
str2 = pBaseAz2->GetDescription();
}
else if(pCompareInfo->iColumn == iColParentType)
{
str1 = pBaseAz1->GetParentType();
str2 = pBaseAz2->GetParentType();
}
iResult = CompareString(LOCALE_USER_DEFAULT, 0, str1, -1, str2, -1) - 2;
iResult *= pCompareInfo->iSortDirection;
}
return iResult;
}
//+----------------------------------------------------------------------------
// Function:SortListControl
// Synopsis:Sorts a list control
// Arguments:pListCtrl: List control to sort
// iColumnClicked: column clicked
// iSortDirection: direction in which to sort
// uiFlags: column info
// bActionItem: if item in list is actionitem
//-----------------------------------------------------------------------------
void
SortListControl(CListCtrl* pListCtrl,
int iColumnClicked,
int iSortDirection,
UINT uiFlags,
BOOL bActionItem)
{
if(!pListCtrl)
{
ASSERT(pListCtrl);
return;
}
CompareInfo compareInfo;
compareInfo.bActionItem = bActionItem;
compareInfo.iColumn = iColumnClicked;
compareInfo.iSortDirection = iSortDirection;
compareInfo.uiFlags = uiFlags;
pListCtrl->SortItems(ListCompareProc,
(DWORD_PTR)&compareInfo);
}
//+----------------------------------------------------------------------------
// Synopsis: Ensures that selection in listview control is visible
//-----------------------------------------------------------------------------
void
EnsureListViewSelectionIsVisible(CListCtrl *pListCtrl)
{
ASSERT(pListCtrl);
int iSelected = pListCtrl->GetNextItem(-1, LVNI_SELECTED);
if (-1 != iSelected)
pListCtrl->EnsureVisible(iSelected, FALSE);
}
//+----------------------------------------------------------------------------
// Synopsis:Convert input number in string format to long. if number is out
// of range displays a message.
//-----------------------------------------------------------------------------
BOOL
ConvertStringToLong(LPCWSTR pszInput,
long &reflongOutput,
HWND hWnd)
{
if(!pszInput)
{
ASSERT(pszInput);
return FALSE;
}
//
//Get the Max len of long
long lMaxLong = LONG_MAX;
WCHAR szMaxLongBuffer[34];
_ltow(lMaxLong,szMaxLongBuffer,10);
size_t nMaxLen = wcslen(szMaxLongBuffer);
//
//Get the length of input
LPCWSTR pszTempInput = pszInput;
if(pszInput[0] == L'-')
{
pszTempInput++;
}
//
//Length of input greater than length of Max Long, than
//input is out of range.
size_t nInputLen = wcslen(pszTempInput);
if(nInputLen > nMaxLen)
{
if(hWnd)
{
DisplayError(hWnd,IDS_GREATER_THAN_MAX_LONG,pszTempInput,szMaxLongBuffer);
}
return FALSE;
}
//
//Convert input to int64 and check its less that max integer
//
__int64 i64Input = _wtoi64(pszTempInput);
if(i64Input > (__int64)lMaxLong)
{
if(hWnd)
{
DisplayError(hWnd,IDS_GREATER_THAN_MAX_LONG,pszTempInput,szMaxLongBuffer);
}
return FALSE;
}
//
//Value is good
//
reflongOutput = _wtol(pszInput);
return TRUE;
}
VOID
SetSel(CEdit& refEdit)
{
refEdit.SetFocus();
refEdit.SetSel(0,-1);
}
//+----------------------------------------------------------------------------
// Function: ValidateStoreTypeAndName
// Synopsis: Validates the user entered AD Store Name
// Arguments: strName: User entered store name to verify
// Returns: TRUE if name is valid else false
//-----------------------------------------------------------------------------
BOOL
ValidateStoreTypeAndName(HWND hWnd,
LONG ulStoreType,
const CString& strName)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,ValidateStoreTypeAndName)
//Store Name is not entered in the valid format. We should come here only
//when store name is entered at the command line.
if((AZ_ADMIN_STORE_INVALID == ulStoreType) ||
strName.IsEmpty())
{
DisplayError(hWnd,IDS_INVALIDSTORE_ON_COMMANDLINE);
return FALSE;
}
//No validation is required for XML Store
if(ulStoreType == AZ_ADMIN_STORE_XML)
{
return TRUE;
}
ASSERT(ulStoreType == AZ_ADMIN_STORE_AD);
BOOL bRet = FALSE;
PDS_NAME_RESULT pResult = NULL;
do
{
//Get the store name with LDAP:// prefix
CString strFormalName;
NameToStoreName(AZ_ADMIN_STORE_AD,
strName,
TRUE,
strFormalName);
Dbg(DEB_SNAPIN, "AD store name entered is: %ws\n", CHECK_NULL(strFormalName));
CComPtr<IADsPathname> spPathName;
HRESULT hr = spPathName.CoCreateInstance(CLSID_Pathname,
NULL,
CLSCTX_INPROC_SERVER);
BREAK_ON_FAIL_HRESULT(hr);
hr = spPathName->Set(CComBSTR(strFormalName),
ADS_SETTYPE_FULL);
BREAK_ON_FAIL_HRESULT(hr);
//Get the DN entered by user
CComBSTR bstrDN;
hr = spPathName->Retrieve(ADS_FORMAT_X500_DN,&bstrDN);
BREAK_ON_FAIL_HRESULT(hr);
if(bstrDN.Length() == 0)
{
Dbg(DEB_SNAPIN, "spPathName->Retrieve returned 0 len DN\n");
break;
}
//Do a syntactical crack for the DN to see if its a valid DN
LPCWSTR pszName = bstrDN;
if( DsCrackNames(NULL,
DS_NAME_FLAG_SYNTACTICAL_ONLY,
DS_FQDN_1779_NAME,
DS_CANONICAL_NAME,
1,
&pszName,
&pResult) != DS_NAME_NO_ERROR)
{
Dbg(DEB_SNAPIN, "DsCrackName failed to crack the name");
break;
}
ASSERT(pResult);
if(pResult->rItems->status == DS_NAME_NO_ERROR)
{
bRet = TRUE;
}
}while(0);
if(pResult)
DsFreeNameResult(pResult);
if(!bRet)
{
DisplayError(hWnd,IDS_INVALID_AD_STORE_NAME);
}
return bRet;
}
//+----------------------------------------------------------------------------
// Function: NameToFormatStoreName
// Synopsis: Converts user entered name to format which core understands
// Arguments: ulStoreType: Type of store
// strName: User entered store name
// bUseLDAP:use LDAP string to format AD name instead msldap
// strFormalName: gets the output ldap name
//-----------------------------------------------------------------------------
void
NameToStoreName(IN LONG lStoreType,
IN const CString& strName,
IN BOOL bUseLDAP,
OUT CString& strFormalName)
{
strFormalName.Empty();
if(lStoreType == AZ_ADMIN_STORE_XML)
{
if(_wcsnicmp(strName,g_szMSXML,wcslen(g_szMSXML)) == 0 )
{
strFormalName = strName;
}
else
{
strFormalName = g_szMSXML + strName;
}
return;
}
else if(lStoreType == AZ_ADMIN_STORE_AD)
{
LPCWSTR lpcszPrefix = bUseLDAP ? g_szLDAP : g_szMSLDAP;
LPCWSTR lpcszOtherPrefix = bUseLDAP ? g_szMSLDAP : g_szLDAP;
if(_wcsnicmp(strName,lpcszPrefix,wcslen(lpcszPrefix)) == 0 )
{
strFormalName = strName;
}
else
{
size_t nlen = wcslen(lpcszOtherPrefix);
//Check if user has put other prefix in the name
if(_wcsnicmp(strName,lpcszOtherPrefix,nlen) == 0 )
{
strFormalName = lpcszPrefix + strName.Right(strName.GetLength() - (int)nlen);
}
else
{
strFormalName = lpcszPrefix + strName;
}
}
return;
}
ASSERT(FALSE);
return;
}
void
TrimWhiteSpace(CString& str)
{
str.TrimLeft(L"\t ");
str.TrimRight(L"\t ");
}
BOOL
TranslateNameFromDnToDns(const CString& strInputDN,
CString& strOutputDNS)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,TranslateNameFromDnToDns)
if(strInputDN.IsEmpty())
return FALSE;
strOutputDNS.Empty();
Dbg(DEB_SNAPIN, "DN of Forest is %ws\n", (LPCWSTR)strInputDN);
LPCWSTR pstrName = strInputDN;
PDS_NAME_RESULT pResult;
if( DS_NAME_NO_ERROR
== DsCrackNames(NULL,
DS_NAME_FLAG_SYNTACTICAL_ONLY,
DS_FQDN_1779_NAME,
DS_CANONICAL_NAME,
1,
(LPWSTR*)(&pstrName),
&pResult))
{
if(pResult &&
pResult->cItems == 1 &&
pResult->rItems[0].status == DS_NAME_NO_ERROR &&
pResult->rItems[0].pDomain)
{
strOutputDNS = pResult->rItems[0].pDomain;
Dbg(DEB_SNAPIN, "DNS of Forest is %ws\n", (LPCWSTR)strOutputDNS);
}
if(pResult)
{
DsFreeNameResult(pResult);
}
}
return !strOutputDNS.IsEmpty();
}
//+----------------------------------------------------------------------------
// Function:GetSearchObject
// Synopsis:Get IDirectorySearch object to search at forest
//-----------------------------------------------------------------------------
HRESULT
GetSearchObject(IN CADInfo& refAdInfo,
OUT CComPtr<IDirectorySearch>& refspSearchObject)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetSearchObject)
HRESULT hr = S_OK;
do
{
//
hr = refAdInfo.GetRootDSE();
BREAK_ON_FAIL_HRESULT(hr);
const CString& strForestDNS = refAdInfo.GetRootDomainDnsName();
CString strGCPath = L"GC://";
strGCPath += strForestDNS;
//
//Get IDirectorySearch Object
//
hr = AzRoleAdsOpenObject((LPWSTR)(LPCWSTR)strGCPath,
NULL,
NULL,
IID_IDirectorySearch,
(void**)&refspSearchObject);
BREAK_ON_FAIL_HRESULT(hr);
}while(0);
return hr;
}
//
// Attributes that we want the Object Picker to retrieve
//
static const LPCTSTR g_aszOPAttributes[] =
{
TEXT("distinguishedName"),
};
//+----------------------------------------------------------------------------
// Function:GetListOfAuthorizationStore
// Synopsis:Search at GC for AD policy stores and returns list.
//-----------------------------------------------------------------------------
HRESULT
GetListOfAuthorizationStore(IN CADInfo& refAdInfo,
OUT CList<CString,CString> &strList)
{
HRESULT hr = S_OK;
//If List is not empty, empty it
while(!strList.IsEmpty())
strList.RemoveHead();
do
{
TIMER("Time to search GC for AD Stores");
CComPtr<IDirectorySearch> spSearchObject;
CString str;
hr = GetSearchObject(refAdInfo,
spSearchObject);
BREAK_ON_FAIL_HRESULT(hr);
CDSSearch searchObject(spSearchObject);
searchObject.SetFilterString((LPWSTR)g_pszAuthorizationStoreQueryFilter);
searchObject.SetAttributeList((LPWSTR*)g_aszOPAttributes,1);
hr = searchObject.DoQuery();
BREAK_ON_FAIL_HRESULT(hr);
int iIndex = 0;
while(TRUE)
{
hr = searchObject.GetNextRow();
//We are done
if(hr == S_ADS_NOMORE_ROWS)
{
hr = S_OK;
break;
}
BREAK_ON_FAIL_HRESULT(hr);
ADS_SEARCH_COLUMN ColumnData;
hr = searchObject.GetColumn((LPWSTR)g_aszOPAttributes[0], &ColumnData);
if(SUCCEEDED(hr))
{
ASSERT(ADSTYPE_DN_STRING == ColumnData.dwADsType);
strList.AddTail(ColumnData.pADsValues->DNString);
searchObject.FreeColumn(&ColumnData);
}
}//End of while loop
}while(0);
if(!strList.IsEmpty())
return S_OK;
return hr;
}
/******************************************************************************
Class: CBaseAddDialog
Purpose:Displays a dialog box with list of AD Policy stores
******************************************************************************/
class CBrowseADStoreDlg : public CHelpEnabledDialog
{
public:
CBrowseADStoreDlg(CList<CString,CString>&strList,
CString& strSelectedADStorePath)
:CHelpEnabledDialog(IDD_BROWSE_AD_STORE),
m_strList(strList),
m_strSelectedADStorePath(strSelectedADStorePath)
{
}
virtual BOOL
OnInitDialog();
virtual void
OnOK();
private:
CList<CString,CString> &m_strList;
CString& m_strSelectedADStorePath;
};
BOOL
CBrowseADStoreDlg::
OnInitDialog()
{
CListCtrl* pListCtrl = (CListCtrl*)GetDlgItem(IDC_LIST);
ASSERT(pListCtrl);
//
//Initialize the list control
//
ListView_SetImageList(pListCtrl->GetSafeHwnd(),
LoadImageList(::AfxGetInstanceHandle (),
MAKEINTRESOURCE(IDB_ICONS)),
LVSIL_SMALL);
//Add ListBox Extended Style
pListCtrl->SetExtendedStyle(LVS_EX_FULLROWSELECT |
LVS_EX_INFOTIP);
//Add List box Columns
AddColumnToListView(pListCtrl,Col_For_Browse_ADStore_Page);
POSITION pos = m_strList.GetHeadPosition();
for (int i=0;i < m_strList.GetCount();i++)
{
pListCtrl->InsertItem(LVIF_TEXT|LVIF_STATE|LVIF_IMAGE,
i,
m_strList.GetNext(pos),
0,
0,
iIconStore,
NULL);
}
return TRUE;
}
void
CBrowseADStoreDlg::
OnOK()
{
TRACE_METHOD_EX(DEB_SNAPIN,CBrowseADStoreDlg,OnOK)
CListCtrl* pListCtrl = (CListCtrl*)GetDlgItem(IDC_LIST);
int iSelected = -1;
if((iSelected = pListCtrl->GetNextItem(-1, LVIS_SELECTED)) != -1)
{
m_strSelectedADStorePath = pListCtrl->GetItemText(iSelected,0);
}
CHelpEnabledDialog::OnOK();
}
//+----------------------------------------------------------------------------
// Function:BrowseAdStores
// Synopsis:Displays a dialog box with list of AD stores available.
// Arguments:strDN: Gets the selected ad store name
//-----------------------------------------------------------------------------
void
BrowseAdStores(IN HWND hwndOwner,
OUT CString& strDN,
IN CADInfo& refAdInfo)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,BrowseAdStores)
CList<CString,CString> strList;
if(SUCCEEDED(GetListOfAuthorizationStore(refAdInfo,
strList)))
{
if(!strList.IsEmpty())
{
CBrowseADStoreDlg dlg(strList,strDN);
dlg.DoModal();
}
else
{
DisplayInformation(hwndOwner,
IDS_NO_AD_STORE);
}
}
else
{
//Display Error
DisplayError(hwndOwner,
IDS_CANNOT_ACCESS_AD);
}
}
//+----------------------------------------------------------------------------
// Function:LoadIcons
// Synopsis:Adds icons to imagelist
//-----------------------------------------------------------------------------
HRESULT
LoadIcons(LPIMAGELIST pImageList)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,LoadIcons)
if(!pImageList)
{
ASSERT(pImageList);
return E_POINTER;
}
struct RESID2IICON
{
UINT uIconId; // Icon resource ID
int iIcon; // Index of the icon in the image list
};
const static RESID2IICON rgzLoadIconList[] =
{
{IDI_UNKNOWN_SID, iIconUnknownSid},
{IDI_COMPUTER, iIconComputerSid},
{IDI_GROUP, iIconGroup},
//iIconLocalGroup, //This is not used, but since its in the imagelist
// //i added an entry here
{IDI_USER, iIconUser,},
{ IDI_BASIC_GROUP, iIconBasicGroup},
{ IDI_LDAP_GROUP, iIconLdapGroup},
{ IDI_OPERATION, iIconOperation},
{ IDI_TASK, iIconTask},
{ IDI_ROLE_DEFINITION, iIconRoleDefinition},
{ IDI_STORE, iIconStore},
{ IDI_APP, iIconApplication},
{ IDI_ROLE, iIconRole},
{ IDI_ROLE_SNAPIN, iIconRoleSnapin},
{ IDI_SCOPE, iIconScope},
{ IDI_CONTAINER, iIconContainer},
{ 0, 0} // Must be last
};
for (int i = 0; rgzLoadIconList[i].uIconId != 0; i++)
{
HICON hIcon =
::LoadIcon (AfxGetInstanceHandle (),
MAKEINTRESOURCE (rgzLoadIconList[i].uIconId));
ASSERT (hIcon && "Icon ID not found in resources");
pImageList->ImageListSetIcon ((PLONG_PTR) hIcon,
rgzLoadIconList[i].iIcon);
}
return S_OK;
}
//+----------------------------------------------------------------------------
// Function: LoadImageList
// Synopsis: Loads image list
//-----------------------------------------------------------------------------
HIMAGELIST
LoadImageList(HINSTANCE hInstance, LPCTSTR pszBitmapID)
{
HIMAGELIST himl = NULL;
HBITMAP hbm = LoadBitmap(hInstance, pszBitmapID);
if (hbm != NULL)
{
BITMAP bm;
GetObject(hbm, sizeof(BITMAP), &bm);
himl = ImageList_Create(bm.bmHeight, // height == width
bm.bmHeight,
ILC_COLOR | ILC_MASK,
bm.bmWidth / bm.bmHeight,
0); // don't need to grow
if (himl != NULL)
ImageList_AddMasked(himl, hbm, CLR_DEFAULT);
DeleteObject(hbm);
}
return himl;
}
//+----------------------------------------------------------------------------
// Function: AddExtensionToFileName
// Synopsis: Functions adds .xml extension to name of file if no extension
// is present.
// Arguments:
// Returns:
//-----------------------------------------------------------------------------
VOID
AddExtensionToFileName(IN OUT CString& strFileName)
{
if(strFileName.IsEmpty())
return;
//if the last char is "\" don't do anything
if((strFileName.ReverseFind(L'\\') + 1) == strFileName.GetLength())
return;
int iLastDot = strFileName.ReverseFind(L'.');
if(iLastDot != -1)
{
//if there are three chars after last dot,
//file has extension. Index returned is zero based
if(strFileName.GetLength() == (iLastDot + 3 + 1))
return;
}
//File doesn't have extension. Add extension to the file.
strFileName += g_pszFileStoreExtension;
}
//+----------------------------------------------------------------------------
// Function: GetFileExtension
// Synopsis: Get the extension of the file.
//-----------------------------------------------------------------------------
BOOL
GetFileExtension(IN const CString& strFileName,
OUT CString& strExtension)
{
if(strFileName.IsEmpty())
return FALSE;
//Find the position of last dot
int iLastDot = strFileName.ReverseFind(L'.');
if(iLastDot != -1)
{
strExtension = strFileName.Right(strFileName.GetLength() - (iLastDot+1));
return TRUE;
}
return FALSE;
}
//+----------------------------------------------------------------------------
// Function:GetCurrentWorkingDirectory
// Synopsis:Gets the current working directory
//-----------------------------------------------------------------------------
BOOL
GetCurrentWorkingDirectory(IN OUT CString& strCWD)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetCurrentWorkingDirectory)
strCWD.Empty();
LPWSTR pszBuffer = NULL;
do
{
int nLen = 0;
WCHAR szBuffer[MAX_PATH];
if((nLen = GetCurrentDirectory(MAX_PATH,szBuffer)) != 0)
{
//If the return value is less than MAX_PATH, function
//was successful. If its greater, buffer is not big enough,
//dynamically allocate it below.
if(nLen < MAX_PATH)
{
strCWD = szBuffer;
break;
}
//Bigger buffer is required
pszBuffer = new WCHAR[nLen];
if(pszBuffer)
{
if((nLen = GetCurrentDirectory(nLen,pszBuffer)) != 0)
{
strCWD = pszBuffer;
break;
}
}
}
}while(0);//FALSE LOOP
if(pszBuffer)
delete [] pszBuffer;
//Add \ at the end of string
if(!strCWD.IsEmpty() &&
((strCWD.ReverseFind(L'\\') + 1) != strCWD.GetLength()))
{
strCWD += L'\\';
}
return !strCWD.IsEmpty();
}
VOID
RemoveItemsFromActionMap(ActionMap& mapActionItem)
{
for (ActionMap::iterator it = mapActionItem.begin();
it != mapActionItem.end();
++it)
{
delete (*it).second;
}
}
/******************************************************************************
Class: CADInfo
Purpose:Keeps a cache of Active Directory info avoiding multiple binds
******************************************************************************/
HRESULT
CADInfo::
GetRootDSE()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetRootDSE)
HRESULT hr = S_OK;
if(m_spRootDSE == NULL)
{
//
//Bind to RootDSE
//
hr = AzRoleAdsOpenObject(L"LDAP://RootDSE",
NULL,
NULL,
IID_IADs,
(void**)&m_spRootDSE);
CHECK_HRESULT(hr);
}
return hr;
}
const CString&
CADInfo::GetDomainDnsName()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetDomainDnsName)
if(m_strDomainDnsName.IsEmpty())
{
if(m_strDomainDn.IsEmpty())
GetDomainDn();
if(!m_strDomainDn.IsEmpty())
{
TranslateNameFromDnToDns(m_strDomainDn,m_strDomainDnsName);
Dbg(DEB_SNAPIN, "Domain Dns is: %ws\n", CHECK_NULL((LPCTSTR)m_strDomainDnsName));
}
}
return m_strDomainDnsName;
}
const CString&
CADInfo::GetDomainDn()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetDomainDn)
if((m_spRootDSE != NULL) && m_strDomainDn.IsEmpty())
{
// Get the default name
VARIANT Default;
VariantInit(&Default);
HRESULT hr = m_spRootDSE->Get (CComBSTR(L"defaultNamingContext"), &Default);
if(SUCCEEDED(hr))
{
ASSERT(VT_BSTR == Default.vt);
if(VT_BSTR == Default.vt)
{
m_strDomainDn = Default.bstrVal;
::VariantClear(&Default);
Dbg(DEB_SNAPIN, "Domain Dn is: %ws\n", CHECK_NULL((LPCTSTR)m_strDomainDn));
}
}
}
return m_strDomainDn;
}
const CString&
CADInfo::GetRootDomainDnsName()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetRootDomainDnsName)
if(m_strRootDomainDnsName.IsEmpty())
{
if(m_strRootDomainDn.IsEmpty())
GetRootDomainDn();
if(!m_strRootDomainDn.IsEmpty())
{
TranslateNameFromDnToDns(m_strRootDomainDn,m_strRootDomainDnsName);
Dbg(DEB_SNAPIN, "Root Domain Dns is: %ws\n", CHECK_NULL((LPCTSTR)m_strRootDomainDnsName));
}
}
return m_strRootDomainDnsName;
}
const CString&
CADInfo::GetRootDomainDn()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetRootDomainDn)
if((m_spRootDSE != NULL) && m_strRootDomainDn.IsEmpty())
{
// Get the default name
VARIANT Default;
VariantInit(&Default);
HRESULT hr = m_spRootDSE->Get(CComBSTR(L"rootDomainNamingContext"), &Default);
if(SUCCEEDED(hr))
{
//Convert DN to DNS name
m_strRootDomainDn = Default.bstrVal;
::VariantClear(&Default);
Dbg(DEB_SNAPIN, "Root Domain DN is: %ws\n", CHECK_NULL((LPCTSTR)m_strRootDomainDn));
}
}
return m_strRootDomainDn;
}
BOOL GetDcNameForDomain(IN const CString& strDomainName,
OUT CString& strDCName)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetDcNameForDomain)
if(strDomainName.IsEmpty())
{
return FALSE;
}
strDCName.Empty();
PDOMAIN_CONTROLLER_INFO pDomainInfo = NULL;
//Get the DC Name
DWORD dwErr = DsGetDcName(NULL,
(LPCWSTR)strDomainName,
NULL,
NULL,
DS_IS_DNS_NAME|DS_DIRECTORY_SERVICE_REQUIRED,
&pDomainInfo);
if((ERROR_SUCCESS == dwErr) && pDomainInfo)
{
LPWSTR pszDCName = pDomainInfo->DomainControllerName;
//The returned computer name is prefixed with \\
//Remove backslashes
if(pszDCName[0] == L'\\' && pszDCName[1] == L'\\')
pszDCName += 2;
//If a DNS-style name is returned, it is terminated with a period,
//indicating that the returned name is an absolute (non-relative)
//DNS name.
//We don't need period, remove it
//DomainControllerName is in DNS format.
if(pDomainInfo->Flags & DS_DNS_CONTROLLER_FLAG)
{
size_t dwLen = wcslen(pszDCName);
if(dwLen && (L'.' == pszDCName[dwLen -1]))
{
pszDCName[dwLen -1] = L'\0';
}
}
Dbg(DEB_SNAPIN, "DC is %ws\n", pszDCName);
strDCName = pszDCName;
NetApiBufferFree(pDomainInfo);
return TRUE;
}
return FALSE;
}
const CString&
CADInfo::
GetRootDomainDCName()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetRootDomainDCName)
if((m_spRootDSE != NULL) && m_strRootDomainDcName.IsEmpty())
{
GetDcNameForDomain(GetRootDomainDnsName(),m_strRootDomainDcName);
}
return m_strRootDomainDcName;
}
const CString&
CADInfo::
GetDomainDCName()
{
TRACE_METHOD_EX(DEB_SNAPIN,CADInfo,GetDomainDCName)
if((m_spRootDSE != NULL) && m_strDomainDcName.IsEmpty())
{
GetDcNameForDomain(GetDomainDnsName(),m_strDomainDcName);
}
return m_strDomainDcName;
}
//+--------------------------------------------------------------------------
// Function: AzRoleAdsOpenObject
// Synopsis: A thin wrapper around ADsOpenObject
//+--------------------------------------------------------------------------
HRESULT AzRoleAdsOpenObject(LPWSTR lpszPathName,
LPWSTR lpszUserName,
LPWSTR lpszPassword,
REFIID riid,
VOID** ppObject,
BOOL bBindToServer)
{
static DWORD additionalFlags = GetADsOpenObjectFlags();
DWORD dwFlags = ADS_SECURE_AUTHENTICATION | additionalFlags;
if (bBindToServer)
{
//
// If we know we are connecting to a specific server and not domain in general
// then pass the ADS_SERVER_BIND flag to save ADSI the trouble of figuring it out
//
dwFlags |= ADS_SERVER_BIND;
}
//
//Get IDirectorySearch Object
//
return ADsOpenObject(lpszPathName,
lpszUserName,
lpszPassword,
additionalFlags,
riid,
ppObject);
}
VOID
GetDefaultADContainerPath(IN CADInfo& refAdInfo,
IN BOOL bAddServer,
IN BOOL bAddLdap,
OUT CString& strPath)
{
strPath.Empty();
if(!refAdInfo.GetDomainDn().IsEmpty())
{
if(!refAdInfo.GetDomainDCName().IsEmpty())
{
if(bAddLdap)
{
strPath += L"LDAP://";
}
if(bAddServer)
{
strPath += refAdInfo.GetDomainDCName();
strPath += L"/";
}
strPath += g_pszProgramDataPrefix;
strPath += refAdInfo.GetDomainDn();
}
else
{
if(bAddLdap)
{
strPath = L"LDAP://";
}
strPath += g_pszProgramDataPrefix;
strPath += refAdInfo.GetDomainDn();
}
}
}
//+--------------------------------------------------------------------------
// Function: IsBizRuleWritable
// Synopsis: Checks if bizrules are writable for this object
//+--------------------------------------------------------------------------
BOOL
IsBizRuleWritable(HWND hWnd, CContainerAz& refBaseAz)
{
CScopeAz* pScopeAz = dynamic_cast<CScopeAz*>(&refBaseAz);
//Bizrules are always writable for at
//application level
if(!pScopeAz)
{
return TRUE;
}
BOOL bBizRuleWritable = TRUE;
HRESULT hr = pScopeAz->BizRulesWritable(bBizRuleWritable);
if(SUCCEEDED(hr) && !bBizRuleWritable)
{
DisplayInformation(hWnd,
IDS_BIZRULE_NOT_ALLOWED,
pScopeAz->GetName());
return FALSE;
}
return TRUE;
}
//+--------------------------------------------------------------------------
// Function: ParseStoreURL
// Synopsis: Extracts the store name and type from a store url
// store url are in format msldap://DN or msxml://filepath
//+--------------------------------------------------------------------------
void
ParseStoreURL(IN const CString& strStoreURL,
OUT CString& refstrStoreName,
OUT LONG& reflStoreType)
{
if(_wcsnicmp(strStoreURL,g_szMSXML,wcslen(g_szMSXML)) == 0 )
{
reflStoreType = AZ_ADMIN_STORE_XML;
refstrStoreName = strStoreURL.Mid((int)wcslen(g_szMSXML));
}
else if(_wcsnicmp(strStoreURL,g_szMSLDAP,wcslen(g_szMSLDAP)) == 0 )
{
reflStoreType = AZ_ADMIN_STORE_AD;
refstrStoreName = strStoreURL.Mid((int)wcslen(g_szMSLDAP));
}
else
{
reflStoreType = AZ_ADMIN_STORE_INVALID;
refstrStoreName = strStoreURL;
}
}
/******************************************************************************
Class: CCommandLineOptions
Purpose:class for reading the command line options for console file
******************************************************************************/
void
CCommandLineOptions::
Initialize()
{
TRACE_METHOD_EX(DEB_SNAPIN,CCommandLineOptions,Initialize)
//This should be called only once
if(m_bInit)
{
return;
}
m_bInit = TRUE;
// see if we have command line arguments
// Count of arguments
int cArgs = 0;
// Array of pointers to string
LPCWSTR * lpServiceArgVectors = (LPCWSTR *)CommandLineToArgvW(GetCommandLineW(),
&cArgs);
if (lpServiceArgVectors == NULL || cArgs <= 2)
{
// none, just return
return;
}
m_bCommandLineSpecified = TRUE;
CString strStoreURL = lpServiceArgVectors[2];
ParseStoreURL(strStoreURL,
m_strStoreName,
m_lStoreType);
Dbg(DEB_SNAPIN, "Store URL Name entered at commandline is %ws\n", CHECK_NULL(strStoreURL));
Dbg(DEB_SNAPIN, "Store Name entered at commandline is %ws\n", CHECK_NULL(m_strStoreName));
Dbg(DEB_SNAPIN, "AD store type entered is: %u\n", m_lStoreType);
}
//+----------------------------------------------------------------------------
// Function: OpenAdminManager
// Synopsis: Open an existing Authorization Store adds
// corresponding adminManager object to snapin
// Arguments:IN hWnd: Handle of window for dialog box
// IN bOpenFromSavedConsole: True if open is in response to a console
// file.
// IN lStoreType: XML or AD
// IN strName: Name of store
// IN strScriptDir : Script directory
// IN pRootData: Snapin Rootdata
// IN pComponentData: ComponentData
// Returns:
//-----------------------------------------------------------------------------
HRESULT OpenAdminManager(IN HWND hWnd,
IN BOOL bOpenFromSavedConsole,
IN ULONG lStoreType,
IN const CString& strStoreName,
IN const CString& strScriptDir,
IN CRootData* pRootData,
IN CComponentDataObject* pComponentData)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,OpenAdminManager)
if(!pRootData || !pComponentData)
{
ASSERT(pRootData);
ASSERT(pComponentData);
return E_POINTER;
}
//NTRAID#NTBUG9-706617-2002/07/17-hiteshr Our validation code cannot validate
//ADAM dn. Do not do any validation.
////Vaidate the store name
//if(!ValidateStoreTypeAndName(hWnd,
// lStoreType,
// strStoreName))
//{
// return E_INVALIDARG;
//}
HRESULT hr = OpenCreateAdminManager(FALSE,
bOpenFromSavedConsole,
lStoreType,
strStoreName,
L"",
strScriptDir,
pRootData,
pComponentData);
if(FAILED(hr))
{
//Display Error
if(hr == HRESULT_FROM_WIN32(ERROR_FILE_NOT_FOUND))
{
if(!bOpenFromSavedConsole)
{
::DisplayError(hWnd,
IDS_ADMIN_MANAGER_NOT_FOUND,
(LPCTSTR)strStoreName);
}
else
{
::DisplayError(hWnd,
IDS_CANNOT_FIND_AUTHORIZATION_STORE,
(LPCTSTR)strStoreName);
}
}
else if(hr == HRESULT_FROM_WIN32(ERROR_INVALID_NAME))
{
ErrorMap * pErrorMap = GetErrorMap(ADMIN_MANAGER_AZ);
::DisplayError(hWnd,
pErrorMap->idInvalidName,
pErrorMap->pszInvalidChars);
}
else
{
//Display Generic Error
CString strError;
GetSystemError(strError, hr);
::DisplayError(hWnd,
IDS_OPEN_ADMIN_MANAGER_GENERIC_ERROR,
(LPCTSTR)strError);
}
}
return hr;
}
//+----------------------------------------------------------------------------
// Function: GetDisplayNameFromStoreURL
// Synopsis: Get the display name for the store.
// Arguments: strPolicyURL: This is store url in msxml://filepath or
// msldap://dn format.
// strDisplayName: This gets the display name. For xml, display
// name is name of file, for AD its name of leaf element
// Returns:
//-----------------------------------------------------------------------------
void
GetDisplayNameFromStoreURL(IN const CString& strPolicyURL,
OUT CString& strDisplayName)
{
//Store URL format has msxml:// or msldap:// prefix
//Get the store name without any prefix
CString strStorePath;
LONG lStoreType;
ParseStoreURL(strPolicyURL,
strStorePath,
lStoreType);
//Default Display Name of store is path without prefix.
strDisplayName = strStorePath;
if(AZ_ADMIN_STORE_INVALID == lStoreType)
{
ASSERT(FALSE);
return;
}
//For XML store, display name is name of the file
if(AZ_ADMIN_STORE_XML == lStoreType)
{
strDisplayName = PathFindFileName(strStorePath);
}
//For AD store, display name is name of the leaf element
else
{
do
{
CComPtr<IADsPathname> spPathName;
HRESULT hr = spPathName.CoCreateInstance(CLSID_Pathname,
NULL,
CLSCTX_INPROC_SERVER);
BREAK_ON_FAIL_HRESULT(hr);
//The path which we have right now can be dn or server/dn.
//append LDAP:// to it.
CString strLDAPStorePath = g_szLDAP + strStorePath;
hr = spPathName->Set(CComBSTR(strLDAPStorePath),
ADS_SETTYPE_FULL);
BREAK_ON_FAIL_HRESULT(hr);
//Get the leaf element. This will return leaf element in the
//format cn=foo. We only want "foo".
CComBSTR bstrLeaf;
hr = spPathName->Retrieve(ADS_FORMAT_LEAF ,&bstrLeaf);
BREAK_ON_FAIL_HRESULT(hr);
if(bstrLeaf.Length())
{
strDisplayName = bstrLeaf;
strDisplayName.Delete(0,strDisplayName.Find(L'=') + 1);
}
}while(0);
}
}
void
SetXMLStoreDirectory(IN CRoleRootData& roleRootData,
IN const CString& strXMLStorePath)
{
CString strXMLStoreDirectory = GetDirectoryFromPath(strXMLStorePath);
roleRootData.SetXMLStorePath(strXMLStoreDirectory);
}
//+----------------------------------------------------------------------------
// Function: GetDirectoryFromPath
// Synopsis: Removes the file name from the input file path and return
// the folder path. For Ex: Input is C:\temp\foo.xml. Return
// value will be C:\temp\
//-----------------------------------------------------------------------------
CString
GetDirectoryFromPath(IN const CString& strPath)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,GetDirectoryFromPath)
Dbg(DEB_SNAPIN, "Input path", CHECK_NULL(strPath));
CString strDir;
if(strPath.GetLength() < MAX_PATH)
{
WCHAR szPath[MAX_PATH];
HRESULT hr = StringCchCopy(szPath,MAX_PATH,(LPCWSTR)strPath);
if(FAILED(hr))
return strDir;
if(!PathRemoveFileSpec(szPath))
return strDir;
PathAddBackslash(szPath);
strDir = szPath;
}
Dbg(DEB_SNAPIN, "Output Dir", CHECK_NULL(strDir));
return strDir;
}
//+----------------------------------------------------------------------------
// Function: ConvertToExpandedAndAbsolutePath
// Synopsis: Expands the environment variables in the input path and also
// makes it absolute if necessary.
//-----------------------------------------------------------------------------
void
ConvertToExpandedAndAbsolutePath(IN OUT CString& strPath)
{
TRACE_FUNCTION_EX(DEB_SNAPIN,ConvertToExpandedAndAbsolutePath)
Dbg(DEB_SNAPIN, "Input name", CHECK_NULL(strPath));
do
{
//
//Expand evironment variables in the path
//
WCHAR szExpandedPath[MAX_PATH];
DWORD dwSize = ExpandEnvironmentStrings(strPath,
szExpandedPath,
MAX_PATH);
//Buffer is small, allocate required buffer and try again
if(dwSize > MAX_PATH)
{
LPWSTR pszExpandedPath = (LPWSTR)LocalAlloc(LPTR,dwSize*sizeof(WCHAR));
if(pszExpandedPath)
{
dwSize = ExpandEnvironmentStrings(strPath,
pszExpandedPath,
dwSize);
if(dwSize)
{
strPath = pszExpandedPath;
}
LocalFree(pszExpandedPath);
pszExpandedPath = NULL;
if(!dwSize)
{
break;
}
}
}
else if(dwSize)
{
strPath = szExpandedPath;
}
else
{
break;
}
//Make absolute path
WCHAR szAbsolutePath[MAX_PATH];
dwSize = GetFullPathName(strPath,
MAX_PATH,
szAbsolutePath,
NULL);
//Buffer is small
if(dwSize > MAX_PATH)
{
LPWSTR pszAbsolutePath = (LPWSTR)LocalAlloc(LPTR,dwSize*sizeof(WCHAR));
if(pszAbsolutePath)
{
dwSize = GetFullPathName(strPath,
MAX_PATH,
pszAbsolutePath,
NULL);
if(dwSize)
{
strPath = pszAbsolutePath;
}
LocalFree(pszAbsolutePath);
pszAbsolutePath = NULL;
}
}
else if(dwSize)
{
strPath = szAbsolutePath;
}
}while(0);
Dbg(DEB_SNAPIN, "Output name", CHECK_NULL(strPath));
}
//+----------------------------------------------------------------------------
// Function: PreprocessScript
// Synopsis: Script is read from XML file and displayed multi line edit control.
// End of line in the XML is indicated by LF instead of CRLF sequence,
// however Edit Control requires CRLF sequence to format correctly and
// with only LF it displays everything in a single line with a box for
// LF char. This function checks if script uses LF for line termination
// and changes it with CRLF sequence.
//-----------------------------------------------------------------------------
void
PreprocessScript(CString& strScript)
{
WCHAR chLF = 0x0a;
WCHAR szCRLF[3] = {0x0D, 0x0A, 0};
if(strScript.Find(chLF) != -1 && strScript.Find(szCRLF) == -1)
{
CString strProcessedScript;
int len = strScript.GetLength();
for( int i = 0; i < len; ++i)
{
WCHAR ch = strScript.GetAt(i);
if(ch == chLF)
{
strProcessedScript += szCRLF;
}
else
{
strProcessedScript += ch;
}
}
strScript = strProcessedScript;
}
}