wbemdisp: Add ISWbemSecurity stub interface.
Signed-off-by: Alistair Leslie-Hughes <leslie_alistair@hotmail.com> Signed-off-by: Hans Leidekker <hans@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
ed2861c28c
commit
350d980ccc
|
@ -38,6 +38,7 @@
|
||||||
WINE_DEFAULT_DEBUG_CHANNEL(wbemdisp);
|
WINE_DEFAULT_DEBUG_CHANNEL(wbemdisp);
|
||||||
|
|
||||||
static HRESULT EnumVARIANT_create( IEnumWbemClassObject *, IEnumVARIANT ** );
|
static HRESULT EnumVARIANT_create( IEnumWbemClassObject *, IEnumVARIANT ** );
|
||||||
|
static HRESULT ISWbemSecurity_create( ISWbemSecurity ** );
|
||||||
|
|
||||||
enum type_id
|
enum type_id
|
||||||
{
|
{
|
||||||
|
@ -47,6 +48,7 @@ enum type_id
|
||||||
ISWbemProperty_tid,
|
ISWbemProperty_tid,
|
||||||
ISWbemPropertySet_tid,
|
ISWbemPropertySet_tid,
|
||||||
ISWbemServices_tid,
|
ISWbemServices_tid,
|
||||||
|
ISWbemSecurity_tid,
|
||||||
last_tid
|
last_tid
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -60,7 +62,8 @@ static REFIID wbemdisp_tid_id[] =
|
||||||
&IID_ISWbemObjectSet,
|
&IID_ISWbemObjectSet,
|
||||||
&IID_ISWbemProperty,
|
&IID_ISWbemProperty,
|
||||||
&IID_ISWbemPropertySet,
|
&IID_ISWbemPropertySet,
|
||||||
&IID_ISWbemServices
|
&IID_ISWbemServices,
|
||||||
|
&IID_ISWbemSecurity
|
||||||
};
|
};
|
||||||
|
|
||||||
static HRESULT get_typeinfo( enum type_id tid, ITypeInfo **ret )
|
static HRESULT get_typeinfo( enum type_id tid, ITypeInfo **ret )
|
||||||
|
@ -1873,8 +1876,12 @@ static HRESULT WINAPI services_get_Security_(
|
||||||
ISWbemServices *iface,
|
ISWbemServices *iface,
|
||||||
ISWbemSecurity **objWbemSecurity )
|
ISWbemSecurity **objWbemSecurity )
|
||||||
{
|
{
|
||||||
FIXME( "\n" );
|
TRACE( "%p, %p\n", iface, objWbemSecurity );
|
||||||
return E_NOTIMPL;
|
|
||||||
|
if (!objWbemSecurity)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
return ISWbemSecurity_create( objWbemSecurity );
|
||||||
}
|
}
|
||||||
|
|
||||||
static const ISWbemServicesVtbl services_vtbl =
|
static const ISWbemServicesVtbl services_vtbl =
|
||||||
|
@ -2128,8 +2135,12 @@ static HRESULT WINAPI locator_get_Security_(
|
||||||
ISWbemLocator *iface,
|
ISWbemLocator *iface,
|
||||||
ISWbemSecurity **objWbemSecurity )
|
ISWbemSecurity **objWbemSecurity )
|
||||||
{
|
{
|
||||||
FIXME( "%p, %p\n", iface, objWbemSecurity );
|
TRACE( "%p, %p\n", iface, objWbemSecurity );
|
||||||
return E_NOTIMPL;
|
|
||||||
|
if (!objWbemSecurity)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
return ISWbemSecurity_create( objWbemSecurity );
|
||||||
}
|
}
|
||||||
|
|
||||||
static const ISWbemLocatorVtbl locator_vtbl =
|
static const ISWbemLocatorVtbl locator_vtbl =
|
||||||
|
@ -2160,3 +2171,231 @@ HRESULT SWbemLocator_create( void **obj )
|
||||||
TRACE( "returning iface %p\n", *obj );
|
TRACE( "returning iface %p\n", *obj );
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct security
|
||||||
|
{
|
||||||
|
ISWbemSecurity ISWbemSecurity_iface;
|
||||||
|
LONG refs;
|
||||||
|
WbemImpersonationLevelEnum implevel;
|
||||||
|
WbemAuthenticationLevelEnum authlevel;
|
||||||
|
};
|
||||||
|
|
||||||
|
static inline struct security *impl_from_ISWbemSecurity( ISWbemSecurity *iface )
|
||||||
|
{
|
||||||
|
return CONTAINING_RECORD( iface, struct security, ISWbemSecurity_iface );
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI security_AddRef(
|
||||||
|
ISWbemSecurity *iface )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
return InterlockedIncrement( &security->refs );
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI security_Release(
|
||||||
|
ISWbemSecurity *iface )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
LONG refs = InterlockedDecrement( &security->refs );
|
||||||
|
if (!refs)
|
||||||
|
{
|
||||||
|
TRACE( "destroying %p\n", security );
|
||||||
|
heap_free( security );
|
||||||
|
}
|
||||||
|
return refs;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_QueryInterface(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
REFIID riid,
|
||||||
|
void **ppvObject )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
TRACE( "%p, %s, %p\n", security, debugstr_guid( riid ), ppvObject );
|
||||||
|
|
||||||
|
if (IsEqualGUID( riid, &IID_ISWbemSecurity ) ||
|
||||||
|
IsEqualGUID( riid, &IID_IDispatch ) ||
|
||||||
|
IsEqualGUID( riid, &IID_IUnknown ))
|
||||||
|
{
|
||||||
|
*ppvObject = iface;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FIXME( "interface %s not implemented\n", debugstr_guid(riid) );
|
||||||
|
return E_NOINTERFACE;
|
||||||
|
}
|
||||||
|
ISWbemSecurity_AddRef( iface );
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_GetTypeInfoCount(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
UINT *count )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
TRACE( "%p, %p\n", security, count );
|
||||||
|
|
||||||
|
*count = 1;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_GetTypeInfo(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
UINT index,
|
||||||
|
LCID lcid,
|
||||||
|
ITypeInfo **info )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
TRACE( "%p, %u, %u, %p\n", security, index, lcid, info );
|
||||||
|
|
||||||
|
return get_typeinfo( ISWbemSecurity_tid, info );
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_GetIDsOfNames(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
REFIID riid,
|
||||||
|
LPOLESTR *names,
|
||||||
|
UINT count,
|
||||||
|
LCID lcid,
|
||||||
|
DISPID *dispid )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
ITypeInfo *typeinfo;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
|
TRACE( "%p, %s, %p, %u, %u, %p\n", security, debugstr_guid(riid), names, count, lcid, dispid );
|
||||||
|
|
||||||
|
if (!names || !count || !dispid) return E_INVALIDARG;
|
||||||
|
|
||||||
|
hr = get_typeinfo( ISWbemSecurity_tid, &typeinfo );
|
||||||
|
if (SUCCEEDED(hr))
|
||||||
|
{
|
||||||
|
hr = ITypeInfo_GetIDsOfNames( typeinfo, names, count, dispid );
|
||||||
|
ITypeInfo_Release( typeinfo );
|
||||||
|
}
|
||||||
|
return hr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_Invoke(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
DISPID member,
|
||||||
|
REFIID riid,
|
||||||
|
LCID lcid,
|
||||||
|
WORD flags,
|
||||||
|
DISPPARAMS *params,
|
||||||
|
VARIANT *result,
|
||||||
|
EXCEPINFO *excep_info,
|
||||||
|
UINT *arg_err )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
ITypeInfo *typeinfo;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
|
TRACE( "%p, %d, %s, %d, %d, %p, %p, %p, %p\n", security, member, debugstr_guid(riid),
|
||||||
|
lcid, flags, params, result, excep_info, arg_err );
|
||||||
|
|
||||||
|
hr = get_typeinfo( ISWbemSecurity_tid, &typeinfo );
|
||||||
|
if (SUCCEEDED(hr))
|
||||||
|
{
|
||||||
|
hr = ITypeInfo_Invoke( typeinfo, &security->ISWbemSecurity_iface, member, flags,
|
||||||
|
params, result, excep_info, arg_err );
|
||||||
|
ITypeInfo_Release( typeinfo );
|
||||||
|
}
|
||||||
|
return hr;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_get_ImpersonationLevel(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
WbemImpersonationLevelEnum *impersonation_level )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
FIXME( "%p, %p: stub\n", security, impersonation_level );
|
||||||
|
|
||||||
|
if (!impersonation_level)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
*impersonation_level = security->implevel;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_put_ImpersonationLevel(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
WbemImpersonationLevelEnum impersonation_level )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
FIXME( "%p, %d: stub\n", security, impersonation_level );
|
||||||
|
|
||||||
|
security->implevel = impersonation_level;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_get_AuthenticationLevel(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
WbemAuthenticationLevelEnum *authentication_level )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
FIXME( "%p, %p: stub\n", security, authentication_level );
|
||||||
|
|
||||||
|
if (!authentication_level)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
*authentication_level = security->authlevel;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_put_AuthenticationLevel(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
WbemAuthenticationLevelEnum authentication_level )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
FIXME( "%p, %d: stub\n", security, authentication_level );
|
||||||
|
|
||||||
|
security->authlevel = authentication_level;
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI security_get_Privileges(
|
||||||
|
ISWbemSecurity *iface,
|
||||||
|
ISWbemPrivilegeSet **privilege_set )
|
||||||
|
{
|
||||||
|
struct security *security = impl_from_ISWbemSecurity( iface );
|
||||||
|
FIXME( "%p, %p: stub\n", security, privilege_set );
|
||||||
|
|
||||||
|
if (!privilege_set)
|
||||||
|
return E_INVALIDARG;
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const ISWbemSecurityVtbl security_vtbl =
|
||||||
|
{
|
||||||
|
security_QueryInterface,
|
||||||
|
security_AddRef,
|
||||||
|
security_Release,
|
||||||
|
security_GetTypeInfoCount,
|
||||||
|
security_GetTypeInfo,
|
||||||
|
security_GetIDsOfNames,
|
||||||
|
security_Invoke,
|
||||||
|
security_get_ImpersonationLevel,
|
||||||
|
security_put_ImpersonationLevel,
|
||||||
|
security_get_AuthenticationLevel,
|
||||||
|
security_put_AuthenticationLevel,
|
||||||
|
security_get_Privileges
|
||||||
|
};
|
||||||
|
|
||||||
|
static HRESULT ISWbemSecurity_create( ISWbemSecurity **obj )
|
||||||
|
{
|
||||||
|
struct security *security;
|
||||||
|
|
||||||
|
TRACE( "%p\n", obj );
|
||||||
|
|
||||||
|
if (!(security = heap_alloc( sizeof(*security) ))) return E_OUTOFMEMORY;
|
||||||
|
security->ISWbemSecurity_iface.lpVtbl = &security_vtbl;
|
||||||
|
security->refs = 1;
|
||||||
|
security->implevel = wbemImpersonationLevelImpersonate;
|
||||||
|
security->authlevel = wbemAuthenticationLevelPktPrivacy;
|
||||||
|
|
||||||
|
*obj = &security->ISWbemSecurity_iface;
|
||||||
|
TRACE( "returning iface %p\n", *obj );
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue