|
|
///////////////////////////////////////////////////////////////////////////////
//
// File: obj.h
//
// History: 19-Nov-99 markder Created.
// 16-Nov-00 markder Converted from ShimDatabase.h, rewritten
// 15-Jan-02 jdoherty Modified code to add ID to additional tags.
//
// Desc: This file contains definitions of the SdbDatabase object model.
//
///////////////////////////////////////////////////////////////////////////////
#if !defined(AFX_OBJ_H__5C16373A_D713_46CD_B8BF_7755216C62E0__INCLUDED_)
#define AFX_OBJ_H__5C16373A_D713_46CD_B8BF_7755216C62E0__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
#include "xml.h"
#include "utils.h"
extern DWORD g_dwCurrentWriteFilter; extern DATE g_dtCurrentWriteRevisionCutoff;
//
// Common map types
//
typedef CMap<DWORD, DWORD, DWORD, DWORD> CMapDWORDToDWORD;
//
// These definitions are used by SdbMatchingFile::m_dwMask
//
#define SDB_MATCHINGINFO_SIZE 0x00000001
#define SDB_MATCHINGINFO_CHECKSUM 0x00000002
#define SDB_MATCHINGINFO_REGISTRY_ENTRY 0x00000004
#define SDB_MATCHINGINFO_COMPANY_NAME 0x00000008
#define SDB_MATCHINGINFO_PRODUCT_NAME 0x00000010
#define SDB_MATCHINGINFO_PRODUCT_VERSION 0x00000020
#define SDB_MATCHINGINFO_FILE_DESCRIPTION 0x00000040
#define SDB_MATCHINGINFO_BIN_FILE_VERSION 0x00000080
#define SDB_MATCHINGINFO_BIN_PRODUCT_VERSION 0x00000100
#define SDB_MATCHINGINFO_MODULE_TYPE 0x00000200
#define SDB_MATCHINGINFO_VERFILEDATEHI 0x00000400
#define SDB_MATCHINGINFO_VERFILEDATELO 0x00000800
#define SDB_MATCHINGINFO_VERFILEOS 0x00001000
#define SDB_MATCHINGINFO_VERFILETYPE 0x00002000
#define SDB_MATCHINGINFO_PE_CHECKSUM 0x00004000
#define SDB_MATCHINGINFO_FILE_VERSION 0x00008000
#define SDB_MATCHINGINFO_ORIGINAL_FILENAME 0x00010000
#define SDB_MATCHINGINFO_INTERNAL_NAME 0x00020000
#define SDB_MATCHINGINFO_LEGAL_COPYRIGHT 0x00040000
#define SDB_MATCHINGINFO_16BIT_DESCRIPTION 0x00080000
#define SDB_MATCHINGINFO_UPTO_BIN_PRODUCT_VERSION 0x00100000
#define SDB_MATCHINGINFO_PREVOSMAJORVERSION 0x00200000
#define SDB_MATCHINGINFO_PREVOSMINORVERSION 0x00400000
#define SDB_MATCHINGINFO_PREVOSPLATFORMID 0x00800000
#define SDB_MATCHINGINFO_PREVOSBUILDNO 0x01000000
#define SDB_MATCHINGINFO_LINKER_VERSION 0x02000000
#define SDB_MATCHINGINFO_16BIT_MODULE_NAME 0x04000000
#define SDB_MATCHINGINFO_LINK_DATE 0x08000000
#define SDB_MATCHINGINFO_UPTO_LINK_DATE 0x10000000
#define SDB_MATCHINGINFO_VER_LANGUAGE 0x20000000
#define SDB_MATCHINGINFO_UPTO_BIN_FILE_VERSION 0x40000000
//
// Possible MODULE_TYPE values
//
#define SDB_MATCHINGINFO_MODULE_TYPE_UNK 0
#define SDB_MATCHINGINFO_MODULE_TYPE_DOS 1
#define SDB_MATCHINGINFO_MODULE_TYPE_W16 2
#define SDB_MATCHINGINFO_MODULE_TYPE_W32 3
//
// Filters
//
#define SDB_FILTER_EXCLUDE_ALL 0x00000000
#define SDB_FILTER_DEFAULT 0x00000001
#define SDB_FILTER_OVERRIDE 0x00000002
#define SDB_FILTER_FIX 0x00000004
#define SDB_FILTER_APPHELP 0x00000008
#define SDB_FILTER_MSI 0x00000010
#define SDB_FILTER_DRIVER 0x00000020
#define SDB_FILTER_NTCOMPAT 0x00000040
#define SDB_FILTER_INCLUDE_ALL 0xFFFFFFFF
//
// This enumeration is used by SdbFlag::m_dwType
//
enum { SDB_FLAG_UNKNOWN = 0, SDB_FLAG_KERNEL, SDB_FLAG_USER, SDB_FLAG_NTVDM1, SDB_FLAG_NTVDM2, SDB_FLAG_NTVDM3, SDB_FLAG_SHELL, SDB_FLAG_MAX_TYPE };
//
// This enumeration is used by SdbOutputFile::m_OutputType
//
enum SdbOutputType { SDB_OUTPUT_TYPE_UNKNOWN = 0, SDB_OUTPUT_TYPE_SDB, SDB_OUTPUT_TYPE_HTMLHELP, SDB_OUTPUT_TYPE_MIGDB_INX, SDB_OUTPUT_TYPE_MIGDB_TXT, SDB_OUTPUT_TYPE_WIN2K_REGISTRY, SDB_OUTPUT_TYPE_REDIR_MAP, SDB_OUTPUT_TYPE_NTCOMPAT_INF, SDB_OUTPUT_TYPE_NTCOMPAT_MESSAGE_INF, SDB_OUTPUT_TYPE_APPHELP_REPORT };
//
// This enumeration is used by SdbCaller::m_CallerType
//
enum SdbCallerType { SDB_CALLER_EXCLUDE = 0, SDB_CALLER_INCLUDE };
//
// This enumeration is used by SdbShim::m_Purpose
//
enum SdbPurpose { SDB_PURPOSE_GENERAL = 0, SDB_PURPOSE_SPECIFIC };
//
// This enumeration is used by SdbMessage::m_Type
// These values are taken from badapps.h in shell\published
// and are compatible with Win2k, do not change
//
enum SdbAppHelpType { SDB_APPHELP_NONE = 0, SDB_APPHELP_NOBLOCK = 1, SDB_APPHELP_HARDBLOCK = 2, SDB_APPHELP_MINORPROBLEM = 3, SDB_APPHELP_REINSTALL = 4, SDB_APPHELP_VERSIONSUB = 5, SDB_APPHELP_SHIM = 6 };
enum SdbMatchOperationType { SDB_MATCH_ALL = 0, SDB_MATCH_ANY };
//
// This enumeration is used by SdbData::m_DataType
//
enum SdbDataValueType { eValueNone = REG_NONE, eValueDWORD = REG_DWORD, eValueQWORD = REG_QWORD, eValueString = REG_SZ, eValueBinary = REG_BINARY };
//
// Forward declarations of all classes
//
class SdbApp; class SdbExe; class SdbFile; class SdbShim; class SdbFlag; class SdbData; class SdbAction; class SdbPatch; class SdbLayer; class SdbCaller; class SdbMessage; class SdbLibrary; class SdbShimRef; class SdbFlagRef; class SdbAppHelp; class SdbDatabase; class SdbLayerRef; class SdbAppHelpRef; class SdbMsiPackage; class SdbContactInfo; class SdbMsiTransform; class SdbWinNTUpgrade; class SdbMatchingFile; class SdbMessageField; class SdbWin9xMigration; class SdbMsiTransformRef; class SdbMsiCustomAction; class SdbMessageTemplate; class SdbMatchingRegistryEntry;
class SdbMakefile; class SdbInputFile; class SdbOutputFile;
///////////////////////////////////////////////////////////////////////////////
//
// SdbArrayElement
//
// All elements contained in a SdbArray or SdbRefArray must be derived
// from this base class. It defines the basic m_csName property which is
// used throughout the object model for array lookup, sorting etc.
//
class SdbArrayElement { public: CString m_csName; ULONGLONG m_ullKey; // 64-bit key used to sort element within array
SdbDatabase* m_pDB; // Pointer to root database object.
DWORD m_dwFilter; DWORD m_dwSPMask; DWORD m_dwOSPlatform; CString m_csOSVersionSpec; CString m_csLangID; DATE m_dtLastRevision;
SdbArrayElement() : m_ullKey(0), m_pDB(NULL), m_dwSPMask(0xFFFFFFFF), m_dwOSPlatform(OS_PLATFORM_ALL), m_dwFilter(SDB_FILTER_DEFAULT), m_dtLastRevision(0) {}
virtual ~SdbArrayElement() { }
virtual int Compare(const SdbArrayElement* pElement);
virtual ULONGLONG MakeKey() { return SdbMakeIndexKeyFromString(m_csName); }
virtual void PropagateFilter(DWORD dwFilter);
//
// Virtual persistance functions
//
virtual BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); virtual BOOL WriteToSDB(PDB pdb); virtual BOOL WriteRefToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbArrayT
//
// This template is an extension of CPtrArray which
// designates that the array owns its elements or simply
// references them. If it owns them, it will delete them during
// destruction. Array elements must be derived from SdbArrayElement
// to be properly destructed.
//
// SdbArray and SdbRefArray are class instances of the template.
//
template <class T, BOOL bOwnsElements> class SdbArrayT; template <class T> class SdbArray : public SdbArrayT<T, TRUE> { }; template <class T> class SdbRefArray : public SdbArrayT<T, FALSE> { };
template <class T, BOOL bOwnsElements> class SdbArrayT : public CPtrArray { public: CMapStringToPtr m_mapName;
//
// 'LookupName' looks up an element in the array by name
//
SdbArrayElement* LookupName( LPCTSTR lpszName, long* piStart = NULL ) {
return LookupName(lpszName, NULL, piStart); }
SdbArrayElement* LookupName( LPCTSTR lpszName, LPCTSTR lpszLangID, long* piStart = NULL ) {
CString csName; SdbArrayElement* pElement;
if (lpszLangID) { csName.Format(_T("%s\\%s"), lpszLangID, lpszName); } else { csName = lpszName; } csName.MakeUpper();
if (!m_mapName.Lookup(csName, (LPVOID&)pElement)) { pElement = NULL; }
return pElement; }
~SdbArrayT() { LONG i = 0; if( bOwnsElements ) { for( i = 0; i < (LONG)GetSize(); i++ ) { delete (SdbArrayElement *) GetAt( i ); } } }
//
// 'AddOrdered' will add the element to the array sorted by name
//
int AddOrdered(SdbArrayElement* pElement) {
INT iLeft = 0; INT iRight = (INT) (GetSize() - 1); INT i = -1; INT iCmp; BOOL bFound = FALSE; SdbArrayElement* pElementCompare;
if (0 == pElement->m_ullKey) { pElement->m_ullKey = pElement->MakeKey(); }
if (iRight >= 0) {
do {
i = (iLeft + iRight) / 2; // middle ground
pElementCompare = (SdbArrayElement*)GetAt(i); // element that we're going to try
iCmp = pElement->Compare(pElementCompare);
if (iCmp <= 0) { iRight = i - 1; } if (iCmp >= 0) { iLeft = i + 1; }
} while (iRight >= iLeft); }
//
// if the element was found -- we insert right where it's at
// if not -- to the right of the current element
//
bFound = (iLeft - iRight) > 1; if (!bFound) { i = iRight + 1; }
CPtrArray::InsertAt(i, pElement);
return i; }
//
// 'Add' will simply add an element to the array, and add
// to the name map that is used for look up.
//
INT Add(SdbArrayElement* pElement, SdbDatabase* pDB = NULL, BOOL bOrdered = FALSE) { CString csName; pElement->m_pDB = pDB; csName.MakeUpper();
if (pElement->m_csLangID.GetLength()) { csName.Format(_T("%s\\%s"), pElement->m_csLangID, pElement->m_csName); } else { csName = pElement->m_csName; } csName.MakeUpper();
m_mapName.SetAt(csName, (LPVOID)pElement);
// also insert at the right place according to the imposed order
return (INT)(bOrdered ? AddOrdered(pElement) : CPtrArray::Add(pElement)); }
int Append(const SdbArray<T>& rgArray) { SdbArrayElement* pElement; int nFirstElement = -1; int nThisElement = -1;
//
// Cannot own elements
//
if (!bOwnsElements) { for (long i = 0; i < rgArray.GetSize(); i++) { pElement = (SdbArrayElement *) rgArray.GetAt(i);
nThisElement = Add(pElement, pElement->m_pDB);
if (nFirstElement == -1) { nFirstElement = nThisElement; } } }
return nFirstElement; }
DWORD GetFilteredCount(DWORD dwFilter, DATE dtRevisionCutoff = 0) { DWORD dwCount = 0; long i = 0; SdbArrayElement* pElem;
for (i = 0; i < GetSize(); i++) { pElem = (SdbArrayElement *) GetAt(i);
if ((pElem->m_dwFilter & dwFilter) && dtRevisionCutoff <= pElem->m_dtLastRevision) { dwCount++; } }
return dwCount; }
virtual void PropagateFilter(DWORD dwFilter) { long i = 0; SdbArrayElement* pElem;
for (i = 0; i < GetSize(); i++) { pElem = (SdbArrayElement *) GetAt(i);
pElem->PropagateFilter(dwFilter); } }
//
// 'ReadFromXML' will perform an XQL query on the pParentNode object and
// populate the array with members -- each of which read themselves in from
// the nodes returned by the query.
//
BOOL ReadFromXML(LPCTSTR szXQL, SdbDatabase* pDB, IXMLDOMNode* pParentNode, SdbArray<T>* pOwnerArray = NULL, BOOL bAddOrdered = FALSE, LPCTSTR lpszKeyAttribute = _T("NAME")) { BOOL bSuccess = FALSE; XMLNodeList XQL; IXMLDOMNodePtr cpNode; T* pNewObject = NULL; LONG i; CString csName;
if (!XQL.Query(pParentNode, szXQL)) { SDBERROR_PROPOGATE(); goto eh; }
for (i = 0; i < (LONG)XQL.GetSize(); i++) {
pNewObject = NULL;
if (!XQL.GetItem(i, &cpNode)) { SDBERROR_PROPOGATE(); goto eh; }
if (bOwnsElements) { pNewObject = (T*) new T();
if (pNewObject == NULL) { CString csFormat; csFormat.Format(_T("Error allocating new object to read \"%s\" tag"), szXQL); SDBERROR(csFormat); goto eh; }
if (!pNewObject->ReadFromXML(cpNode, pDB)) { SDBERROR_PROPOGATE(); goto eh; } } else { if (lpszKeyAttribute) { if (!GetAttribute(lpszKeyAttribute, cpNode, &csName)) { CString csFormat; csFormat.Format(_T("Error retrieving %s attribute on tag:\n\n%s\n\n"), lpszKeyAttribute, szXQL, GetXML(cpNode)); SDBERROR(csFormat); goto eh; } }
if (pOwnerArray == NULL) { SDBERROR(_T("Internal error: SdbArray::ReadFromXML() requires non-NULL ") _T("pOwnerArray for reference arrays.")); goto eh; }
pNewObject = (T*) pOwnerArray->LookupName(csName);
if (!pNewObject && g_bStrict) { CString csFormat; csFormat.Format(_T("Tag \"%s\" references unknown LIBRARY item \"%s\":\n\n%s\n\n"), szXQL, csName, GetXML(cpNode));
SDBERROR(csFormat); goto eh; } }
if (pNewObject) { Add(pNewObject, pDB, bAddOrdered); }
cpNode.Release(); }
bSuccess = TRUE;
eh: return bSuccess; }
//
// 'WriteToSDB' will write each of the elements in the array out
// to the SDB database specified by pdb.
//
BOOL WriteToSDB(PDB pdb, BOOL bReference = FALSE) { LONG i; T* pOb;
for (i = 0; i < (LONG)GetSize(); i++) { pOb = (T*) GetAt(i);
if ((g_dwCurrentWriteFilter & pOb->m_dwFilter) && (pOb->m_dtLastRevision != 0 ? g_dtCurrentWriteRevisionCutoff <= pOb->m_dtLastRevision : TRUE)) { if (bReference) { if (!pOb->WriteRefToSDB(pdb)) { return FALSE; } } else { if (!pOb->WriteToSDB(pdb)) { return FALSE; } } } }
return TRUE; }
};
///////////////////////////////////////////////////////////////////////////////
//
// SdbLocalizedString
//
// The SdbLocalizedString object is simply a named string that also has a
// LangID associated with it.
//
class SdbLocalizedString : public SdbArrayElement { public: CString m_csValue; };
///////////////////////////////////////////////////////////////////////////////
//
// SdbLibrary
//
// The SdbLibrary object contains the shims, patches and kernel flags and
// layers that are referenced by App or Exe objects. NOTE: It is possible
// to compile a database without entries in Library, with the assumption
// that any references will be resolved when further databases in the
// search path are opened.
//
class SdbLibrary : public SdbArrayElement { public: SdbArray<SdbFile> m_rgFiles; SdbArray<SdbShim> m_rgShims; SdbArray<SdbPatch> m_rgPatches; SdbArray<SdbLayer> m_rgLayers; SdbArray<SdbFlag> m_rgFlags; SdbArray<SdbCaller> m_rgCallers; SdbArray<SdbMsiTransform> m_rgMsiTransforms;
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgFiles.PropagateFilter(m_dwFilter); m_rgShims.PropagateFilter(m_dwFilter); m_rgPatches.PropagateFilter(m_dwFilter); m_rgLayers.PropagateFilter(m_dwFilter); m_rgFlags.PropagateFilter(m_dwFilter); m_rgCallers.PropagateFilter(m_dwFilter); m_rgMsiTransforms.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_MSI); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb);
//
// method to clear out tagIDs before writing the db out
//
VOID SanitizeTagIDs(VOID); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbDatabase
//
// This is the base class for the three database classes. It contains
// any common properties between the three.
//
class SdbDatabase : public SdbArrayElement { public: SdbDatabase() : m_ID(GUID_NULL), m_pCurrentApp(NULL), m_pCurrentMakefile(NULL), m_pCurrentInputFile(NULL), m_pCurrentOutputFile(NULL), m_iiWildcardExeIndex(NULL), m_iiModuleExeIndex(NULL), m_iiMsiIDIndex(NULL), m_iiDrvIDIndex(NULL), m_iiShimIndex(NULL), m_iiMsiTransformIndex(NULL), m_iiMsiPackageIndex(NULL) { m_Library.m_pDB = this; }
GUID m_ID;
SdbMakefile* m_pCurrentMakefile; SdbInputFile* m_pCurrentInputFile; SdbOutputFile* m_pCurrentOutputFile; GUID m_CurrentDBID; // last written out dbid
CString m_csCurrentLangID;
IXMLDOMNodePtr m_cpCurrentDatabaseNode;
SdbLibrary m_Library;
//
// Holding variables that are used while reading/writing
//
INDEXID m_iiWildcardExeIndex; INDEXID m_iiModuleExeIndex; INDEXID m_iiExeIndex; INDEXID m_iiShimIndex; INDEXID m_iiMsiTransformIndex; INDEXID m_iiMsiPackageIndex; INDEXID m_iiMsiIDIndex; INDEXID m_iiDrvIDIndex; INDEXID m_iiHtmlHelpID; SdbApp* m_pCurrentApp;
IXMLDOMDocumentPtr m_cpTempXMLDoc; IXMLDOMNodePtr m_cpTempXML;
SdbArray<SdbApp> m_rgApps; SdbArray<SdbAction> m_rgAction; SdbRefArray<SdbExe> m_rgExes; SdbRefArray<SdbExe> m_rgWildcardExes; SdbRefArray<SdbExe> m_rgModuleExes; // exes that match on module name
SdbRefArray<SdbWinNTUpgrade> m_rgWinNTUpgradeEntries; SdbRefArray<SdbMsiPackage> m_rgMsiPackages;
CString m_csHTMLHelpFirstScreen; SdbArray<SdbContactInfo> m_rgContactInfo; SdbArray<SdbMessage> m_rgMessages; SdbArray<SdbMessageTemplate> m_rgMessageTemplates; SdbArray<SdbLocalizedString> m_rgHTMLHelpTemplates; SdbArray<SdbLocalizedString> m_rgHTMLHelpFirstScreens; SdbArray<SdbLocalizedString> m_rgLocalizedAppNames; SdbArray<SdbLocalizedString> m_rgLocalizedVendorNames; SdbArray<SdbLocalizedString> m_rgRedirs;
SdbArray<SdbAppHelp> m_rgAppHelps;
//
// Maps used to map IDs to their objects
//
CMapStringToPtr m_mapExeIDtoExe;
SdbExe* LookupExe(DWORD dwTagID);
BOOL ReplaceFields(CString csXML, CString* pcsReturn, SdbRefArray<SdbMessageField>* prgFields); BOOL ReplaceFieldsInXML(IXMLDOMNode* cpTargetNode, SdbRefArray<SdbMessageField>* prgFields); BOOL RedirectLinks(CString* pcsXML, LCID lcid, CString csRedirURL); BOOL HTMLtoText(CString csXML, CString* pcsReturn);
DWORD GetNextSequentialID(CString csType);
BOOL WriteAppHelpRefTag( PDB pdb, CString csHTMLHelpID, LCID langID, CString csURL, CString csAppTitle, CString csSummary);
BOOL ConstructMessageParts( SdbAppHelp* pAppHelp, SdbMessage* pMessage, CString& csLangID, DWORD* pdwHTMLHelpID, CString* pcsURL, CString* pcsContactInformation, CString* pcsAppTitle, CString* pcsSummary, CString* pcsDetails);
BOOL ConstructMigrationMessage( SdbWin9xMigration* pMigApp, SdbMessage* pMessage, CString* pcsMessage);
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgApps.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_FIX); m_rgAction.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_FIX); m_Library.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_FIX); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb);
BOOL IsStandardDatabase(VOID);
};
///////////////////////////////////////////////////////////////////////////////
//
// SdbApp
//
// The SdbApp object groups Exe objects by application title and vendor. Note
// that it contains only references to exes: Exe objects are owned by the
// database object.
//
class SdbApp : public SdbArrayElement { public: CString m_csVendor; CString m_csVendorXML; CString m_csVersion; SdbArray<SdbExe> m_rgExes; SdbArray<SdbMsiPackage> m_rgMsiPackages;
SdbArray<SdbWin9xMigration> m_rgWin9xMigEntries; SdbArray<SdbWinNTUpgrade> m_rgWinNTUpgradeEntries;
SdbRefArray<SdbAppHelpRef> m_rgAppHelpRefs;
CString m_csKeywords; BOOL m_bSeen; GUID m_ID;
SdbApp(): m_ID(GUID_NULL){}
CString GetLocalizedAppName(); CString GetLocalizedAppName(CString csLangID); CString GetLocalizedVendorName(); CString GetLocalizedVendorName(CString csLangID);
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgExes.PropagateFilter(m_dwFilter); m_rgMsiPackages.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_MSI); m_rgWin9xMigEntries.PropagateFilter(m_dwFilter); m_rgWinNTUpgradeEntries.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbContactInfo
//
// The SdbContactInfo object contains all contact information for the vendor
// portion of the AppHelp dialog. These values can be overridden in the
// AppHelp object.
//
class SdbContactInfo : public SdbArrayElement { public: CString m_csXML; GUID m_ID;
SdbContactInfo() : m_ID(GUID_NULL){}
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMessageTemplate
//
// The SdbMessageTemplate object contains AppHelp messages to be used as 'templates'
// for SdbMessage objects. A SdbMessage object can specify a template and
// use its m_csText and m_csHTML values, or override one of them.
//
class SdbMessageTemplate : public SdbArrayElement { public: CString m_csSummaryXML; CString m_csDetailsXML;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMessage
//
// The SdbMessage object contains all information required for an AppHelp
// dialog in localized form. A SdbAppHelp object references a single
// SdbMessage object, but all of the text is localized in multiple languages.
// A SdbMessage object can derive from a SdbMessageTemplate object, which
// supplies the default m_csText and m_csHTML values.
//
class SdbMessage : public SdbArrayElement { public: SdbMessageTemplate* m_pTemplate; SdbArray<SdbMessageField> m_rgFields;
CString m_csContactInfoXML; // Overriding ContactInfo object
CString m_csSummaryXML; // Overriding Template object
CString m_csDetailsXML; // Overriding Template object
GUID m_ID;
SdbMessage() : m_ID(GUID_NULL), m_pTemplate(NULL) {}
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbAppHelp
//
// The SdbAppHelp object is an instantiation of an AppHelp message. An
// SdbAppHelp is the only object that contains the HTMLHELPID attribute,
// which is needed for each unique AppHelp entry in the CHM file.
//
// HTMLHELPID is stored in SdbAppHelp::m_csName.
//
class SdbAppHelp : public SdbArrayElement { public: CString m_csMessage; SdbApp* m_pApp; SdbAppHelpType m_Type; BOOL m_bBlockUpgrade; CString m_csURL; // custom URL, if supplied
SdbAppHelp() : m_bBlockUpgrade(FALSE), m_Type(SDB_APPHELP_NOBLOCK), m_pApp(NULL) { }
void PropagateFilter(DWORD dwFilter) { //
// We OR this one unconditionally to achieve the following
// effect: If an HTMLHELPID is used at least once, it will
// be included. If it is not used at all (given the current
// filtering), it will never get an SDB_FILTER_APPHELP bit
// set.
//
m_dwFilter |= dwFilter; } };
///////////////////////////////////////////////////////////////////////////////
//
// SdbAppHelpRef
//
// The SdbAppHelpRef object is an instantiation of an AppHelp object.
//
class SdbAppHelpRef : public SdbArrayElement { public: BOOL m_bApphelpOnly; SdbAppHelp* m_pAppHelp; IXMLDOMNodePtr m_cpNode;
SdbAppHelpRef() : m_bApphelpOnly(FALSE), m_pAppHelp(NULL) {}
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
if (m_pAppHelp) { m_pAppHelp->PropagateFilter(m_dwFilter); } }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMessageField
//
// The SdbMessageField object contains a name-value pair that can is used to
// replace fields embedded in templates.
//
class SdbMessageField : public SdbArrayElement { public: CString m_csValue;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMatchingFile
//
// The SdbMatchingFile object contains all file information about files that
// must be matched on for app identification. m_dwMask is used to indicate
// which of the criteria contain valid values (see defines at top of file for
// mask).
//
class SdbMatchingFile : public SdbArrayElement { public: DWORD m_dwMask; DWORD m_dwSize; DWORD m_dwChecksum; CString m_csCompanyName; CString m_csProductName; CString m_csProductVersion; CString m_csFileDescription; ULONGLONG m_ullBinFileVersion; ULONGLONG m_ullBinProductVersion; DWORD m_dwVerLanguage;
DWORD m_dwModuleType; DWORD m_dwFileDateMS; DWORD m_dwFileDateLS; DWORD m_dwFileOS; DWORD m_dwFileType; ULONG m_ulPECheckSum; DWORD m_dwLinkerVersion; CString m_csFileVersion; CString m_csOriginalFileName; CString m_csInternalName; CString m_csLegalCopyright; CString m_cs16BitDescription; CString m_cs16BitModuleName; ULONGLONG m_ullUpToBinProductVersion; ULONGLONG m_ullUpToBinFileVersion; DWORD m_dwPrevOSMajorVersion; DWORD m_dwPrevOSMinorVersion; DWORD m_dwPrevOSPlatformID; DWORD m_dwPrevOSBuildNo;
time_t m_timeLinkDate; time_t m_timeUpToLinkDate;
BOOL m_bMatchLogicNot; CString m_csServiceName; CString m_csRegistryEntry;
SdbMatchingFile() : m_dwMask(NULL), m_bMatchLogicNot(FALSE) {}
BOOL IsValidForWin2k(CString csXML);
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMsiPackage
//
// The SdbMsiPackage object represents an Installer package that must be fixed via
// application of a custom MSI_TRANSFORM
//
class SdbMsiPackage : public SdbArrayElement { public:
//
// Pointer to the (parent) app object
//
SdbApp* m_pApp;
//
// supplemental data for MSI_PACKAGE object
// it is used to further identify the package
//
SdbArray<SdbData> m_rgData;
//
// MSI_TRANSFORM stuff designed to fix this package (references transforms in lib)
//
SdbArray<SdbMsiTransformRef> m_rgMsiTransformRefs;
GUID m_MsiPackageID; // package id (non-unique guid)
GUID m_ID; // exe id (unique guid)
//
// RUNTIME_PLATFORM attribute
//
DWORD m_dwRuntimePlatform;
//
// OS_SKU attribute
//
DWORD m_dwOSSKU;
//
// apphelp
//
SdbAppHelpRef m_AppHelpRef;
//
// shims and layers don't cut it, we need another entity here
//
SdbArray<SdbMsiCustomAction> m_rgCustomActions;
//
// we override the default MakeKey function
// in order to sort the content by keys made from guid IDs instead of the name
// secondary sort order will be provided by name
//
virtual ULONGLONG MakeKey() { return MAKEKEYFROMGUID(&m_ID); }
SdbMsiPackage() : m_ID(GUID_NULL), m_dwRuntimePlatform(RUNTIME_PLATFORM_ANY), m_dwOSSKU(OS_SKU_ALL) {}
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_AppHelpRef.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_APPHELP); m_rgData.PropagateFilter(m_dwFilter); m_rgMsiTransformRefs.PropagateFilter(m_dwFilter); m_rgCustomActions.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMsiCustomAction
//
// The SdbMsiCustomAction object encapsulates custom actions and what we do
// for them (shim/etc)
//
class SdbMsiCustomAction : public SdbArrayElement { public: SdbArray<SdbShimRef> m_rgShimRefs; SdbArray<SdbLayerRef> m_rgLayerRefs;
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgShimRefs.PropagateFilter(m_dwFilter); m_rgLayerRefs.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb);
};
///////////////////////////////////////////////////////////////////////////////
//
// SdbMsiTransform
//
// The SdbMsiTransform object encapsulates an MSI_TRANSFORM remedy.
//
class SdbMsiTransform : public SdbArrayElement { public: SdbMsiTransform() : m_tiTagID(NULL), m_pSdbFile(NULL) {}
TAGID m_tiTagID; // tagid of this record
SdbFile* m_pSdbFile; // pointer to the transform file
CString m_csMsiTransformFile; // transform filename
CString m_csDesc; // description
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbMsiTransformRef
//
// The SdbMsiTransformRef object is a reference to an SdbMsiTransform object
// in the library.
//
class SdbMsiTransformRef : public SdbArrayElement { public: SdbMsiTransformRef() : m_pMsiTransform(NULL) {}
SdbMsiTransform* m_pMsiTransform;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
#define MATCH_DEFAULT ((DWORD)-1)
///////////////////////////////////////////////////////////////////////////////
//
// SdbExe
//
// The SdbExe object represents an executable that must be patched/shimmed.
// The m_pApp member can be NULL, or it can contain a pointer to the SdbApp
// object that groups it with other SdbExe objects.
//
class SdbExe : public SdbArrayElement { public: SdbApp* m_pApp; SdbArray<SdbShimRef> m_rgShimRefs; SdbArray<SdbLayerRef> m_rgLayerRefs; SdbArray<SdbFlagRef> m_rgFlagRefs; SdbArray<SdbMatchingFile> m_rgMatchingFiles; SdbArray<SdbData> m_rgData; SdbArray<SdbAction> m_rgAction; SdbRefArray<SdbPatch> m_rgPatches; SdbAppHelpRef m_AppHelpRef; CString m_csSXSManifest;
GUID m_ID; BOOL m_bWildcardInName; BOOL m_bMatchOnModule;
DWORD m_dwTagID; BOOL m_bSeen;
DWORD m_dwMatchMode; // modes include NORMAL, EXCLUSIVE, or ADDITIVE
DWORD m_dwRuntimePlatform; DWORD m_dwOSSKU;
SdbExe() : m_pApp(NULL), m_dwTagID(0), m_ID(GUID_NULL), m_dwMatchMode(MATCH_DEFAULT), m_bWildcardInName(FALSE), m_dwRuntimePlatform(RUNTIME_PLATFORM_ANY), m_dwOSSKU(OS_SKU_ALL), m_bMatchOnModule(FALSE) {m_dwOSPlatform = OS_PLATFORM_I386;}
BOOL IsValidForWin2k(CString csXML);
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgShimRefs.PropagateFilter(m_dwFilter); m_rgLayerRefs.PropagateFilter(m_dwFilter); m_rgFlagRefs.PropagateFilter(m_dwFilter); m_rgMatchingFiles.PropagateFilter(m_dwFilter); m_rgData.PropagateFilter(m_dwFilter); m_rgAction.PropagateFilter(m_dwFilter); m_rgPatches.PropagateFilter(m_dwFilter); m_AppHelpRef.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_APPHELP); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); int Compare(const SdbArrayElement* pElement); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbFile
//
// The SdbFile object represents a binary file that can be stored in the
// database.
//
class SdbFile : public SdbArrayElement { public: SdbFile() : m_tiTagID(NULL) {}
TAGID m_tiTagID;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbShim
//
// The SdbShim object represents a shim, which contains Win32 API hooks.
// A shim's 'purpose' can be marked as GENERAL or SPECIFIC -- if it is GENERAL,
// it is appropriate for reuse, otherwise it is application specific.
//
class SdbShim : public SdbArrayElement { public: SdbShim() : m_ID(GUID_NULL), m_tiTagID(NULL), m_Purpose(SDB_PURPOSE_SPECIFIC), m_bApplyAllShims(FALSE) {m_dwOSPlatform = OS_PLATFORM_I386;}
CString m_csShortName; CString m_csDesc; TAGID m_tiTagID; CString m_csDllFile; SdbPurpose m_Purpose; BOOL m_bApplyAllShims; GUID m_ID;
SdbArray<SdbCaller> m_rgCallers;
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgCallers.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbCaller
//
// The SdbCaller object contains inclusion/exclusion information for shims.
// It allows hooked APIs to be cased by the calling instruction address. For
// example, it is known that ATL.DLL requires accurate OS version information,
// and so any calls to GetVersionExA from ATL.DLL are assured to call the
// original API, rather than the shim hook. This is achieved by adding
// an EXCLUDE subtag to the SHIM tag.
//
class SdbCaller : public SdbArrayElement { public: CString m_csModule; SdbCallerType m_CallerType;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbShimRef
//
// The SdbShimRef object is simply a reference to a SdbShim object that exists
// in a library. It has separate inclusion/exclusion information, which is
// given higher priority than any such information in the SHIM tag within the
// corresponding library. It can contain an optional command line, which is
// passed in to the shim DLL via GetHookAPIs.
//
class SdbShimRef : public SdbArrayElement { public: SdbShimRef() : m_dwRecID(NULL), m_pShim(NULL) {}
DWORD m_dwRecID; SdbShim* m_pShim; CString m_csCommandLine;
SdbArray<SdbCaller> m_rgCallers; SdbArray<SdbData> m_rgData;
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgCallers.PropagateFilter(m_dwFilter); m_rgData.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbPatch
//
// The SdbPatch object contains the patch binary that is parsed by the app
// compat mechanism at run-time. It contains patching instructions, including
// any bits to patch an executable's code with.
//
class SdbPatch : public SdbArrayElement { private: BYTE* m_pBlob; DWORD m_dwBlobMemSize; DWORD m_dwBlobSize;
public: TAGID m_tiTagID; BOOL m_bUsed; GUID m_ID;
SdbPatch() : m_pBlob(NULL), m_tiTagID(0), m_dwBlobMemSize(0), m_dwBlobSize(0), m_ID(GUID_NULL), m_bUsed(FALSE) {m_dwOSPlatform = OS_PLATFORM_I386;}
virtual ~SdbPatch() { if( m_pBlob != NULL ) delete m_pBlob; }
PBYTE GetBlobBytes(void) {return m_pBlob;} DWORD GetBlobSize(void) {return m_dwBlobSize;}
void AddBlobBytes( LPVOID pBytes, DWORD dwSize ); void ClearBlob();
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); BOOL WriteRefToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbFlag
//
// The SdbFlag object contains a mask which is used by kernel-mode
// components in special compatibility casing constructs. These flags can be
// turned on by adding the FLAG subtag to an EXE tag.
//
class SdbFlag : public SdbArrayElement { public: CString m_csDesc; ULONGLONG m_ullMask; DWORD m_dwType; TAGID m_tiTagID; SdbPurpose m_Purpose; GUID m_ID;
SdbFlag() : m_ID(GUID_NULL), m_tiTagID(0), m_Purpose(SDB_PURPOSE_SPECIFIC), m_ullMask(0) {m_dwOSPlatform = OS_PLATFORM_I386;}
static ULONGLONG MakeMask(SdbRefArray<SdbFlag>* prgFlags, DWORD dwType); static TAG TagFromType(DWORD dwType);
BOOL SetType(CString csType);
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbFlagRef
//
// The SdbFlagRef object is simply a reference to a SdbFlag object that exists
// in a library.
//
class SdbFlagRef : public SdbArrayElement { public: SdbFlagRef() : m_pFlag(NULL) {}
SdbFlag* m_pFlag;
CString m_csCommandLine;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbLayer
//
// The SdbLayer object contains a set of shims and/or kernel flags that can be
// turned on to invoke a "compatibility mode". Presently, if the environment
// variable __COMPAT_LAYER is set to the name of this object, all shims and
// kernel flags contained by the layer will be invoked.
//
class SdbLayer : public SdbArrayElement { public: CString m_csDesc; CString m_csDisplayName; TAGID m_tiTagID; GUID m_ID;
SdbArray<SdbShimRef> m_rgShimRefs; SdbArray<SdbFlagRef> m_rgFlagRefs;
SdbLayer (): m_ID(GUID_NULL){m_dwOSPlatform = OS_PLATFORM_I386;}
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgShimRefs.PropagateFilter(m_dwFilter); m_rgFlagRefs.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbLayerRef
//
// The SdbLayerRef object contains a reference to a layer that exists in the
// library. It exists to allow <EXE> entries that reference a layer defined
// in another database.
//
class SdbLayerRef : public SdbArrayElement { public: SdbLayerRef() : m_pLayer(NULL) {}
SdbLayer* m_pLayer; SdbArray<SdbData> m_rgData;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbData
//
// The SdbData object contains a name-value pair that can be queried
// at runtime for any data.
//
class SdbData : public SdbArrayElement { private: SdbDataValueType m_DataType; DWORD m_dwDataSize; //
// nested Data elements
//
SdbArray<SdbData> m_rgData;
public:
union { DWORD m_dwValue; // m_DataType == REG_DWORD
ULONGLONG m_ullValue; // m_DataType == REG_QWORD
LPTSTR m_szValue; // m_DataType == REG_SZ
LPBYTE m_pBinValue; // m_DataType == REG_BINARY
};
SdbData() : m_DataType(eValueNone), m_dwDataSize(0) {}
~SdbData() { Clear(); }
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgData.PropagateFilter(m_dwFilter); }
SdbDataValueType GetValueType() { return m_DataType; }
void Clear(); BOOL SetValue(SdbDataValueType DataType, LPCTSTR lpValue);
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
///////////////////////////////////////////////////////////////////////////////
//
// SdbAction
//
// The SdbAction object contains the type of the action and Data elements that
// provide any data needed to perform this action.
//
class SdbAction: public SdbArrayElement { private: CString m_csType; SdbArray<SdbData> m_rgData;
public:
SdbAction() {} ~SdbAction() {}
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgData.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); BOOL WriteToSDB(PDB pdb); };
class SdbMatchOperation : public SdbArrayElement { public: SdbMatchOperationType m_Type;
SdbArray<SdbMatchingFile> m_rgMatchingFiles; SdbArray<SdbMatchOperation> m_rgSubMatchOps;
SdbMatchOperation() : m_Type(SDB_MATCH_ALL) {}
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_rgMatchingFiles.PropagateFilter(m_dwFilter); m_rgSubMatchOps.PropagateFilter(m_dwFilter); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
class SdbWin9xMigration : public SdbArrayElement { public: SdbWin9xMigration() : m_pApp(NULL), m_bShowInSimplifiedView(FALSE) {}
CString m_csSection; CString m_csMessage; GUID m_ID; BOOL m_bShowInSimplifiedView;
SdbApp* m_pApp;
SdbMatchOperation m_MatchOp;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
class SdbMatchingRegistryEntry : public SdbArrayElement { public: CString m_csValueName; CString m_csValue;
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
class SdbWinNTUpgrade : public SdbArrayElement { public: SdbWinNTUpgrade() : m_ID(GUID_NULL), m_pApp(NULL) {}
SdbAppHelpRef m_AppHelpRef; SdbMatchingFile m_MatchingFile; SdbMatchingRegistryEntry m_MatchingRegistryEntry;
SdbApp* m_pApp; GUID m_ID;
void PropagateFilter(DWORD dwFilter) { SdbArrayElement::PropagateFilter(dwFilter);
m_AppHelpRef.PropagateFilter(m_dwFilter == SDB_FILTER_EXCLUDE_ALL ? SDB_FILTER_EXCLUDE_ALL : SDB_FILTER_NTCOMPAT); }
BOOL ReadFromXML(IXMLDOMNode* pNode, SdbDatabase* pDB); };
#endif // !defined(AFX_OBJ_H__5C16373A_D713_46CD_B8BF_7755216C62E0__INCLUDED_)
|