From 06a9f864e8f1a0fdc2a3d02cab2953911d31921e Mon Sep 17 00:00:00 2001 From: Jacek Caban Date: Mon, 12 Mar 2012 13:02:17 +0100 Subject: [PATCH] msident: Added CLSID_UserIdentityManager object stub implementation. --- dlls/msident/msident.c | 137 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 137 insertions(+) diff --git a/dlls/msident/msident.c b/dlls/msident/msident.c index 69ef4592c8f..4c688b89333 100644 --- a/dlls/msident/msident.c +++ b/dlls/msident/msident.c @@ -19,6 +19,7 @@ #define COBJMACROS #include "windows.h" +#include "initguid.h" #include "msident.h" #include "rpcproxy.h" @@ -28,6 +29,137 @@ WINE_DEFAULT_DEBUG_CHANNEL(msident); static HINSTANCE msident_instance; +static HRESULT WINAPI UserIdentityManager_QueryInterface(IUserIdentityManager *iface, REFIID riid, void **ppv) +{ + if(IsEqualGUID(&IID_IUnknown, riid)) { + TRACE("(IID_IUnknown %p)\n", ppv); + *ppv = iface; + }else if(IsEqualGUID(&IID_IUserIdentityManager, riid)) { + TRACE("(IID_IUserIdentityManager %p)\n", ppv); + *ppv = iface; + }else { + WARN("(%s %p)\n", debugstr_guid(riid), ppv); + *ppv = NULL; + return E_NOINTERFACE; + } + + IUnknown_AddRef((IUnknown*)*ppv); + return S_OK; +} + +static ULONG WINAPI UserIdentityManager_AddRef(IUserIdentityManager *iface) +{ + TRACE("\n"); + return 2; +} + +static ULONG WINAPI UserIdentityManager_Release(IUserIdentityManager *iface) +{ + TRACE("\n"); + return 1; +} + +static HRESULT WINAPI UserIdentityManager_EnumIdentities(IUserIdentityManager *iface, IEnumUserIdentity **ppEnumUser) +{ + FIXME("(%p)\n", ppEnumUser); + return E_NOTIMPL; +} + +static HRESULT WINAPI UserIdentityManager_ManageIdentities(IUserIdentityManager *iface, HWND hwndParent, DWORD dwFlags) +{ + FIXME("(%p %x)\n", hwndParent, dwFlags); + return E_NOTIMPL; +} + +static HRESULT WINAPI UserIdentityManager_Logon(IUserIdentityManager *iface, HWND hwndParent, + DWORD dwFlags, IUserIdentity **ppIdentity) +{ + FIXME("(%p %x %p)\n", hwndParent, dwFlags, ppIdentity); + return E_USER_CANCELLED; +} + +static HRESULT WINAPI UserIdentityManager_Logoff(IUserIdentityManager *iface, HWND hwndParent) +{ + FIXME("(%p)\n", hwndParent); + return E_NOTIMPL; +} + +static HRESULT WINAPI UserIdentityManager_GetIdentityByCookie(IUserIdentityManager *iface, GUID *uidCookie, + IUserIdentity **ppIdentity) +{ + FIXME("(%p %p)\n", uidCookie, ppIdentity); + return E_NOTIMPL; +} + +static const IUserIdentityManagerVtbl UserIdentityManagerVtbl = { + UserIdentityManager_QueryInterface, + UserIdentityManager_AddRef, + UserIdentityManager_Release, + UserIdentityManager_EnumIdentities, + UserIdentityManager_ManageIdentities, + UserIdentityManager_Logon, + UserIdentityManager_Logoff, + UserIdentityManager_GetIdentityByCookie +}; + +static IUserIdentityManager UserIdentityManager = { &UserIdentityManagerVtbl }; + +static HRESULT WINAPI UserIdentityManager_CreateInstance(IClassFactory *iface, IUnknown *outer, REFIID riid, void **ppv) +{ + TRACE("\n"); + + return IUserIdentityManager_QueryInterface(&UserIdentityManager, riid, ppv); +} + +static HRESULT WINAPI ClassFactory_QueryInterface(IClassFactory *iface, REFIID riid, void **ppv) +{ + *ppv = NULL; + + if(IsEqualGUID(&IID_IUnknown, riid)) { + TRACE("(%p)->(IID_IUnknown %p)\n", iface, ppv); + *ppv = iface; + }else if(IsEqualGUID(&IID_IClassFactory, riid)) { + TRACE("(%p)->(IID_IClassFactory %p)\n", iface, ppv); + *ppv = iface; + } + + if(*ppv) { + IUnknown_AddRef((IUnknown*)*ppv); + return S_OK; + } + + FIXME("(%p)->(%s %p)\n", iface, debugstr_guid(riid), ppv); + return E_NOINTERFACE; +} + +static ULONG WINAPI ClassFactory_AddRef(IClassFactory *iface) +{ + TRACE("(%p)\n", iface); + return 2; +} + +static ULONG WINAPI ClassFactory_Release(IClassFactory *iface) +{ + TRACE("(%p)\n", iface); + return 1; +} + +static HRESULT WINAPI ClassFactory_LockServer(IClassFactory *iface, BOOL fLock) +{ + TRACE("(%p)->(%x)\n", iface, fLock); + return S_OK; +} + +static const IClassFactoryVtbl UserIdentityManagerCFVtbl = { + ClassFactory_QueryInterface, + ClassFactory_AddRef, + ClassFactory_Release, + UserIdentityManager_CreateInstance, + ClassFactory_LockServer +}; + +static IClassFactory UserIdentityManagerCF = { &UserIdentityManagerCFVtbl }; + /****************************************************************** * DllMain (msident.@) */ @@ -53,6 +185,11 @@ BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpv) */ HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID *ppv) { + if(IsEqualGUID(&CLSID_UserIdentityManager, rclsid)) { + TRACE("CLSID_UserIdentityManager\n"); + return IClassFactory_QueryInterface(&UserIdentityManagerCF, riid, ppv); + } + FIXME("%s %s %p\n", debugstr_guid(rclsid), debugstr_guid(riid), ppv); return CLASS_E_CLASSNOTAVAILABLE; } -- 2.11.4.GIT