Windows2003-3790/admin/snapin/rolemgr/util.h
2020-09-30 16:53:55 +02:00

747 lines
27 KiB
C++

//+---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 2000 - 2001.
//
// File: util.h
//
// Contents:
//
// History: 07-26-2001 Hiteshr Created
//
//----------------------------------------------------------------------------
//
//Action items are used to for list controls which manage membership of
//core properties. For ex: membership of group. Items can be
//deleted and added from listbox at any time, but they are added to core
//object only when apply button is pressed. Action item keeps track of action
//to do on each item on Apply.
//
enum ACTION
{
ACTION_NONE,
ACTION_ADD,
ACTION_REMOVE,
ACTION_REMOVED,
};
struct ActionItem
{
ActionItem(CBaseAz* pBaseAz):
m_pMemberAz(pBaseAz),
action(ACTION_NONE)
{}
~ActionItem()
{
if(m_pMemberAz)
delete m_pMemberAz;
}
CBaseAz* m_pMemberAz;
ACTION action;
};
typedef multimap<const CString*,ActionItem*,ltstr> ActionMap;
VOID
RemoveItemsFromActionMap(ActionMap& map);
//+----------------------------------------------------------------------------
// Function: IsValidStoreType
// Synopsis: Validates Store Type
//-----------------------------------------------------------------------------
BOOL IsValidStoreType(ULONG lStoreType);
//+----------------------------------------------------------------------------
// 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(IN HWND hWnd,
IN LONG ulStoreType,
IN const CString& strName);
//+----------------------------------------------------------------------------
// 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 ulStoreType,
IN const CString& strName,
IN BOOL bUseLDAP,
OUT CString& strFormalName);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// Function: DeleteSelectedRows
// Synopsis: Deletes the selected rows
//-----------------------------------------------------------------------------
void
DeleteSelectedRows(IN CListCtrl* pListCtrl);
//+----------------------------------------------------------------------------
// Function: SelectListCtrlItem
// Synopsis: Select the item in List Ctrl and mark it visible
// Arguments:
// Returns:
//-----------------------------------------------------------------------------
void
SelectListCtrlItem(IN CListCtrl* pListCtrl,
IN int iSelected);
//+----------------------------------------------------------------------------
// Synopsis: Empties the list and calls delete on items in list
//-----------------------------------------------------------------------------
template<class T>
VOID RemoveItemsFromList(IN CList<T, T>& list, BOOL bLocalFree = FALSE)
{
while(!list.IsEmpty())
{
if(bLocalFree)
LocalFree(list.RemoveTail());
else
delete list.RemoveTail();
}
}
template<class T>
VOID
EmptyList(IN CList<T, T>& list)
{
while(!list.IsEmpty())
list.RemoveTail();
}
//+----------------------------------------------------------------------------
// Synopsis: Gets long value from Edit box
// Returns: FALSE if edit box is empty. Assumes only numeric can be entered
// in edit box
//-----------------------------------------------------------------------------
BOOL
GetLongValue(CEdit& refEdit, LONG& reflValue, HWND hWnd = NULL);
//+----------------------------------------------------------------------------
// Synopsis: Sets long value in Edit box
// Returns:
//-----------------------------------------------------------------------------
VOID SetLongValue(CEdit* pEdit, LONG lValue);
//+----------------------------------------------------------------------------
// Synopsis: Converts a sid in binary format to a sid in string format
//-----------------------------------------------------------------------------
BOOL
ConvertSidToStringSid(IN PSID Sid,
OUT CString* pstrSid);
//+----------------------------------------------------------------------------
// Synopsis: Converts a sid in string format to sid in binary format
//-----------------------------------------------------------------------------
BOOL
ConvertStringSidToSid(IN const CString& strSid,
OUT PSID *ppSid);
//+----------------------------------------------------------------------------
// Function:GetStringSidFromSidCachecAz
// Synopsis:Gets the string sid from CSidCacheAz object
//-----------------------------------------------------------------------------
BOOL
GetStringSidFromSidCachecAz(CBaseAz* pBaseAz,
CString* pstrStringSid);
//+----------------------------------------------------------------------------
// Function: AddBaseAzItemsFromListCtrlToList
// Synopsis: Add items from ListCtrl to List
//-----------------------------------------------------------------------------
VOID
AddBaseAzItemsFromListCtrlToList(IN CListCtrl* pListCtrl,
OUT CList<CBaseAz*,CBaseAz*>& listBaseAz);
//+----------------------------------------------------------------------------
// 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,
CString& strFileName);
template<class CObjectAz, class CObjectAzNode>
class AddChildNodes
{
public:
static HRESULT DoEnum(IN CList<CBaseAz*, CBaseAz*>& listAzChildObject,
IN CBaseContainerNode* pContainerNode)
{
HRESULT hr = S_OK;
POSITION pos = listAzChildObject.GetHeadPosition();
for (int i=0;i < listAzChildObject.GetCount();i++)
{
CObjectAz* pObjectAz= dynamic_cast<CObjectAz*>(listAzChildObject.GetNext(pos));
if(pObjectAz)
{
//Create Container/Leaf Node corresponding to CObjectAz
CObjectAzNode* pObjectAzNode =
new CObjectAzNode(pContainerNode->GetComponentDataObject(),
pContainerNode->GetAdminManagerNode(),
pObjectAz);
if(!pObjectAzNode)
{
hr = E_OUTOFMEMORY;
DBG_OUT_HRESULT(hr);
break;
}
VERIFY(pContainerNode->AddChildToList(pObjectAzNode));
}
else
{
ASSERT(FALSE);
hr = E_UNEXPECTED;
break;
}
}
return hr;
}
};
typedef AddChildNodes<CApplicationAz, CApplicationNode> ADD_APPLICATION_FUNCTION;
typedef AddChildNodes<CScopeAz, CScopeNode> ADD_SCOPE_FUNCTION;
typedef AddChildNodes<CRoleAz, CRoleNode> ADD_ROLE_FUNCTION;
typedef AddChildNodes<COperationAz, COperationNode> ADD_OPERATION_FUNCTION;
typedef AddChildNodes<CTaskAz, CTaskNode> ADD_TASK_FUNCTION;
typedef AddChildNodes<CGroupAz, CGroupNode> ADD_GROUP_FUNCTION;
//+----------------------------------------------------------------------------
// 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);
////////////////////////////////////////////////////////////////////////////////////
// Theme support
class CThemeContextActivator
{
public:
CThemeContextActivator() : m_ulActivationCookie(0)
{
SHActivateContext (&m_ulActivationCookie);
}
~CThemeContextActivator()
{ SHDeactivateContext (m_ulActivationCookie); }
private:
ULONG_PTR m_ulActivationCookie;
};
//
//Error Handling
//
VOID
vFormatString(CString &strOutput, UINT nIDPrompt, va_list *pargs);
VOID
FormatString(CString &strOutput, UINT nIDPrompt, ...);
int DisplayMessageBox(HWND hWnd,
const CString& strMessage,
UINT uStyle);
VOID
GetSystemError(CString &strOutput, DWORD dwErr);
void DisplayError(HWND hWnd, UINT nIDPrompt, ...);
void
DisplayInformation(HWND hWnd, UINT nIDPrompt, ...);
int DisplayConfirmation(HWND hwnd,
UINT nIDPrompt,
...);
void
DisplayWarning(HWND hWnd, UINT nIDPrompt, ...);
BOOL
IsDeleteConfirmed(HWND hwndOwner,
CBaseAz& refBaseAz);
//
//This struct maps the common error messages for each object type
//
struct ErrorMap
{
OBJECT_TYPE_AZ eObjectType;
UINT idObjectType;
UINT idNameAlreadyExist;
UINT idInvalidName;
LPWSTR pszInvalidChars;
};
ErrorMap *GetErrorMap(OBJECT_TYPE_AZ eObjectType);
//+----------------------------------------------------------------------------
// Function: GetLSAConnection
// Synopsis: Wrapper for LsaOpenPolicy
//-----------------------------------------------------------------------------
LSA_HANDLE
GetLSAConnection(IN const CString& strServer,
IN DWORD dwAccessDesired);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// Function: OpenCreateAdminManager
// Synopsis: Open an existing an existing Authorization Store or
// creates a new Authorization Store and adds corresponding
// AdminManager object to snapin
// Arguments:IN hWnd: Handle of window for dialog box
// IN bNew: If True create a new Authz store else open existing
// one
// IN bOpenFromSavedConsole: This is valid when bNew is False.
// True if open is in resopnse to a console file.
// IN lStoreType: XML or AD
// IN strName: Name of store
// IN strDesc: Description. Only valid in case of new
// IN strScriptDir : Script directory
// IN pRootData: Snapin Rootdata
// IN pComponentData: ComponentData
// Returns:
//-----------------------------------------------------------------------------
HRESULT OpenCreateAdminManager(IN BOOL bNew,
IN BOOL bOpenFromSavedConsole,
IN ULONG lStoreType,
IN const CString& strStoreName,
IN const CString& strDesc,
IN const CString& strScriptDir,
IN CRootData* pRootData,
IN CComponentDataObject* pComponentData);
//+----------------------------------------------------------------------------
// Function: OpenAdminManager
// Synopsis: Open an existing 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 resopnse 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& strStoreDir,
IN CRootData* pRootData,
IN CComponentDataObject* pComponentData);
//+----------------------------------------------------------------------------
// 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);
BOOL FindDialogContextTopic(/*IN*/UINT nDialogID,
/*IN*/DWORD_PTR* pMap);
//+----------------------------------------------------------------------------
// 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);
struct CompareInfo
{
BOOL bActionItem;
UINT uiFlags;
int iColumn;
int iSortDirection;
};
//+----------------------------------------------------------------------------
// Function: ListCompareProc
// Synopsis: Comparison function used by list control
//-----------------------------------------------------------------------------
int CALLBACK
ListCompareProc(LPARAM lParam1,
LPARAM lParam2,
LPARAM lParamSort);
//+----------------------------------------------------------------------------
// 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 ColumnClicked,
int SortDirection,
UINT uiFlags,
BOOL bActionItem);
//+----------------------------------------------------------------------------
// Synopsis: Ensures that selection in listview control is visible
//-----------------------------------------------------------------------------
void
EnsureListViewSelectionIsVisible(CListCtrl *pListCtrl);
//+----------------------------------------------------------------------------
// 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 = NULL);
VOID
SetSel(CEdit& refEdit);
void
TrimWhiteSpace(CString& str);
//+----------------------------------------------------------------------------
// Function:LoadIcons
// Synopsis:Adds icons to imagelist
//-----------------------------------------------------------------------------
HRESULT
LoadIcons(LPIMAGELIST pImageList);
//+----------------------------------------------------------------------------
// Function: LoadImageList
// Synopsis: Loads image list
//-----------------------------------------------------------------------------
HIMAGELIST
LoadImageList(HINSTANCE hInstance, LPCTSTR pszBitmapID);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// Function: AddExtensionToFileName
// Synopsis: Functions adds .xml extension to name of file if no extension
// is present.
// Arguments:
// Returns:
//-----------------------------------------------------------------------------
VOID
AddExtensionToFileName(IN OUT CString& strFileName);
//+----------------------------------------------------------------------------
// Function:GetCurrentWorkingDirectory
// Synopsis:Gets the current working directory
//-----------------------------------------------------------------------------
BOOL
GetCurrentWorkingDirectory(IN OUT CString& strCWD);
//+----------------------------------------------------------------------------
// Function: GetFileExtension
// Synopsis: Get the extension of the file.
//-----------------------------------------------------------------------------
BOOL
GetFileExtension(IN const CString& strFileName,
OUT CString& strExtension);
//+--------------------------------------------------------------------------
// Function: AzRoleAdsOpenObject
// Synopsis: A wrapper around ADsOpenObject
//+--------------------------------------------------------------------------
HRESULT AzRoleAdsOpenObject(LPWSTR lpszPathName,
LPWSTR lpszUserName,
LPWSTR lpszPassword,
REFIID riid,
VOID** ppObject,
BOOL bBindToServer = FALSE);
VOID
GetDefaultADContainerPath(IN CADInfo& refAdInfo,
IN BOOL bAddServer,
IN BOOL bAddLdap,
OUT CString& strPath);
//+--------------------------------------------------------------------------
// Function: IsBizRuleWritable
// Synopsis: Checks if bizrules are writable for this object
//+--------------------------------------------------------------------------
BOOL
IsBizRuleWritable(HWND hWnd, CContainerAz& refBaseAz);
/******************************************************************************
Class: CCommandLineOptions
Purpose:class for reading the command line options for console file
******************************************************************************/
class CCommandLineOptions
{
public:
CCommandLineOptions():m_bInit(FALSE),
m_bCommandLineSpecified(FALSE),
m_lStoreType(AZ_ADMIN_STORE_INVALID)
{
}
void Initialize();
const CString& GetStoreName() const { return m_strStoreName;}
LONG GetStoreType() const { return m_lStoreType;}
BOOL CommandLineOptionSpecified() const { return m_bCommandLineSpecified;}
private:
BOOL m_bInit;
BOOL m_bCommandLineSpecified;
CString m_strStoreName;
LONG m_lStoreType;
};
extern CCommandLineOptions commandLineOptions;
//+----------------------------------------------------------------------------
// 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);
void
SetXMLStoreDirectory(IN CRoleRootData& roleRootData,
IN const CString& strXMLStorePath);
//+----------------------------------------------------------------------------
// 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);
//+----------------------------------------------------------------------------
// Function: ConvertToExpandedAndAbsolutePath
// Synopsis: Expands the environment variables in the input path and also
// makes it absolute if necessary.
//-----------------------------------------------------------------------------
void
ConvertToExpandedAndAbsolutePath(IN OUT CString& 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);