Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

362 lines
16 KiB

  1. /*++
  2. 1998 Seagate Software, Inc. All rights reserved.
  3. Module Name:
  4. BaseHSM.h
  5. Abstract:
  6. Implementation of CSakNode. This is the base class for any
  7. of the node implementations, providing common functionality.
  8. Author:
  9. Rohde Wakefield [rohde] 12-Aug-1997
  10. Revision History:
  11. --*/
  12. #ifndef _BASEHSM_H
  13. #define _BASEHSM_H
  14. #define BHSM_MAX_CHILD_PROPS 15
  15. #define BHSM_MAX_NAME 40
  16. #define BHSM_MAX_REG_NAME 512
  17. #define BHSM_MAX_NODE_TYPES 10
  18. // Toolbar buttons for all nodes
  19. #define TB_CMD_VOLUME_SETTINGS 100
  20. #define TB_CMD_VOLUME_TOOLS 101
  21. #define TB_CMD_VOLUME_RULES 102
  22. #define TB_CMD_VOLUME_LIST_SCHED 110
  23. #define TB_CMD_VOLUME_LIST_NEW 111
  24. #define TB_CMD_MESE_COPY 120
  25. #define TB_CMD_CAR_COPIES 130
  26. typedef struct _RS_MMCButton {
  27. INT nBitmap;
  28. INT idCommand;
  29. BYTE fsState;
  30. BYTE fsType;
  31. UINT idButtonText;
  32. UINT idTooltipText;
  33. } RS_MMCBUTTON;
  34. #define MAX_TOOLBAR_BUTTONS 20
  35. // This is a dataobject-related structure that maintains basic information that needs to be passed
  36. // from one dataobject-taking method to another.
  37. struct INTERNAL {
  38. DATA_OBJECT_TYPES m_type; // What context is the data object.
  39. };
  40. //
  41. // Declare array that can be added to or completely cleared
  42. // Grows as needed
  43. //
  44. class CRsNodeArray : public CArray<ISakNode*, ISakNode*>
  45. {
  46. public:
  47. CRsNodeArray( ) { SetSize( 0, 10 ); };
  48. ~CRsNodeArray( ) { Clear( ); };
  49. ISakNode** begin( ) { return( GetData( ) ); };
  50. ISakNode** end( ) { return( GetData( ) + length( ) ); } ;
  51. INT length( ) { return( (INT)GetUpperBound( ) + 1 ); };
  52. HRESULT Add( ISakNode* pNode )
  53. {
  54. HRESULT hr = S_OK;
  55. try {
  56. CWsbBstrPtr keyAdd, keyEnum;
  57. CComPtr<ISakNodeProp> pNodeProp, pEnumProp;
  58. WsbAffirmHr( RsQueryInterface( pNode, ISakNodeProp, pNodeProp ) );
  59. WsbAffirmHr( pNodeProp->get_DisplayName_SortKey( &keyAdd ) );
  60. ISakNode*pNodeEnum;
  61. INT index;
  62. for( index = 0; index < length( ); index++ ) {
  63. pNodeEnum = GetAt( index );
  64. if( pNodeEnum ) {
  65. keyEnum.Free( );
  66. pEnumProp.Release( );
  67. if( SUCCEEDED( RsQueryInterface( pNodeEnum, ISakNodeProp, pEnumProp ) ) ) {
  68. if( SUCCEEDED( pEnumProp->get_DisplayName_SortKey( &keyEnum ) ) ) {
  69. if( _wcsicmp( keyAdd, keyEnum ) <= 0 ) {
  70. break;
  71. }
  72. }
  73. }
  74. }
  75. }
  76. try {
  77. CArray<ISakNode*, ISakNode*>::InsertAt( index, pNode );
  78. } catch( CMemoryException ) {
  79. WsbThrow( E_OUTOFMEMORY );
  80. }
  81. pNode->AddRef( );
  82. } WsbCatch( hr );
  83. return( hr );
  84. };
  85. void Clear( void )
  86. {
  87. ISakNode*pNode;
  88. for( int index = 0; index < length( ); index++ ) {
  89. pNode = GetAt( index );
  90. SetAt( index, 0 );
  91. if( pNode ) pNode->Release( );
  92. }
  93. RemoveAll( );
  94. };
  95. HRESULT CopyTo( int Index, ISakNode** ppNode )
  96. {
  97. if( !ppNode ) return( E_POINTER );
  98. *ppNode = GetAt( Index );
  99. if( *ppNode ) (*ppNode)->AddRef( );
  100. return S_OK;
  101. };
  102. };
  103. class ATL_NO_VTABLE CSakNode :
  104. public CComObjectRoot,
  105. public ISakNode,
  106. public IHsmEvent,
  107. public CComDualImpl<ISakNodeProp, &IID_ISakNodeProp, &LIBID_HSMADMINLib>,
  108. public IDataObject
  109. {
  110. public:
  111. CSakNode( ) : m_rTypeGuid(&(GUID_NULL)) {}
  112. HRESULT FinalConstruct( void );
  113. void FinalRelease( void );
  114. ULONG InternalAddRef( );
  115. ULONG InternalRelease( );
  116. // ISakNode methods
  117. STDMETHOD( InitNode ) ( ISakSnapAsk* pSakSnapAsk, IUnknown* pHsmObj, ISakNode* pParent );
  118. STDMETHOD( TerminateNode ) ( void );
  119. STDMETHOD( GetPrivateData ) ( OUT RS_PRIVATE_DATA* pData );
  120. STDMETHOD( SetPrivateData ) ( IN RS_PRIVATE_DATA Data );
  121. STDMETHOD( GetHsmObj ) ( IUnknown** ppHsmObj );
  122. STDMETHOD( GetNodeType ) ( GUID *pNodeType );
  123. STDMETHOD( FindNodeOfType ) ( REFGUID nodetype, ISakNode** ppNode );
  124. STDMETHOD( GetEnumState ) ( BOOL* pState );
  125. STDMETHOD( SetEnumState ) ( BOOL State );
  126. STDMETHOD( GetScopeID ) ( HSCOPEITEM* pid );
  127. STDMETHOD( SetScopeID ) ( HSCOPEITEM id );
  128. STDMETHOD( GetParent ) ( ISakNode ** ppParent );
  129. STDMETHOD( IsContainer ) ( void );
  130. STDMETHOD( CreateChildren ) ( void );
  131. STDMETHOD( EnumChildren ) ( IEnumUnknown ** ppEnum );
  132. STDMETHOD( DeleteChildren ) ( void );
  133. STDMETHOD( DeleteAllChildren ) ( void );
  134. STDMETHOD( ChildrenAreValid ) ( void );
  135. STDMETHOD( InvalidateChildren ) ( void );
  136. STDMETHOD( HasDynamicChildren ) ( void );
  137. STDMETHOD( EnumChildDisplayProps ) ( IEnumString ** ppEnum );
  138. STDMETHOD( EnumChildDisplayTitles ) ( IEnumString ** ppEnum );
  139. STDMETHOD( EnumChildDisplayPropWidths ) ( IEnumString ** ppEnum );
  140. STDMETHOD( GetMenuHelp ) ( LONG sCmd, BSTR * szHelp );
  141. STDMETHOD( SupportsPropertiesNoEngine ) ( void );
  142. STDMETHOD( SupportsProperties ) ( BOOL bMutliSelec );
  143. STDMETHOD( SupportsRefresh ) ( BOOL bMutliSelect );
  144. STDMETHOD( SupportsRefreshNoEngine ) ( );
  145. STDMETHOD( SupportsDelete ) ( BOOL bMutliSelec );
  146. STDMETHOD( AddPropertyPages ) ( RS_NOTIFY_HANDLE handle, IUnknown* pUnkPropSheetCallback, IEnumGUID *pEnumGuid, IEnumUnknown *pEnumUnkNode);
  147. STDMETHOD( ActivateView ) ( OLE_HANDLE );
  148. STDMETHOD( RefreshObject ) ( void );
  149. STDMETHOD( DeleteObject ) ( void );
  150. STDMETHOD( GetObjectId ) ( GUID *pObjectId );
  151. STDMETHOD( SetObjectId ) ( GUID pObjectId );
  152. STDMETHOD( SetupToolbar ) ( IToolbar *pToolbar );
  153. STDMETHOD( HasToolbar ) ( void );
  154. STDMETHOD( OnToolbarButtonClick ) ( IDataObject *pDataObject, long cmdId );
  155. STDMETHOD( IsValid ) ( );
  156. // IHsmEvent methods
  157. STDMETHOD( OnStateChange ) ( void );
  158. // ISakNodeProp methods
  159. STDMETHOD( get_DisplayName ) ( BSTR *pszName );
  160. STDMETHOD( put_DisplayName ) ( OLECHAR *pszName );
  161. STDMETHOD( get_DisplayName_SortKey ) ( BSTR *pszName );
  162. STDMETHOD( put_DisplayName_SortKey ) ( OLECHAR *pszName );
  163. STDMETHOD( get_Type ) ( BSTR *pszType );
  164. STDMETHOD( put_Type ) ( OLECHAR *pszType );
  165. STDMETHOD( get_Type_SortKey ) ( BSTR *pszType );
  166. STDMETHOD( get_Description ) ( BSTR *pszDesc );
  167. STDMETHOD( put_Description ) ( OLECHAR *pszDesc );
  168. STDMETHOD( get_Description_SortKey ) ( BSTR *pszDesc );
  169. // IDataObject methods
  170. public:
  171. // Implemented
  172. STDMETHOD( SetData ) ( LPFORMATETC lpFormatetc, LPSTGMEDIUM lpMedium, BOOL bRelease );
  173. STDMETHOD( GetData ) ( LPFORMATETC lpFormatetcIn, LPSTGMEDIUM lpMedium );
  174. STDMETHOD( GetDataHere ) ( LPFORMATETC lpFormatetc, LPSTGMEDIUM lpMedium );
  175. STDMETHOD( EnumFormatEtc ) ( DWORD dwDirection, LPENUMFORMATETC* ppEnumFormatEtc );
  176. // IDataObject methods that are Not Implemented
  177. private:
  178. STDMETHOD( QueryGetData ) ( LPFORMATETC /*lpFormatetc*/ )
  179. { return E_NOTIMPL; };
  180. STDMETHOD( GetCanonicalFormatEtc ) ( LPFORMATETC /*lpFormatetcIn*/, LPFORMATETC /*lpFormatetcOut*/ )
  181. { return E_NOTIMPL; };
  182. STDMETHOD( DAdvise ) ( LPFORMATETC /*lpFormatetc*/, DWORD /*advf*/, LPADVISESINK /*pAdvSink*/, LPDWORD /*pdwConnection*/ )
  183. { return E_NOTIMPL; };
  184. STDMETHOD( DUnadvise ) ( DWORD /*dwConnection*/ )
  185. { return E_NOTIMPL; };
  186. STDMETHOD( EnumDAdvise ) ( LPENUMSTATDATA* /*ppEnumAdvise*/ )
  187. { return E_NOTIMPL; };
  188. // Implementation
  189. public:
  190. CRsNodeArray m_Children; // Child nodes
  191. BOOL m_bEnumState; // TRUE if children have been enumerated
  192. HSCOPEITEM m_scopeID; // MMC scope item id.
  193. BOOL m_bChildrenAreValid; // TRUE if list of children is up-to-date
  194. CWsbBstrPtr m_szName; // name of node
  195. CWsbBstrPtr m_szName_SortKey; // name of node
  196. CWsbBstrPtr m_szType; // type of node
  197. CWsbBstrPtr m_szDesc; // description of node
  198. BSTR m_rgszChildPropIds[BHSM_MAX_CHILD_PROPS]; // array of child node property Ids
  199. BSTR m_rgszChildPropTitles[BHSM_MAX_CHILD_PROPS];// array of child node title properties
  200. BSTR m_rgszChildPropWidths[BHSM_MAX_CHILD_PROPS];// array of child node width properties
  201. INT m_cChildProps; // number of child node properties
  202. INT m_cChildPropsShow; // number of child node properties to show
  203. CComPtr<ISakNode> m_pParent;
  204. CComPtr<ISakSnapAsk> m_pSakSnapAsk; // pointer to the saksnap "ask" interface
  205. CComPtr<IUnknown> m_pHsmObj; // pointer to the underlying HSM COM object this node encapsulates
  206. const GUID* m_rTypeGuid; // pointer to the type guid for this node type
  207. BOOL m_bSupportsPropertiesNoEngine; // TRUE if this node has property pages.
  208. BOOL m_bSupportsPropertiesSingle; // TRUE if this node has property pages.
  209. BOOL m_bSupportsPropertiesMulti; // TRUE if this node has property pages.
  210. BOOL m_bSupportsRefreshSingle; // TRUE if this node supports the refresh method.
  211. BOOL m_bSupportsRefreshMulti; // TRUE if this node supports the refresh method.
  212. BOOL m_bSupportsRefreshNoEngine; // TRUE if this node supports the refresh method.
  213. BOOL m_bSupportsDeleteSingle; // TRUE if this node supports the delete method.
  214. BOOL m_bSupportsDeleteMulti; // TRUE if this node supports the delete method.
  215. BOOL m_bIsContainer; // TRUE if this node is a container type (as opposed to leaf).
  216. BOOL m_bHasDynamicChildren; // TRUE if this nodes immediate children change
  217. protected:
  218. GUID m_ObjectId;
  219. RS_PRIVATE_DATA m_PrivateData;
  220. INT m_ToolbarBitmap;
  221. INT m_cToolbarButtons;
  222. RS_MMCBUTTON m_ToolbarButtons[MAX_TOOLBAR_BUTTONS];
  223. // Clipboard formats that are required by the console
  224. public:
  225. static UINT m_cfNodeType;
  226. static UINT m_cfNodeTypeString;
  227. static UINT m_cfDisplayName;
  228. static UINT m_cfInternal;
  229. static UINT m_cfClassId;
  230. static UINT m_cfComputerName;
  231. static UINT m_cfEventLogViews;
  232. private:
  233. // Generic "GetData" which will allocate if told to
  234. HRESULT GetDataGeneric( LPFORMATETC lpFormatetcIn, LPSTGMEDIUM lpMedium, BOOL DoAlloc );
  235. // methods to retrieve particular "flavors" of data from a dataobject
  236. HRESULT RetrieveNodeTypeData( LPSTGMEDIUM lpMedium );
  237. HRESULT RetrieveNodeTypeStringData( LPSTGMEDIUM lpMedium );
  238. HRESULT RetrieveDisplayName( LPSTGMEDIUM lpMedium );
  239. HRESULT RetrieveInternal( LPSTGMEDIUM lpMedium );
  240. HRESULT RetrieveClsid( LPSTGMEDIUM lpMedium );
  241. HRESULT RetrieveComputerName( LPSTGMEDIUM lpMedium );
  242. HRESULT RetrieveEventLogViews( LPSTGMEDIUM lpMedium );
  243. // methods to store particular "flavors" of data from a dataobject
  244. HRESULT StoreInternal( LPSTGMEDIUM lpMedium );
  245. // helper method utilized by each of the above
  246. HRESULT Retrieve(const void* pBuffer, DWORD len, LPSTGMEDIUM lpMedium);
  247. HRESULT Store(void* pBuffer, DWORD len, LPSTGMEDIUM lpMedium);
  248. // actual data store in this dataobject.
  249. INTERNAL m_internal;
  250. // Maintain a connection point
  251. CComPtr<IUnknown> m_pUnkConnection;
  252. DWORD m_Advise;
  253. protected:
  254. void SetConnection( IUnknown *pUnkConnection );
  255. virtual HRESULT RefreshScopePane( );
  256. // Registry Helper Functions for derived classes. Not a part of any interface.
  257. static HRESULT LoadRegString( HKEY hKey, OLECHAR * szValName, OLECHAR * sz, OLECHAR * szDefault );
  258. static HRESULT LoadRegDWord( HKEY hKey, OLECHAR * szValName, DWORD * pdw, DWORD dwDefault );
  259. // Helper functions for derived classes to set result pane properties from resource strings
  260. HRESULT FreeChildProps();
  261. HRESULT SetChildProps (const TCHAR* ResIdPropsIds, LONG resIdPropsTitles, LONG resIdPropsWidths);
  262. // Helper Functions to create our children.
  263. static HRESULT NewChild( REFGUID nodetype, IUnknown** ppUnkChild );
  264. HRESULT InternalDelete( BOOL Recurse );
  265. HRESULT AddChild( ISakNode* pChild );
  266. // General Helper functions - not part of any interface.
  267. static HRESULT LoadContextMenu( UINT nId, HMENU *phMenu );
  268. static HRESULT GetCLSIDFromNodeType( REFGUID nodetype, const CLSID ** ppclsid );
  269. static const OLECHAR * CSakNode::GetClassNameFromNodeType( REFGUID Nodetype );
  270. static int AddScopeImage( UINT nId );
  271. static int AddResultImage( UINT nId );
  272. static BSTR SysAlloc64BitSortKey( LONGLONG Number );
  273. };
  274. // macro for multiple-inheritance (CSakNode and a ISakNode derived interface)
  275. // Forwards all CSakNode implemented members to CSakNode explicitly
  276. #define FORWARD_BASEHSM_IMPLS \
  277. STDMETHOD( get_DisplayName ) ( BSTR *pszName ) { return CSakNode::get_DisplayName( pszName ); } \
  278. STDMETHOD( put_DisplayName ) ( OLECHAR *pszName ) { return CSakNode::put_DisplayName( pszName ); } \
  279. STDMETHOD( get_DisplayName_SortKey ) ( BSTR *pszName ) { return CSakNode::get_DisplayName_SortKey( pszName ); } \
  280. STDMETHOD( put_DisplayName_SortKey ) ( OLECHAR *pszName ) { return CSakNode::put_DisplayName_SortKey( pszName ); } \
  281. STDMETHOD( get_Type ) ( BSTR *pszType ) { return CSakNode::get_Type( pszType ); } \
  282. STDMETHOD( put_Type ) ( OLECHAR *pszType ) { return CSakNode::put_Type( pszType ); } \
  283. STDMETHOD( get_Type_SortKey ) ( BSTR *pszType ) { return CSakNode::get_Type_SortKey( pszType ); } \
  284. STDMETHOD( get_Description ) ( BSTR *pszDesc ) { return CSakNode::get_Description( pszDesc ); } \
  285. STDMETHOD( put_Description ) ( OLECHAR *pszDesc ) { return CSakNode::put_Description( pszDesc ); } \
  286. STDMETHOD( get_Description_SortKey ) ( BSTR *pszDesc ) { return CSakNode::get_Description_SortKey( pszDesc ); } \
  287. // Typedef of class that implements IEnumUnknown
  288. typedef CComObject<CComEnum<IEnumUnknown, &IID_IEnumUnknown, IUnknown *,
  289. _CopyInterface<IUnknown> > > CEnumUnknown;
  290. // Typedef of class that implements IEnumVARIANT
  291. typedef CComObject<CComEnum<IEnumVARIANT, &IID_IEnumVARIANT, VARIANT,
  292. _Copy<VARIANT> > > CEnumVariant;
  293. // Typedef of class that implements IEnumString
  294. typedef CComObject<CComEnum<IEnumString, &IID_IEnumString, LPOLESTR,
  295. _Copy<LPOLESTR> > > CEnumString;
  296. // Typedef of class that implements IEnumGUID
  297. typedef CComObject<CComEnum<IEnumGUID, &IID_IEnumGUID, GUID,
  298. _Copy<GUID> > > CEnumGUID;
  299. #endif