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.
 
 
 
 
 
 

76 lines
1.9 KiB

#ifndef _TAPI_PROMPTED_OBJECT_SAFETY_H_
#define _TAPI_PROMPTED_OBJECT_SAFETY_H_
/*++
Copyright (c) 1999 Microsoft Corporation
Module Name:
PromptedObjectSafety.h
Abstract:
abstract base class for secure object safety mechanism
calls the derived class's Ask() method to determine
whether safe for scripting request should be rejected
--*/
#include "ObjectSafeImpl.h"
class CPromptedObjectSafety : public CObjectSafeImpl
{
public:
STDMETHOD(SetInterfaceSafetyOptions)(REFIID riid,
DWORD dwOptionSetMask,
DWORD dwEnabledOptions)
{
if ( SUCCEEDED(InterfaceSupported(riid)) && Ask() )
{
return CObjectSafeImpl::SetInterfaceSafetyOptions(riid,
dwOptionSetMask,
dwEnabledOptions);
}
else
{
return E_FAIL;
}
}
STDMETHOD(GetInterfaceSafetyOptions)(REFIID riid,
DWORD *pdwSupportedOptions,
DWORD *pdwEnabledOptions)
{
if (SUCCEEDED(InterfaceSupported(riid)) && Ask())
{
return CObjectSafeImpl::GetInterfaceSafetyOptions(riid,
pdwSupportedOptions,
pdwEnabledOptions);
}
else
{
return E_FAIL;
}
}
//
// implement Ask() in the derived class. Should contain the logic to make
// the decision on whether the control should be allowed to run
//
// return FALSE if you want to mark your control as not safe for scripting
// return TRUE otherwise
//
virtual BOOL Ask() = 0;
};
#endif // _TAPI_PROMPTED_OBJECT_SAFETY_H_