|
|
//---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995
//
// File: getobj.cxx
//
// Contents: NetWare 3.12 GetObject functionality
//
// History:
//----------------------------------------------------------------------------
#include "NWCOMPAT.hxx"
#pragma hdrstop
//+---------------------------------------------------------------------------
// Function: GetObject
//
// Synopsis: Called by ResolvePathName to return an object
//
// Arguments: [LPWSTR szBuffer]
// [CCredentials &Credentials]
// [LPVOID *ppObject]
//
// Returns: HRESULT
//
// Modifies: -
//
// History: 11-Jan-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetObject( LPWSTR szBuffer, CCredentials &Credentials, LPVOID * ppObject ) { OBJECTINFO ObjectInfo; POBJECTINFO pObjectInfo = &ObjectInfo; CLexer Lexer(szBuffer); HRESULT hr = S_OK;
memset(pObjectInfo, 0, sizeof(OBJECTINFO)); hr = Object(&Lexer, pObjectInfo); BAIL_ON_FAILURE(hr);
hr = ValidateProvider(pObjectInfo); BAIL_ON_FAILURE(hr);
switch (pObjectInfo->ObjectType) { case TOKEN_COMPUTER: hr = GetComputerObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_USER: hr = GetUserObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_GROUP: hr = GetGroupObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_SCHEMA: hr = GetSchemaObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_CLASS: hr = GetClassObject(pObjectInfo, ppObject); break;
case TOKEN_PROPERTY: hr = GetPropertyObject(pObjectInfo, ppObject); break;
case TOKEN_SYNTAX: hr = GetSyntaxObject(pObjectInfo, ppObject); break;
case TOKEN_FILESERVICE: hr = GetFileServiceObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_FILESHARE: hr = GetFileShareObject(pObjectInfo, Credentials, ppObject); break;
case TOKEN_PRINTER: hr = GetPrinterObject(pObjectInfo, Credentials, ppObject); break;
default: hr = HeuristicGetObject(pObjectInfo, Credentials, ppObject); break; }
error:
FreeObjectInfo( &ObjectInfo, TRUE ); RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: HeuristicGetObject
//
// Synopsis: Get object of yet undetermined type.
//
// Arguments: [POBJECTINFO pObjectInfo]
// [CCredentials &Credentials]
// [LPVOID *ppObject]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 11-Jan-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT HeuristicGetObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK;
//
// Case 0: No componenet - Namespace object.
//
if (pObjectInfo->NumComponents == 0) { RRETURN(GetNamespaceObject(pObjectInfo, Credentials, ppObject)); }
//
// Case 1: Single component - Computer object.
//
if (pObjectInfo->NumComponents == 1) {
RRETURN(GetComputerObject(pObjectInfo, Credentials, ppObject)); }
//
// Case 2: Two components - FileService object
// Group object
// Schema object
// User object
// Printer object
//
if (pObjectInfo->NumComponents == 2) {
hr = GetSchemaObject(pObjectInfo, Credentials, ppObject);
if (FAILED(hr)) {
hr = GetUserObject(pObjectInfo, Credentials, ppObject);
if (FAILED(hr)) {
hr = GetGroupObject(pObjectInfo, Credentials, ppObject);
if (FAILED(hr)) {
hr = GetFileServiceObject(pObjectInfo, Credentials, ppObject);
if (FAILED(hr)) {
hr = GetPrinterObject(pObjectInfo, Credentials, ppObject); } } } }
if (FAILED(hr)) { hr = E_ADS_UNKNOWN_OBJECT; } else { RRETURN(S_OK); } }
//
// Case 3: Three components - FileShare object
// Schema Class object
// Schema FunctionSet object
// Schema Syntax object
//
if (pObjectInfo->NumComponents == 3) {
hr = GetFileShareObject(pObjectInfo, Credentials, ppObject);
if (FAILED(hr)) {
if ( _wcsicmp( pObjectInfo->ComponentArray[1], SCHEMA_NAME ) == 0 ){
hr = GetClassObject(pObjectInfo, ppObject);
if (FAILED(hr)) { hr = GetPropertyObject(pObjectInfo, ppObject); }
if (FAILED(hr)) {
hr = GetSyntaxObject(pObjectInfo, ppObject); } } }
if (FAILED(hr)) { hr = E_ADS_UNKNOWN_OBJECT; } else { RRETURN(S_OK); } }
//
// Case 4: Four components - Schema FunctionSetAlias object
// Schema Property object
//
RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetNamespaceObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 04-Mar-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetNamespaceObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK;
hr = ValidateNamespaceObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATNamespace::CreateNamespace( L"ADs:", L"NWCOMPAT:", Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); BAIL_ON_FAILURE(hr);
RRETURN(hr);
error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetComputerObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 11-Jan-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetComputerObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidateComputerObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATComputer::CreateComputer( ADsParent, pObjectInfo->ComponentArray[0], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetUserObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 29-Feb-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetUserObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidateUserObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATUser::CreateUser( ADsParent, NWCOMPAT_COMPUTER_ID, pObjectInfo->ComponentArray[0], pObjectInfo->ComponentArray[1], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetGroupObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 29-Feb-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetGroupObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidateGroupObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATGroup::CreateGroup( ADsParent, NWCOMPAT_COMPUTER_ID, pObjectInfo->ComponentArray[0], pObjectInfo->ComponentArray[1], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetSchemaObject
//
// Synopsis:
//
// Arguments:
//
// Returns:
//
// Modifies:
//
// History: 1-17-96 yihsins Created.
//
//----------------------------------------------------------------------------
HRESULT GetSchemaObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { LPUNKNOWN pUnknown = NULL; WCHAR ADsParent[MAX_ADS_PATH]; HRESULT hr = S_OK;
if (pObjectInfo->NumComponents != 2) RRETURN(E_ADS_BAD_PATHNAME);
if ( _wcsicmp( pObjectInfo->ComponentArray[1], SCHEMA_NAME ) != 0 ) { hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
hr = BuildParent(pObjectInfo, ADsParent); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATSchema::CreateSchema( ADsParent, pObjectInfo->ComponentArray[1], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, (void **)&pUnknown ); BAIL_ON_FAILURE(hr);
*ppObject = pUnknown;
RRETURN(hr);
error: if (pUnknown) pUnknown->Release();
*ppObject = NULL; RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetClassObject
//
// Synopsis:
//
// Arguments:
//
// Returns:
//
// Modifies:
//
// History: 1-17-96 yihsins Created.
//
//----------------------------------------------------------------------------
HRESULT GetClassObject( POBJECTINFO pObjectInfo, LPVOID * ppObject ) { LPUNKNOWN pUnknown = NULL; WCHAR ADsParent[MAX_ADS_PATH]; HRESULT hr = S_OK; DWORD i;
if (pObjectInfo->NumComponents != 3) RRETURN(E_ADS_BAD_PATHNAME);
if ( _wcsicmp( pObjectInfo->ComponentArray[1], SCHEMA_NAME ) != 0 ) { hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// Look for the given class name
//
for ( i = 0; i < g_cNWCOMPATClasses; i++ ) { if ( _wcsicmp( g_aNWCOMPATClasses[i].bstrName, pObjectInfo->ComponentArray[2] ) == 0 ) break; }
if ( i == g_cNWCOMPATClasses ) { //
// Class name not found, return error
//
hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// Class name found, create and return the object
//
hr = BuildParent(pObjectInfo, ADsParent); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATClass::CreateClass( ADsParent, &g_aNWCOMPATClasses[i], ADS_OBJECT_BOUND, IID_IUnknown, (void **)&pUnknown ); BAIL_ON_FAILURE(hr);
*ppObject = pUnknown;
RRETURN(hr);
error: if (pUnknown) pUnknown->Release();
*ppObject = NULL; RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetSyntaxObject
//
// Synopsis:
//
// Arguments:
//
// Returns:
//
// Modifies:
//
// History: 1-17-96 yihsins Created.
//
//----------------------------------------------------------------------------
HRESULT GetSyntaxObject( POBJECTINFO pObjectInfo, LPVOID * ppObject ) { LPUNKNOWN pUnknown = NULL; WCHAR ADsParent[MAX_ADS_PATH]; HRESULT hr = S_OK; DWORD i;
if (pObjectInfo->NumComponents != 3) RRETURN(E_ADS_BAD_PATHNAME);
if ( _wcsicmp( pObjectInfo->ComponentArray[1], SCHEMA_NAME ) != 0 ) { hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// Look for the given syntax name
//
for ( i = 0; i < g_cNWCOMPATSyntax; i++ ) { if ( _wcsicmp( g_aNWCOMPATSyntax[i].bstrName, pObjectInfo->ComponentArray[2] ) == 0 ) break; }
if ( i == g_cNWCOMPATSyntax ) { //
// Syntax name not found, return error
//
hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// Syntax name found, create and return the object
//
hr = BuildParent(pObjectInfo, ADsParent); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATSyntax::CreateSyntax( ADsParent, &g_aNWCOMPATSyntax[i], ADS_OBJECT_BOUND, IID_IUnknown, (void **)&pUnknown ); BAIL_ON_FAILURE(hr);
*ppObject = pUnknown;
RRETURN(hr);
error: if (pUnknown) pUnknown->Release();
*ppObject = NULL; RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetPropertyObject
//
// Synopsis:
//
// Arguments:
//
// Returns:
//
// Modifies:
//
// History: 1-17-96 yihsins Created.
//
//----------------------------------------------------------------------------
HRESULT GetPropertyObject( POBJECTINFO pObjectInfo, LPVOID * ppObject ) { LPUNKNOWN pUnknown = NULL; WCHAR ADsParent[MAX_ADS_PATH]; WCHAR ADsGrandParent[MAX_ADS_PATH]; HRESULT hr = S_OK; DWORD nClass, nProp;
if (pObjectInfo->NumComponents != 3) RRETURN(E_ADS_BAD_PATHNAME);
if ( _wcsicmp( pObjectInfo->ComponentArray[1], SCHEMA_NAME ) != 0 ) { hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// We found the specified functional set, now see if we can locate
// the given property name
//
for ( nProp = 0; nProp < g_cNWCOMPATProperties; nProp++ ) { if ( _wcsicmp(g_aNWCOMPATProperties[nProp].szPropertyName, pObjectInfo->ComponentArray[2] ) == 0 ) break; }
if ( nProp == g_cNWCOMPATProperties ) { // Return error because the given property name is not found
hr = E_ADS_BAD_PATHNAME; BAIL_ON_FAILURE(hr); }
//
// Property name is found, so create and return the object
//
hr = BuildParent(pObjectInfo, ADsParent); BAIL_ON_FAILURE(hr);
hr = BuildGrandParent(pObjectInfo, ADsGrandParent); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATProperty::CreateProperty( ADsParent, &(g_aNWCOMPATProperties[nProp]), ADS_OBJECT_BOUND, IID_IUnknown, (void **)&pUnknown ); BAIL_ON_FAILURE(hr);
*ppObject = pUnknown;
RRETURN(hr);
error: if (pUnknown) pUnknown->Release();
*ppObject = NULL; RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetFileServiceObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 22-Apr-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetFileServiceObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidateFileServiceObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATFileService::CreateFileService( ADsParent, pObjectInfo->ComponentArray[0], pObjectInfo->ComponentArray[1], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetFileShareObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 22-Apr-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetFileShareObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidateFileShareObject( pObjectInfo, Credentials ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATFileShare::CreateFileShare( ADsParent, pObjectInfo->ComponentArray[2], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: GetPrinterObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
// LPVOID * ppObject
//
// Returns: HRESULT
//
// Modifies:
//
// History: 2-May-96 t-ptam Created.
//
//----------------------------------------------------------------------------
HRESULT GetPrinterObject( POBJECTINFO pObjectInfo, CCredentials &Credentials, LPVOID * ppObject ) { HRESULT hr = S_OK; WCHAR ADsParent[MAX_ADS_PATH];
hr = ValidatePrinterObject( pObjectInfo ); BAIL_ON_FAILURE(hr);
hr = BuildParent( pObjectInfo, ADsParent ); BAIL_ON_FAILURE(hr);
hr = CNWCOMPATPrintQueue::CreatePrintQueue( ADsParent, pObjectInfo->ComponentArray[1], Credentials, ADS_OBJECT_BOUND, IID_IUnknown, ppObject ); error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidateNamespaceObject
//
// Synopsis:
//
// Arguments: POBJECTINFO pObjectInfo
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies:
//
// History: 16-Jan-96 t-ptam (Patrick) Created.
//
//----------------------------------------------------------------------------
HRESULT ValidateNamespaceObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) {
//
// BugBug -- KrishnaG move this to a global string.
//
if (!_wcsicmp(pObjectInfo->ProviderName, bstrProviderName)) { } RRETURN(S_OK); }
//+---------------------------------------------------------------------------
// Function: ValidateComputerObject
//
// Synopsis: Validate the existence of a computer object by obtaining
// a handle to it. A computer object must exist if a handle
// to it can be obtained.
//
// Arguments: [LPWSTR szComputerName]
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies:
//
// History: 16-Jan-96 t-ptam (Patrick) Created.
//
//----------------------------------------------------------------------------
HRESULT ValidateComputerObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) { //
// A handle of a certain bindery can only be obtained if the bindery
// exist. Therefore we used this fact to validate the existence of
// a computer object.
//
NWCONN_HANDLE hConn = NULL; HRESULT hr = S_OK;
if (pObjectInfo->NumComponents != 1) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Try to obtain a handle to a NWCOMPAT Server.
//
hr = NWApiGetBinderyHandle( &hConn, pObjectInfo->ComponentArray[0], Credentials ); BAIL_ON_FAILURE(hr);
//
// Detach handle.
//
hr = NWApiReleaseBinderyHandle( hConn );
error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidateUserObject
//
// Synopsis: Validate the existence of a computer object by obtaining
// a handle to it. A computer object must exist if a handle
// to it can be obtained.
//
// Arguments: [LPWSTR szComputerName]
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies: pObjectInfo->ComponentArray[1] is upper-cased
//
// History: 29-Feb-96 t-ptam (Patrick) Created.
// 29-Jul-96 t-danal Uppercase fix.
//
// Note: Netware will let you create a lowercase user name but will
// internally store only uppercase. However, it will not
// return the uppercase user name on a lowercase request.
//
//----------------------------------------------------------------------------
HRESULT ValidateUserObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) { NWCONN_HANDLE hConn = NULL; HRESULT hr = S_OK; DWORD dwResumeObjectID = 0xffffffff;
if (pObjectInfo->NumComponents != 2) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Obtain a handle to a NetWare Server.
//
hr = NWApiGetBinderyHandle( &hConn, pObjectInfo->ComponentArray[0], Credentials ); BAIL_ON_FAILURE(hr);
//
// Get the specified (uppercased) user object.
//
hr = NWApiValidateObject( hConn, OT_USER, _wcsupr(pObjectInfo->ComponentArray[1]), &dwResumeObjectID ); BAIL_ON_FAILURE(hr);
error: if (hConn) { NWApiReleaseBinderyHandle(hConn); }
RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidateGroupObject
//
// Synopsis: Validate the existence of a group object by scanning
// for it in the bindery.
//
// Arguments: [POBJECTINFO pObjectInfo]
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies: pObjectInfo->ComponentArray[1] is upper-cased
//
// History: 29-Feb-96 t-ptam (Patrick) Created.
// 29-Jul-96 t-danal Uppercase fix.
//
// Note: Netware will let you create a lowercase user name but will
// internally store only uppercase. However, it will not
// return the uppercase user name on a lowercase request.
//
//----------------------------------------------------------------------------
HRESULT ValidateGroupObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) { NWCONN_HANDLE hConn = NULL; HRESULT hr = S_OK; DWORD dwResumeObjectID = 0xffffffff;
if (pObjectInfo->NumComponents != 2) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Obtain a handle to a NetWare Server.
//
hr = NWApiGetBinderyHandle( &hConn, pObjectInfo->ComponentArray[0], Credentials ); BAIL_ON_FAILURE(hr);
//
// Get the specified (uppercased) group object.
//
hr = NWApiValidateObject( hConn, OT_USER_GROUP, _wcsupr(pObjectInfo->ComponentArray[1]), &dwResumeObjectID ); BAIL_ON_FAILURE(hr);
error: if (hConn) { NWApiReleaseBinderyHandle(hConn); }
RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidateFileServiceObject
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies:
//
// History: 22-Apr-96 t-ptam (Patrick) Created.
//
//----------------------------------------------------------------------------
HRESULT ValidateFileServiceObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) { //
// In NetWare, a FileService object represents a bindery, which is also
// represented as a computer object. Therefore validation of file service
// object can be done the same way as the computer object.
//
//
// A handle of a certain bindery can only be obtained if the bindery exist.
// Therefore we used this fact to validate the existence of a computer
// object.
//
NWCONN_HANDLE hConn = NULL; HRESULT hr = S_OK;
if (pObjectInfo->NumComponents != 2) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Check for valid NetWare File Server name.
//
if (_wcsicmp(pObjectInfo->ComponentArray[1], bstrNWFileServiceName)) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Try to obtain a handle to a NWCOMPAT Server.
//
hr = NWApiGetBinderyHandle( &hConn, pObjectInfo->ComponentArray[0], Credentials ); BAIL_ON_FAILURE(hr);
//
// Detach handle.
//
hr = NWApiReleaseBinderyHandle( hConn );
error: RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidateFileShareObject
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
// CCredentials &Credentials
//
// Returns: HRESULT
//
// Modifies:
//
// History: 29-Apr-96 t-ptam (Patrick) Created.
//
//----------------------------------------------------------------------------
HRESULT ValidateFileShareObject( POBJECTINFO pObjectInfo, CCredentials &Credentials ) { HRESULT hr = S_OK; DWORD dwResumeObjectID = 0xffffffff; NWCONN_HANDLE hConn = NULL; NWVOL_NUM VolumeNumber = 0;
if (pObjectInfo->NumComponents != 3) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Obtain a handle to a NetWare Server.
//
hr = NWApiGetBinderyHandle( &hConn, pObjectInfo->ComponentArray[0], Credentials ); BAIL_ON_FAILURE(hr);
//
// Try to get the Volume ID that correspond to the Volume name. If it
// succeeds, the FileShare is valid.
//
hr = NWApiGetVolumeNumber( hConn, pObjectInfo->ComponentArray[2], &VolumeNumber ); BAIL_ON_FAILURE(hr);
error: if (hConn) { NWApiReleaseBinderyHandle(hConn); }
RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: ValidatePrinterObject
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 2-May-96 t-ptam (Patrick) Created.
//
//----------------------------------------------------------------------------
HRESULT ValidatePrinterObject( POBJECTINFO pObjectInfo ) { HANDLE hPrinter = NULL; HRESULT hr = S_OK; WCHAR szUncName[MAX_PATH];
if (pObjectInfo->NumComponents != 2) { RRETURN(E_ADS_BAD_PATHNAME); }
//
// Build UNC name from ObjectInfo.
//
wsprintf( szUncName, L"\\\\%s\\%s", pObjectInfo->ComponentArray[0], pObjectInfo->ComponentArray[1] );
//
// Get a handle of the printer.
//
hr = NWApiOpenPrinter( szUncName, &hPrinter, PRINTER_ACCESS_USE ); BAIL_ON_FAILURE(hr);
//
// Release it.
//
hr = NWApiClosePrinter( hPrinter ); error:
RRETURN(hr); }
//+---------------------------------------------------------------------------
// Function: BuildParent
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
// [LPWSTR szBuffer]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 11-3-95 krishnag Created.
//
//----------------------------------------------------------------------------
HRESULT BuildParent( POBJECTINFO pObjectInfo, LPWSTR szBuffer ) { DWORD i = 0;
if (!pObjectInfo->ProviderName) { RRETURN(E_ADS_BAD_PATHNAME); }
wsprintf(szBuffer,L"%s:", pObjectInfo->ProviderName);
if (pObjectInfo->NumComponents - 1) {
wcscat(szBuffer, L"//"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[0]);
for (i = 1; i < (pObjectInfo->NumComponents - 1); i++) { wcscat(szBuffer, L"/"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[i]); } } RRETURN(S_OK); }
//+---------------------------------------------------------------------------
// Function: BuildGrandParent
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
// [LPWSTR szBuffer]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 11-3-95 krishnag Created.
//
//----------------------------------------------------------------------------
HRESULT BuildGrandParent(POBJECTINFO pObjectInfo, LPWSTR szBuffer) { DWORD i = 0;
if (!pObjectInfo->ProviderName) { RRETURN(E_ADS_BAD_PATHNAME); }
wsprintf(szBuffer,L"%s:", pObjectInfo->ProviderName);
if (pObjectInfo->NumComponents - 2) {
wcscat(szBuffer, L"//"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[0]);
for (i = 1; i < (pObjectInfo->NumComponents - 2); i++) { wcscat(szBuffer, L"/"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[i]); } }
RRETURN(S_OK); }
//+---------------------------------------------------------------------------
// Function: BuildADsPath
//
// Synopsis:
//
// Arguments: [POBJECTINFO pObjectInfo]
// [LPWSTR szBuffer]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 11-3-95 krishnag Created.
//
//----------------------------------------------------------------------------
HRESULT BuildADsPath( POBJECTINFO pObjectInfo, LPWSTR szBuffer ) { DWORD i = 0;
if (!pObjectInfo->ProviderName) { RRETURN(E_ADS_BAD_PATHNAME); }
wsprintf(szBuffer,L"%s:", pObjectInfo->ProviderName);
if (pObjectInfo->NumComponents) {
wcscat(szBuffer, L"//"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[0]);
for (i = 1; i < (pObjectInfo->NumComponents); i++) { wcscat(szBuffer, L"/"); wcscat(szBuffer, pObjectInfo->DisplayComponentArray[i]); } } RRETURN(S_OK); }
|