Go Premium for a chance to win a PS4. Enter to Win

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 217
  • Last Modified:

API to find out server info

I'm looking for a way to find out the root file server that I'm connected.  We are currently running on a Novell network, in transition to Windows 2000. If there's a API or OCX that will do the trick for both, that would be ideal. However, I'm guessing that it'll be 2 different ones.
0
kcleary
Asked:
kcleary
  • 5
  • 3
  • 2
  • +2
1 Solution
 
falkorCommented:

'try this
Sub main()
    Dim iCtr As Integer
   
    For iCtr = 1 To 28
        Debug.Print iCtr & " = " & Environ$(iCtr)
    Next iCtr
   
    'once you decide on your property, you can call like this:
    'debug.print Envinron$("USERNAME")

End Sub
0
 
falkorCommented:
It sounds like you'll be looking for this one:

msgbox Environ$("HOMESHARE")
0
 
kclearyAuthor Commented:
Works good for an Windows NT computer, but what about for a 9X computer?
0
Concerto Cloud for Software Providers & ISVs

Can Concerto Cloud Services help you focus on evolving your application offerings, while delivering the best cloud experience to your customers? From DevOps to revenue models and customer support, the answer is yes!

Learn how Concerto can help you.

 
falkorCommented:
Hmm, Environ does work on 95.  Unfortunatly, the only 95/98 machines I have around right now are not on our network.  I'm curious, what did you get when you tried it?
0
 
kclearyAuthor Commented:
I'm using the FILE_SERVER variable/property (I didn't see a HOMESHARE one).  On a Win98 PC, there is no variable for FILE_SERVER, so I'm receiving nothing.
0
 
kclearyAuthor Commented:
I'm using the FILE_SERVER variable/property (I didn't see a HOMESHARE one).  On a Win98 PC, there is no variable for FILE_SERVER, so I'm receiving nothing.
0
 
cookreCommented:
For Novell:
Unless you have:
* a standardized login script that sets an environment variable to what you want, or
* a standard drive letter mapping whose properties you can query, then

it will be a real pain to find out what you want.

Much depends on which version of Novell you're running and whether or not you permit multiple connections.  With bindery connections, things are a little easier, but when logging into NDS, the concept of a login server begins to blur, since you don't neccessarily know before hand which physical server you'll be authenticated through.
0
 
Ryan ChongCommented:
Hi kcleary,

Take a look on link below, maybe you can find something useful:

http://www.mvps.org/vbnet/code/network/index.html

'Hope will help.
0
 
kclearyAuthor Commented:
It appears that there's no way to get the info I need all of the time.  Environ$ works on an NT 4.0 PC, but I haven't been able to get it to work elsewhere.  ryancys link has plenty of good code, but nothing that looked like it would take care of the problem.  I beginning to fear that cookre is right.

I will continue to look at some of your comments and hopefully find a solution.
0
 
cookreCommented:
For Novell, if you're using tree logins (as opposed to bindery), and if you have only one login server per container, you would extract the container name from the fully qualified userid then enumerate the servers in the root of that container, looking for the sole login server, i.e., skipping print servers, NWIPs, etc.

If the tree and its' object name were well designed, the server name itself would help in identifying its' function.

Another approach would be to enumerate all of the client's connections, looking further only when you find an attachment to a server in the user's container.

And, yes, there is an API for all of this. You can download the Netware SDK and NovellWin32 SDK for free at:

http://developer.novell.com/ndk/bykit.htm

If I remember right, it's about 85M.

To give you a small glimpse at Netware API programming, here's some code to map a drive (done this way because we couldn't always rely on the presence of the MAP command):

//////////////////////////////////////////////////////////////////////
//
// Map a drive to the specified server
// Returns:
//          Success: 0
//                   If an existing connection is being used,
//                   the returned DriveNumber will be >0.
//                   If the connection is a new one, the returned
//                   DriveNumber will be negative.
//
// Error returns:
// 1 - Unable to get connection references
// 2 - Unable to get connection handle
// 3 - Attach failure
// 4 - Create context handle failure
// 5 - Unable to get context
// 6 - Unable to authenticate
// 7 - No drive letters available
// 8 - Map drive failure
//

int MapDrive(char * ServerName,char * Path,NWCONN_HANDLE * hCon,int *DriveNumber)
{
NWRCODE           RC;
nuint32           ScanCtr;
int               NumConnections;
nuint32           TempConnRef;
nuint32           ConnRefs[100];
NWCONN_HANDLE     hConn;
char              TempServerName[64];
NWCONN_NUM        ConnNumber;
NWDSContextHandle hContext;
char              ContextStr[255];
int               idx;
char              TempStr[256];
nuint16           BitMask;
int               NewConn;
int               RetryCnt;

// Load up all connection references and look
// for the Primary Server
NewConn=0;
ScanCtr=0;
NumConnections=0;
RC=NWCCScanConnRefs(&ScanCtr,&TempConnRef);
while (RC==0)
      {
      ConnRefs[NumConnections]=TempConnRef;
      NumConnections+=1;
      RC=NWCCScanConnRefs(&ScanCtr,&TempConnRef);
      }
if (NumConnections==0)
   {
   strcpy(GlobalErrMsg,"No connection references(MD)");
   return 1;
   }
hConn=0;
for (idx=0; idx<NumConnections; idx++)
    {
    RC=NWCCGetConnRefInfo(ConnRefs[idx],NWCC_INFO_SERVER_NAME,12,TempServerName);
    if (0!=stricmp(ServerName,TempServerName)) continue;
    // Goodie! We have a connection to the selected server
    // Get connection number for tracking info
    RC=NWCCGetConnRefInfo(ConnRefs[idx],NWCC_INFO_CONN_NUMBER,4,&ConnNumber);
    // Get handle to that connection
    RC=NWCCOpenConnByRef(ConnRefs[idx],NWCC_OPEN_LICENSED,NWCC_RESERVED,&hConn);
    if (RC!=0)
       {
       strcpy(GlobalErrMsg,"Unable to open connection ref(MD)");
       return 2;
       }
    break;
    }
// If we didn't have a connection already, make one
if (hConn==0)
   {
   sprintf(TempStr,"Attaching to %s (Attempt 1 of 6)",ServerName);
   UpdateStatusBar(TempStr);
   RC=NWAttachToFileServer(ServerName,0,&hConn);
   while (RC!=0)
         {
         RetryCnt=2;
         while ((RetryCnt<7) && (RC!=0))
               {
               Pause((double)10000);
               sprintf(TempStr,"Attaching to %s (Attempt %d of 6)",ServerName,RetryCnt);
               UpdateStatusBar(TempStr);
               RC=NWAttachToFileServer(ServerName,0,&hConn);
               RetryCnt+=1;
               }
         }
   if (RC!=0) {sprintf(GlobalErrMsg,"Attach failed(%04x)(MD)",RC); return 3;}

   RC=NWDSCreateContextHandle(&hContext);
   if (RC!=0) {sprintf(GlobalErrMsg,"CreateContextHandle failed(%04x)(MD)",RC); return 4;}
   RC=NWDSGetContext(hContext,DCK_NAME_CONTEXT,ContextStr);
   if (RC!=0) {sprintf(GlobalErrMsg,"Attach failed(%04x)(MD)",RC); return 5;}
   RC=NWDSAuthenticateConn(hContext,hConn);
   if (RC!=0) {sprintf(GlobalErrMsg,"Attach failed(%04x)(MD)",RC); return 6;}
   NewConn=1;
   }
//
// Find a drive letter to map through
*DriveNumber=0;
for (idx=7; idx<27; idx++)
    {
    RC=NWGetDriveStatus((nuint16)idx,1,&BitMask,NULL,TempStr,TempStr,TempStr);
    if (RC!=0) continue;
    if (BitMask==0)
       {
       *DriveNumber=idx;
       break;
       }
    }
if (*DriveNumber==0)
   {
   strcpy(GlobalErrMsg,"No drive letters available(MD)");
   return 7;
   }
RC=NWSetDriveBase((nuint16)*DriveNumber,hConn,(NWDIR_HANDLE)0,Path,0);
if (RC!=0)
   {
   sprintf(GlobalErrMsg,"General MapDrive failure [%04x](MD)",RC);
   return 8;
   }
if (NewConn==1) *DriveNumber=-*DriveNumber;
*hCon=hConn;
return 0;
}
0
 
kclearyAuthor Commented:
Thanks to everyone for the help on this question.  It seems there's no easy way to get the information that we need, but you all gave me some valuable info to help solve our problem.

I have submitted a request to split pts. between everyone.

Thanks again for the help.
0
 
ComTechCommented:
Helll all, a Points slplit has been requested and will go as follows:

75=cookre
75=falkor
50=ryancys

I have refunded 125 point for the split.  I will accept 75 here for cookre.

kcleary, wyou will need to open 2 New questions, one for falkor and one for ryancys.

Entitle each question (IN THIS TOPIC AREA) *Points for <Expert Name>*    In the comment box type *for your help in question #20171853*  Choose the points you wish to aware 1=75 and 1=50 and submit, and you are all done.

Thanks,
ComTech
Communtiy Support

0

Featured Post

Hire Technology Freelancers with Gigs

Work with freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely, and get projects done right.

  • 5
  • 3
  • 2
  • +2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now