2020-09-30 16:53:55 +02:00

1035 lines
26 KiB
C++

//--------------------------------------------------------------------------/
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1996
//
// File: cfshare.cxx
//
// Contents: Contains methods for the following objects
// CWinNTFileShare, CWinNTFileShareGeneralInfo
//
//
// History: 02/15/96 ramv (Ram Viswanathan) Created.
//
//----------------------------------------------------------------------------
#include "winnt.hxx"
#pragma hdrstop
#define INITGUID
#if DBG
DECLARE_INFOLEVEL(FileShare );
DECLARE_DEBUG( FileShare);
#define FileShareDebugOut(x) FileShareInlineDebugOut x
#endif
DEFINE_IDispatch_ExtMgr_Implementation(CWinNTFileShare);
DEFINE_IADsExtension_ExtMgr_Implementation(CWinNTFileShare);
DEFINE_IADs_TempImplementation(CWinNTFileShare);
DEFINE_IADs_PutGetImplementation(CWinNTFileShare,FileShareClass, gdwFileShareTableSize);
DEFINE_IADsPropertyList_Implementation(CWinNTFileShare, FileShareClass, gdwFileShareTableSize)
CWinNTFileShare::CWinNTFileShare()
{
_pDispMgr = NULL;
_pExtMgr = NULL;
_pszShareName = NULL;
_pPropertyCache = NULL;
_pszServerName = NULL;
ENLIST_TRACKING(CWinNTFileShare);
return;
}
CWinNTFileShare::~CWinNTFileShare()
{
delete _pExtMgr; // created last, destroyed first
delete _pDispMgr;
if(_pszShareName){
FreeADsStr(_pszShareName);
}
if(_pszServerName){
FreeADsStr(_pszServerName);
}
delete _pPropertyCache;
return;
}
//+---------------------------------------------------------------------------
//
// Function: CWinNTFileShare::Create
//
// Synopsis: Static function used to create a FileShare object. This
// will be called by EnumFileShares::Next
//
// Arguments: [ppWinNTFileShare] -- Ptr to a ptr to a new FileShare object.
//
// Returns: HRESULT.
//
// Modifies:
//
// History: 12-11-95 RamV Created.
//
//----------------------------------------------------------------------------
HRESULT
CWinNTFileShare::Create(LPTSTR pszADsParent,
LPTSTR pszServerName,
LPTSTR pszServiceName,
LPTSTR pszShareName,
DWORD dwObject,
REFIID riid,
CWinNTCredentials& Credentials,
LPVOID * ppvoid
)
{
CWinNTFileShare FAR * pCWinNTFileShare = NULL;
HRESULT hr;
//
// Create the FileShare Object
//
hr = AllocateFileShareObject(pszADsParent,
pszServerName,
pszServiceName,
pszShareName,
&pCWinNTFileShare );
BAIL_ON_FAILURE(hr);
ADsAssert(pCWinNTFileShare->_pDispMgr);
hr = pCWinNTFileShare->InitializeCoreObject(pszADsParent,
pszShareName,
FILESHARE_CLASS_NAME,
FILESHARE_SCHEMA_NAME,
CLSID_WinNTFileShare,
dwObject);
BAIL_ON_FAILURE(hr);
pCWinNTFileShare->_Credentials = Credentials;
hr = pCWinNTFileShare->_Credentials.RefServer(pszServerName);
BAIL_ON_FAILURE(hr);
//
// Load ext mgr and extensions
//
hr = ADSILoadExtensionManager(
FILESHARE_CLASS_NAME,
(IADs *) pCWinNTFileShare,
pCWinNTFileShare->_pDispMgr,
Credentials,
&pCWinNTFileShare->_pExtMgr
);
BAIL_ON_FAILURE(hr);
ADsAssert(pCWinNTFileShare->_pExtMgr);
// check if the call is from UMI
if(Credentials.GetFlags() & ADS_AUTH_RESERVED) {
//
// we do not pass riid to InitUmiObject below. This is because UMI object
// does not support IDispatch. There are several places in ADSI code where
// riid passed into this function is defaulted to IID_IDispatch -
// IADsContainer::Create for example. To handle these cases, we always
// request IID_IUnknown from the UMI object. Subsequent code within UMI
// will QI for the appropriate interface.
//
if(4 == pCWinNTFileShare->_dwNumComponents) {
pCWinNTFileShare->_CompClasses[0] = L"Domain";
pCWinNTFileShare->_CompClasses[1] = L"Computer";
pCWinNTFileShare->_CompClasses[2] = L"FileService";
pCWinNTFileShare->_CompClasses[3] = L"FileShare";
}
else if(3 == pCWinNTFileShare->_dwNumComponents) {
pCWinNTFileShare->_CompClasses[0] = L"Computer";
pCWinNTFileShare->_CompClasses[1] = L"FileService";
pCWinNTFileShare->_CompClasses[2] = L"FileShare";
}
else
BAIL_ON_FAILURE(hr = UMI_E_FAIL);
hr = pCWinNTFileShare->InitUmiObject(
pCWinNTFileShare->_Credentials,
FileShareClass,
gdwFileShareTableSize,
pCWinNTFileShare->_pPropertyCache,
(IUnknown *) (INonDelegatingUnknown *) pCWinNTFileShare,
pCWinNTFileShare->_pExtMgr,
IID_IUnknown,
ppvoid
);
BAIL_ON_FAILURE(hr);
//
// UMI object was created and the interface was obtained successfully.
// UMI object now has a reference to the inner unknown of IADs, since
// the call to Release() below is not going to be made in this case.
//
RRETURN(hr);
}
hr = pCWinNTFileShare->QueryInterface(riid, (void **)ppvoid);
BAIL_ON_FAILURE(hr);
pCWinNTFileShare->Release();
RRETURN(hr);
error:
delete pCWinNTFileShare;
RRETURN (hr);
}
HRESULT
CWinNTFileShare::AllocateFileShareObject(LPTSTR pszADsParent,
LPTSTR pszServerName,
LPTSTR pszServiceName,
LPTSTR pszShareName,
CWinNTFileShare ** ppFileShare
)
{
CWinNTFileShare * pCWinNTFileShare = NULL;
HRESULT hr;
//
// Create the FileShare Object
//
pCWinNTFileShare = new CWinNTFileShare();
if (pCWinNTFileShare == NULL) {
hr = E_OUTOFMEMORY;
goto error;
}
pCWinNTFileShare->_pDispMgr = new CAggregatorDispMgr;
if(pCWinNTFileShare ->_pDispMgr == NULL){
hr = E_OUTOFMEMORY;
goto error;
}
hr = LoadTypeInfoEntry(pCWinNTFileShare->_pDispMgr,
LIBID_ADs,
IID_IADsFileShare,
(IADsFileShare *)pCWinNTFileShare,
DISPID_REGULAR );
BAIL_ON_FAILURE(hr);
hr = LoadTypeInfoEntry(pCWinNTFileShare->_pDispMgr,
LIBID_ADs,
IID_IADsPropertyList,
(IADsPropertyList *)pCWinNTFileShare,
DISPID_VALUE );
BAIL_ON_FAILURE(hr);
pCWinNTFileShare->_pszServerName =
AllocADsStr(pszServerName);
if(!(pCWinNTFileShare->_pszServerName)){
hr = E_OUTOFMEMORY;
goto error;
}
pCWinNTFileShare->_pszShareName =
AllocADsStr(pszShareName);
if(!(pCWinNTFileShare->_pszShareName)){
hr = E_OUTOFMEMORY;
goto error;
}
hr = CPropertyCache::createpropertycache(
FileShareClass,
gdwFileShareTableSize,
(CCoreADsObject *)pCWinNTFileShare,
&(pCWinNTFileShare ->_pPropertyCache)
);
BAIL_ON_FAILURE(hr);
(pCWinNTFileShare->_pDispMgr)->RegisterPropertyCache(
pCWinNTFileShare->_pPropertyCache
);
*ppFileShare = pCWinNTFileShare;
RRETURN(hr);
error:
//
// direct memeber assignement assignement at pt of creation, so
// do NOT delete _pPropertyCache or _pDisMgr here to avoid attempt
// of deletion again in pPrintJob destructor and AV
//
delete pCWinNTFileShare;
RRETURN (hr);
}
/* IUnknown methods for FileShare object */
//----------------------------------------------------------------------------
// Function: QueryInterface
//
// Synopsis: If this object is aggregated within another object, then
// all calls will delegate to the outer object. Otherwise, the
// non-delegating QI is called
//
// Arguments:
//
// iid interface requested
// ppInterface Returns pointer to interface requested. NULL if interface
// is not supported.
//
// Returns: S_OK on success. Error code otherwise.
//
// Modifies: *ppInterface to return interface pointer
//
//----------------------------------------------------------------------------
STDMETHODIMP CWinNTFileShare::QueryInterface(
REFIID iid,
LPVOID *ppInterface
)
{
if(_pUnkOuter != NULL)
RRETURN(_pUnkOuter->QueryInterface(
iid,
ppInterface
));
RRETURN(NonDelegatingQueryInterface(
iid,
ppInterface
));
}
//----------------------------------------------------------------------------
// Function: AddRef
//
// Synopsis: IUnknown::AddRef. If this object is aggregated within
// another, all calls will delegate to the outer object.
// Otherwise, the non-delegating AddRef is called
//
// Arguments:
//
// None
//
// Returns: New reference count
//
// Modifies: Nothing
//
//----------------------------------------------------------------------------
STDMETHODIMP_(ULONG) CWinNTFileShare::AddRef(void)
{
if(_pUnkOuter != NULL)
RRETURN(_pUnkOuter->AddRef());
RRETURN(NonDelegatingAddRef());
}
//----------------------------------------------------------------------------
// Function: Release
//
// Synopsis: IUnknown::Release. If this object is aggregated within
// another, all calls will delegate to the outer object.
// Otherwise, the non-delegating Release is called
//
// Arguments:
//
// None
//
// Returns: New reference count
//
// Modifies: Nothing
//
//----------------------------------------------------------------------------
STDMETHODIMP_(ULONG) CWinNTFileShare::Release(void)
{
if(_pUnkOuter != NULL)
RRETURN(_pUnkOuter->Release());
RRETURN(NonDelegatingRelease());
}
//----------------------------------------------------------------------------
STDMETHODIMP
CWinNTFileShare::NonDelegatingQueryInterface(REFIID riid, LPVOID FAR* ppvObj)
{
HRESULT hr = S_OK;
if(!ppvObj){
RRETURN(E_POINTER);
}
if (IsEqualIID(riid, IID_IUnknown))
{
*ppvObj = (IADs *) this;
}
else if (IsEqualIID(riid, IID_IDispatch))
{
*ppvObj = (IADs *)this;
}
else if (IsEqualIID(riid, IID_ISupportErrorInfo))
{
*ppvObj = (ISupportErrorInfo FAR *) this;
}
else if (IsEqualIID(riid, IID_IADsPropertyList))
{
*ppvObj = (IADsPropertyList *)this;
}
else if (IsEqualIID(riid, IID_IADs))
{
*ppvObj = (IADs FAR *) this;
}
else if (IsEqualIID(riid, IID_IADsFileShare))
{
*ppvObj = (IADsFileShare FAR *) this;
}
else if( (_pDispatch != NULL) &&
IsEqualIID(riid, IID_IADsExtension) )
{
*ppvObj = (IADsExtension *) this;
}
else if (_pExtMgr)
{
RRETURN( _pExtMgr->QueryInterface(riid, ppvObj));
}
else
{
*ppvObj = NULL;
RRETURN(E_NOINTERFACE);
}
((LPUNKNOWN)*ppvObj)->AddRef();
RRETURN(S_OK);
}
/* ISupportErrorInfo method */
STDMETHODIMP
CWinNTFileShare::InterfaceSupportsErrorInfo(
THIS_ REFIID riid
)
{
if (IsEqualIID(riid, IID_IADs) ||
IsEqualIID(riid, IID_IADsFileShare) ||
IsEqualIID(riid, IID_IADsPropertyList)) {
return S_OK;
} else {
return S_FALSE;
}
}
//+-----------------------------------------------------------------
//
// Function: SetInfo
//
// Synopsis: SetInfo on actual FileShare
//
// Arguments: void
//
// Returns: HRESULT.
//
// Modifies:
//
// History: 02/08/96 RamV Created
//----------------------------------------------------------------------------
STDMETHODIMP
CWinNTFileShare::SetInfo(THIS)
{
NET_API_STATUS nasStatus;
LPSHARE_INFO_2 lpShareInfo2 = NULL;
HRESULT hr = S_OK;
TCHAR szUncServerName[MAX_PATH];
BOOL fNewFileShare = FALSE;
if (GetObjectState() == ADS_OBJECT_UNBOUND) {
hr = WinNTAddFileShare();
BAIL_IF_ERROR(hr);
SetObjectState(ADS_OBJECT_BOUND);
fNewFileShare = TRUE;
}
//
// First get the information and modify only those fields which
// have been changed by user
//
hr = MakeUncName(_pszServerName, szUncServerName);
BAIL_IF_ERROR(hr);
nasStatus = NetShareGetInfo(szUncServerName,
_pszShareName,
2,
(LPBYTE *)&lpShareInfo2);
if (nasStatus != NERR_Success || !lpShareInfo2){
hr = HRESULT_FROM_WIN32(nasStatus);
goto cleanup;
}
hr = MarshallAndSet(lpShareInfo2);
BAIL_IF_ERROR(hr);
if(SUCCEEDED(hr))
_pPropertyCache->ClearModifiedFlags();
cleanup:
if (FAILED(hr) && fNewFileShare) {
//
// Try and delete the fileshare as the SetInfo as a
// whole failed but the create part was successful.
//
nasStatus = NetShareDel(
szUncServerName,
_pszShareName,
0
);
}
if(lpShareInfo2)
NetApiBufferFree(lpShareInfo2);
RRETURN_EXP_IF_ERR(hr);
}
STDMETHODIMP
CWinNTFileShare::GetInfo(THIS_ DWORD dwApiLevel, BOOL fExplicit)
{
HRESULT hr = S_OK;
switch(dwApiLevel){
case 1:
hr = GetLevel1Info(fExplicit);
BAIL_IF_ERROR(hr);
break;
case 2:
hr = GetLevel2Info(fExplicit);
BAIL_IF_ERROR(hr);
break;
default:
//
// we should not be here
//
ADsAssert(FALSE);
break;
}
cleanup:
RRETURN_EXP_IF_ERR (hr);
}
STDMETHODIMP
CWinNTFileShare::GetInfo(THIS)
{
RRETURN(GetInfo(2,TRUE));
}
STDMETHODIMP
CWinNTFileShare::ImplicitGetInfo(THIS)
{
RRETURN(GetInfo(2,FALSE));
}
//
// helper functions for GetInfo and SetInfo
//
HRESULT
CWinNTFileShare::GetLevel2Info(THIS_ BOOL fExplicit)
{
//
// here we do a NetShareGetInfo on level 2 and unmarshall the relevant
// fields
//
NET_API_STATUS nasStatus;
LPSHARE_INFO_2 lpShareInfo2 = NULL;
HRESULT hr;
TCHAR szUncServerName[MAX_PATH];
POBJECTINFO pObjectInfo = NULL;
TCHAR szComputerPath[MAX_PATH];
hr = MakeUncName(_pszServerName, szUncServerName);
BAIL_IF_ERROR(hr);
nasStatus = NetShareGetInfo(szUncServerName,
_pszShareName,
2,
(LPBYTE *)&lpShareInfo2);
if (nasStatus != NERR_Success || !lpShareInfo2){
hr = HRESULT_FROM_WIN32(nasStatus);
goto cleanup;
}
//
// unmarshall the info
//
hr = BuildObjectInfo(_Parent, &pObjectInfo);
BAIL_IF_ERROR(hr);
hr = BuildComputerFromObjectInfo(pObjectInfo,
szComputerPath);
BAIL_IF_ERROR(hr);
hr = SetLPTSTRPropertyInCache(_pPropertyCache,
TEXT("HostComputer"),
szComputerPath,
fExplicit
);
hr = SetLPTSTRPropertyInCache(_pPropertyCache,
TEXT("Description"),
lpShareInfo2->shi2_remark,
fExplicit
);
hr = SetLPTSTRPropertyInCache(_pPropertyCache,
TEXT("Path"),
lpShareInfo2->shi2_path,
fExplicit
);
hr = SetDWORDPropertyInCache(_pPropertyCache,
TEXT("CurrentUserCount"),
lpShareInfo2->shi2_current_uses,
fExplicit
);
hr = SetDWORDPropertyInCache(_pPropertyCache,
TEXT("MaxUserCount"),
lpShareInfo2->shi2_max_uses,
fExplicit
);
hr = SetLPTSTRPropertyInCache(
_pPropertyCache,
TEXT("Name"),
_Name,
fExplicit
);
cleanup:
if(lpShareInfo2){
NetApiBufferFree(lpShareInfo2);
}
FreeObjectInfo(pObjectInfo);
RRETURN(hr);
}
HRESULT
CWinNTFileShare::GetLevel1Info(THIS_ BOOL fExplicit)
{
//
// here we do a NetShareGetInfo on level 1 and unmarshall the relevant
// fields
//
NET_API_STATUS nasStatus;
LPSHARE_INFO_1 lpShareInfo1 = NULL;
HRESULT hr;
TCHAR szUncServerName[MAX_PATH];
POBJECTINFO pObjectInfo = NULL;
TCHAR szComputerPath[MAX_PATH];
hr = MakeUncName(_pszServerName, szUncServerName);
BAIL_IF_ERROR(hr);
nasStatus = NetShareGetInfo(szUncServerName,
_pszShareName,
1,
(LPBYTE *)&lpShareInfo1);
if (nasStatus != NERR_Success || !lpShareInfo1){
hr = HRESULT_FROM_WIN32(nasStatus);
goto cleanup;
}
//
// unmarshall the info
//
//
// unmarshall the info
//
hr = BuildObjectInfo(_Parent, &pObjectInfo);
BAIL_IF_ERROR(hr);
hr = BuildComputerFromObjectInfo(pObjectInfo,
szComputerPath);
BAIL_IF_ERROR(hr);
hr = SetLPTSTRPropertyInCache(_pPropertyCache,
TEXT("HostComputer"),
szComputerPath,
fExplicit
);
cleanup:
if(lpShareInfo1)
NetApiBufferFree(lpShareInfo1);
FreeObjectInfo(pObjectInfo);
RRETURN(hr);
}
HRESULT
CWinNTFileShare::WinNTAddFileShare(void)
{
TCHAR szUncServerName[MAX_ADS_PATH];
NET_API_STATUS nasStatus;
SHARE_INFO_2 ShareInfo2;
DWORD dwParmErr;
DWORD dwMaxUserCount;
LPTSTR pszPath = NULL;
LPTSTR pszDescription = NULL;
HRESULT hr = S_OK;
hr = MakeUncName(_pszServerName, szUncServerName);
BAIL_IF_ERROR(hr);
//
// Fill the ShareInfo2 structure
//
ShareInfo2.shi2_netname = _pszShareName;
ShareInfo2.shi2_type = STYPE_DISKTREE;
hr = GetLPTSTRPropertyFromCache(_pPropertyCache,
TEXT("Path"),
&pszPath);
if(SUCCEEDED(hr)){
ShareInfo2.shi2_path = pszPath;
} else {
ShareInfo2.shi2_path = _T("");
}
hr = GetLPTSTRPropertyFromCache(_pPropertyCache,
TEXT("Description"),
&pszDescription);
if(SUCCEEDED(hr)){
ShareInfo2.shi2_remark = pszDescription;
} else {
ShareInfo2.shi2_remark = TEXT("");
}
hr = GetDWORDPropertyFromCache(_pPropertyCache,
TEXT("MaxUserCount"),
&dwMaxUserCount);
if(SUCCEEDED(hr)){
ShareInfo2.shi2_max_uses = dwMaxUserCount;
} else {
ShareInfo2.shi2_max_uses = -1; // unlimited
}
ShareInfo2.shi2_permissions = ACCESS_ALL & ~ ACCESS_PERM;
ShareInfo2.shi2_current_uses = 0;
ShareInfo2.shi2_passwd = NULL;
nasStatus = NetShareAdd(szUncServerName,
2,
(LPBYTE )&ShareInfo2,
&dwParmErr);
if(nasStatus != NERR_Success){
#if DBG
FileShareDebugOut((DEB_TRACE,
"NetShareAdd : parameter %ld unknown\n",
dwParmErr));
#endif
hr = HRESULT_FROM_WIN32(nasStatus);
goto cleanup;
} else{
hr = S_OK;
}
cleanup:
if(pszPath){
FreeADsStr(pszPath);
}
if(pszDescription){
FreeADsStr(pszDescription);
}
RRETURN(hr);
}
STDMETHODIMP
CWinNTFileShare::get_CurrentUserCount(THIS_ LONG FAR* retval)
{
GET_PROPERTY_LONG((IADsFileShare *)this, CurrentUserCount);
}
STDMETHODIMP
CWinNTFileShare::get_Description(THIS_ BSTR FAR* retval)
{
GET_PROPERTY_BSTR((IADsFileShare *)this, Description);
}
STDMETHODIMP
CWinNTFileShare::put_Description(THIS_ BSTR bstrDescription)
{
PUT_PROPERTY_BSTR((IADsFileShare *)this, Description);
}
STDMETHODIMP
CWinNTFileShare::get_HostComputer(THIS_ BSTR FAR* retval)
{
HRESULT hr;
POBJECTINFO pObjectInfo = NULL;
TCHAR szComputerName[MAX_PATH];
if(!retval){
RRETURN_EXP_IF_ERR(E_ADS_BAD_PARAMETER);
}
hr = BuildObjectInfo(_Parent, &pObjectInfo);
BAIL_ON_FAILURE(hr);
hr = BuildComputerFromObjectInfo(pObjectInfo,
szComputerName);
BAIL_ON_FAILURE(hr);
hr = ADsAllocString(szComputerName, retval);
error:
FreeObjectInfo(pObjectInfo);
RRETURN_EXP_IF_ERR(hr);
}
STDMETHODIMP
CWinNTFileShare::put_HostComputer(THIS_ BSTR bstrHostComputer)
{
RRETURN_EXP_IF_ERR(E_ADS_PROPERTY_NOT_SUPPORTED);
}
STDMETHODIMP
CWinNTFileShare::get_Path(THIS_ BSTR FAR* retval)
{
GET_PROPERTY_BSTR((IADsFileShare *)this, Path);
}
STDMETHODIMP
CWinNTFileShare::put_Path(THIS_ BSTR bstrPath)
{
//
// note that path can be set only prior to creation
// of the object. It cannot be changed later.
//
if(GetObjectState() == ADS_OBJECT_UNBOUND){
PUT_PROPERTY_BSTR((IADsFileShare *)this, Path);
} else {
RRETURN_EXP_IF_ERR(E_ADS_PROPERTY_NOT_SUPPORTED);
}
}
STDMETHODIMP
CWinNTFileShare::get_MaxUserCount(THIS_ LONG FAR* retval)
{
GET_PROPERTY_LONG((IADsFileShare *)this, MaxUserCount);
}
STDMETHODIMP
CWinNTFileShare::put_MaxUserCount(THIS_ LONG lMaxUserCount)
{
PUT_PROPERTY_LONG((IADsFileShare *)this, MaxUserCount);
}
HRESULT
CWinNTFileShare::MarshallAndSet(LPSHARE_INFO_2 lpShareInfo2)
{
HRESULT hr = S_OK;
LPTSTR pszDescription = NULL;
LPTSTR pszPath = NULL;
DWORD dwValue;
TCHAR szUncServerName[MAX_PATH];
NET_API_STATUS nasStatus;
DWORD dwParmErr;
hr = MakeUncName(_pszServerName,
szUncServerName);
BAIL_IF_ERROR(hr);
hr = GetLPTSTRPropertyFromCache(
_pPropertyCache,
TEXT("Description"),
&pszDescription
);
if(SUCCEEDED(hr)){
lpShareInfo2->shi2_remark = pszDescription;
}
hr = GetLPTSTRPropertyFromCache(
_pPropertyCache,
TEXT("Path"),
&pszPath
);
//
// pszPath should not be NULL - sanity check to catch prefix issue.
//
if(SUCCEEDED(hr) && pszPath) {
#ifdef WIN95
if (_wcsicmp(lpShareInfo2->shi2_path, pszPath) ) {
#else
if (CompareStringW(
LOCALE_SYSTEM_DEFAULT,
NORM_IGNORECASE,
lpShareInfo2->shi2_path,
-1,
pszPath,
-1
) != CSTR_EQUAL ) {
#endif
// trying to change the path which is not allowed
hr = (E_ADS_PROPERTY_NOT_SUPPORTED);
BAIL_IF_ERROR(hr);
}
lpShareInfo2->shi2_path = pszPath;
}
hr = GetDWORDPropertyFromCache(
_pPropertyCache,
TEXT("MaxUserCount"),
&dwValue
);
if(SUCCEEDED(hr)){
lpShareInfo2->shi2_max_uses = dwValue;
}
//
// you ignore earlier errors, why? because these errors were raised
// due to internal cached values being invalid.
//
hr = S_OK;
//
// Do the SetInfo now that you have all info
//
nasStatus = NetShareSetInfo(szUncServerName,
_pszShareName,
2,
(LPBYTE)lpShareInfo2,
&dwParmErr);
if(nasStatus != NERR_Success){
#if DBG
FileShareDebugOut((DEB_TRACE,
"NetShareSetInfo : parameter %ld unknown\n", dwParmErr));
#endif
hr = HRESULT_FROM_WIN32(nasStatus);
}
cleanup:
if(pszDescription)
FreeADsStr(pszDescription);
if(pszPath)
FreeADsStr(pszPath);
RRETURN_EXP_IF_ERR(hr);
}
//
// helper functions
//
HRESULT
WinNTDeleteFileShare(POBJECTINFO pObjectInfo)
{
HRESULT hr = S_OK;
NET_API_STATUS nasStatus = NERR_Success;
TCHAR szUncServerName[MAX_PATH];
hr = MakeUncName(pObjectInfo->ComponentArray[1],
szUncServerName);
BAIL_IF_ERROR(hr);
nasStatus = NetShareDel(szUncServerName,
pObjectInfo->ComponentArray[3],
0);
cleanup:
if(FAILED(hr)){
RRETURN(hr);
}
if(nasStatus != NERR_Success){
RRETURN(HRESULT_FROM_WIN32(nasStatus));
}
else{
RRETURN(S_OK);
}
}