VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/VBoxCredProv/VBoxCredProvProvider.h@ 61559

Last change on this file since 61559 was 40435, checked in by vboxsync, 13 years ago

updates

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.5 KB
Line 
1/* $Id: VBoxCredProvProvider.h 40435 2012-03-12 18:01:39Z vboxsync $ */
2/** @file
3 * VBoxCredProvProvider - The actual credential provider class.
4 */
5
6/*
7 * Copyright (C) 2012 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef ___VBOX_CREDPROV_PROVIDER_H___
19#define ___VBOX_CREDPROV_PROVIDER_H___
20
21#include <credentialprovider.h>
22#include <Windows.h>
23#include <strsafe.h>
24
25#include <VBox/VBoxGuestLib.h>
26
27#include "VBoxCredProvCredential.h"
28#include "VBoxCredProvPoller.h"
29
30class VBoxCredProvProvider : public ICredentialProvider
31{
32public:
33
34 /** @name IUnknown methods.
35 * @{ */
36 IFACEMETHODIMP_(ULONG) AddRef(void);
37 IFACEMETHODIMP_(ULONG) Release(void);
38 IFACEMETHODIMP QueryInterface(REFIID interfaceID, void **ppvInterface);
39 /** @} */
40
41
42 /** @name ICredentialProvider interface
43 * @{ */
44 IFACEMETHODIMP SetUsageScenario(CREDENTIAL_PROVIDER_USAGE_SCENARIO cpUsageScenario, DWORD dwFlags);
45 IFACEMETHODIMP SetSerialization(const CREDENTIAL_PROVIDER_CREDENTIAL_SERIALIZATION *pcpCredentialSerialization);
46
47 IFACEMETHODIMP Advise(__in ICredentialProviderEvents *pcpEvents, UINT_PTR upAdviseContext);
48 IFACEMETHODIMP UnAdvise();
49
50 IFACEMETHODIMP GetFieldDescriptorCount(__out DWORD* pdwCount);
51 IFACEMETHODIMP GetFieldDescriptorAt(DWORD dwIndex, __deref_out CREDENTIAL_PROVIDER_FIELD_DESCRIPTOR **ppFieldDescriptor);
52
53 IFACEMETHODIMP GetCredentialCount(__out DWORD *pdwCount,
54 __out DWORD *pdwDefault,
55 __out BOOL *pfAutoLogonWithDefault);
56 IFACEMETHODIMP GetCredentialAt(DWORD dwIndex,
57 __out ICredentialProviderCredential **ppcpc);
58 /** @} */
59
60 friend HRESULT VBoxCredProvProviderCreate(REFIID riid, __deref_out void **ppv);
61
62protected:
63
64 VBoxCredProvProvider(void);
65 virtual ~VBoxCredProvProvider(void);
66
67public:
68
69 /** Loads the configuration from the registry. */
70 DWORD LoadConfiguration(void);
71 /** Determines whether the current session this provider is
72 * loaded into needs to be handled or not. */
73 bool HandleCurrentSession(void);
74 /** Event which gets triggered by the poller thread in case
75 * there are credentials available from the host. */
76 void OnCredentialsProvided(void);
77
78private:
79
80 /** Interface reference count. */
81 LONG m_cRefs;
82 /** Our one and only credential. */
83 VBoxCredProvCredential *m_pCred;
84 /** Poller thread for credential lookup. */
85 VBoxCredProvPoller *m_pPoller;
86 /** Used to tell our owner to re-enumerate credentials. */
87 ICredentialProviderEvents *m_pEvents;
88 /** Used to tell our owner who we are when asking to re-enumerate credentials. */
89 UINT_PTR m_upAdviseContext;
90 /** Saved usage scenario. */
91 CREDENTIAL_PROVIDER_USAGE_SCENARIO m_enmUsageScenario;
92 /** Flag whether we need to handle remote session over Windows Remote
93 * Desktop Service. */
94 bool m_fHandleRemoteSessions;
95};
96
97#endif /* !___VBOX_CREDPROV_PROVIDER_H___ */
98
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette