Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

500 lines
14 KiB

/*++
Copyright (c) 1992-1996 Microsoft Corporation
Module Name:
dlog_tbl.c
Abstract:
All routines to perform operations on the Domain Logon Table.
Environment:
User Mode - Win32
Revision History:
10-May-1996 DonRyan
Removed banner from Technology Dynamics, Inc.
--*/
//--------------------------- WINDOWS DEPENDENCIES --------------------------
//--------------------------- STANDARD DEPENDENCIES -- #include<xxxxx.h> ----
#include <stdio.h>
#include <memory.h>
//--------------------------- MODULE DEPENDENCIES -- #include"xxxxx.h" ------
#include <snmp.h>
#include <snmputil.h>
#include "mibfuncs.h"
//--------------------------- SELF-DEPENDENCY -- ONE #include"module.h" -----
#include "dlog_tbl.h"
//--------------------------- PUBLIC VARIABLES --(same as in module.h file)--
// Prefix to the Domain Logon table
static UINT dlogSubids[] = { 4, 8, 1 };
static AsnObjectIdentifier MIB_DomLogonPrefix = { 3, dlogSubids };
DOM_LOGON_TABLE MIB_DomLogonTable = { 0, NULL };
//--------------------------- PRIVATE CONSTANTS -----------------------------
#define DLOG_FIELD_SUBID (MIB_DomLogonPrefix.idLength+MIB_OidPrefix.idLength)
#define DLOG_FIRST_FIELD DLOG_USER_FIELD
#define DLOG_LAST_FIELD DLOG_MACHINE_FIELD
//--------------------------- PRIVATE STRUCTS -------------------------------
//--------------------------- PRIVATE VARIABLES -----------------------------
//--------------------------- PRIVATE PROTOTYPES ----------------------------
UINT MIB_dlogons_get(
IN OUT RFC1157VarBind *VarBind
);
int MIB_dlogons_match(
IN AsnObjectIdentifier *Oid,
OUT UINT *Pos
);
UINT MIB_dlogons_copyfromtable(
IN UINT Entry,
IN UINT Field,
OUT RFC1157VarBind *VarBind
);
//--------------------------- PRIVATE PROCEDURES ----------------------------
//--------------------------- PUBLIC PROCEDURES -----------------------------
//
// MIB_dlogons_func
// High level routine for handling operations on the Domain Logon table
//
// Notes:
//
// Return Codes:
// None.
//
// Error Codes:
// None.
//
UINT MIB_dlogons_func(
IN UINT Action,
IN MIB_ENTRY *MibPtr,
IN OUT RFC1157VarBind *VarBind
)
{
int Found;
UINT Entry;
UINT Field;
UINT ErrStat;
switch ( Action )
{
case MIB_ACTION_GETFIRST:
// Fill the Domain Logon table with the info from server
if ( SNMPAPI_ERROR == MIB_dlogons_lmget() )
{
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
// If no elements in table, then return next MIB var, if one
if ( MIB_DomLogonTable.Len == 0 )
{
if ( MibPtr->MibNext == NULL )
{
ErrStat = SNMP_ERRORSTATUS_NOSUCHNAME;
goto Exit;
}
// Do get first on the next MIB var
ErrStat = (*MibPtr->MibNext->MibFunc)( Action, MibPtr->MibNext,
VarBind );
break;
}
//
// Place correct OID in VarBind
// Assuming the first field in the first record is the "start"
{
UINT temp_subs[] = { DLOG_FIRST_FIELD };
AsnObjectIdentifier FieldOid = { 1, temp_subs };
AsnObjectIdentifier tmpOid;
tmpOid = VarBind->name; // keep a copy (structure copy)
if (!SnmpUtilOidCpy( &VarBind->name, &MIB_OidPrefix ))
{
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &MIB_DomLogonPrefix ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &FieldOid ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &MIB_DomLogonTable.Table[0].Oid ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
// free the original VarBind->name
SnmpUtilOidFree(&tmpOid);
}
//
// Let fall through on purpose
//
case MIB_ACTION_GET:
ErrStat = MIB_dlogons_get( VarBind );
break;
case MIB_ACTION_GETNEXT:
// Fill the Domain Logon Table with the info from server
if ( SNMPAPI_ERROR == MIB_dlogons_lmget() )
{
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
// Determine which field
Field = VarBind->name.ids[DLOG_FIELD_SUBID];
// Lookup OID in table
if (Field < DLOG_FIRST_FIELD)
{
Entry = 0; // will take the first entry into the table
Field = DLOG_FIRST_FIELD; // and the first column of the table
Found = MIB_TBL_POS_BEFORE;
}
else if (Field > DLOG_LAST_FIELD)
Found = MIB_TBL_POS_END;
else
Found = MIB_dlogons_match( &VarBind->name, &Entry );
// Index not found, but could be more fields to base GET on
if ((Found == MIB_TBL_POS_BEFORE && MIB_DomLogonTable.Len == 0) ||
Found == MIB_TBL_POS_END )
{
// Index not found in table, get next from field
// Field ++;
// Make sure not past last field
// if ( Field > DLOG_LAST_FIELD )
// {
// Get next VAR in MIB
ErrStat = (*MibPtr->MibNext->MibFunc)( MIB_ACTION_GETFIRST,
MibPtr->MibNext,
VarBind );
break;
// }
}
// Get next TABLE entry
if ( Found == MIB_TBL_POS_FOUND )
{
Entry ++;
if ( Entry > MIB_DomLogonTable.Len-1 )
{
Entry = 0;
Field ++;
if ( Field > DLOG_LAST_FIELD )
{
// Get next VAR in MIB
ErrStat = (*MibPtr->MibNext->MibFunc)( MIB_ACTION_GETFIRST,
MibPtr->MibNext,
VarBind );
break;
}
}
}
//
// Place correct OID in VarBind
// Assuming the first field in the first record is the "start"
{
UINT temp_subs[1];
AsnObjectIdentifier FieldOid;
AsnObjectIdentifier tmpOid;
temp_subs[0] = Field;
FieldOid.idLength = 1;
FieldOid.ids = temp_subs;
tmpOid = VarBind->name; // keep a copy (structure copy)
if (!SnmpUtilOidCpy( &VarBind->name, &MIB_OidPrefix ))
{
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &MIB_DomLogonPrefix ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &FieldOid ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
if (!SnmpUtilOidAppend( &VarBind->name, &MIB_DomLogonTable.Table[Entry].Oid ))
{
SnmpUtilOidFree(&VarBind->name);
VarBind->name = tmpOid; // restore
ErrStat = SNMP_ERRORSTATUS_RESOURCEUNAVAILABLE;
goto Exit;
}
// free the original VarBind->name
SnmpUtilOidFree(&tmpOid);
}
ErrStat = MIB_dlogons_copyfromtable( Entry, Field, VarBind );
break;
case MIB_ACTION_SET:
ErrStat = SNMP_ERRORSTATUS_NOSUCHNAME;
break;
default:
ErrStat = SNMP_ERRORSTATUS_GENERR;
}
Exit:
return ErrStat;
} // MIB_dlogons_func
//
// MIB_dlogons_get
// Retrieve Domain Logon Table information.
//
// Notes:
//
// Return Codes:
// None.
//
// Error Codes:
// None.
//
UINT MIB_dlogons_get(
IN OUT RFC1157VarBind *VarBind
)
{
UINT Entry;
int Found;
UINT ErrStat;
if (VarBind->name.ids[DLOG_FIELD_SUBID] < DLOG_FIRST_FIELD ||
VarBind->name.ids[DLOG_FIELD_SUBID] > DLOG_LAST_FIELD)
{
ErrStat = SNMP_ERRORSTATUS_NOSUCHNAME;
goto Exit;
}
// Fill the Domain Logon Table with the info from server
if ( SNMPAPI_ERROR == MIB_dlogons_lmget() )
{
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
Found = MIB_dlogons_match( &VarBind->name, &Entry );
// Look for a complete OID match
if ( Found != MIB_TBL_POS_FOUND )
{
ErrStat = SNMP_ERRORSTATUS_NOSUCHNAME;
goto Exit;
}
// Copy data from table
ErrStat = MIB_dlogons_copyfromtable( Entry, VarBind->name.ids[DLOG_FIELD_SUBID],
VarBind );
Exit:
return ErrStat;
} // MIB_dlogons_get
//
// MIB_dlogons_match
// Match the target OID with a location in the Domain Logon Table
//
// Notes:
//
// Return Codes:
// None.
//
// Error Codes:
// None
//
int MIB_dlogons_match(
IN AsnObjectIdentifier *Oid,
OUT UINT *Pos
)
{
AsnObjectIdentifier TempOid;
int nResult;
// Remove prefix including field reference
TempOid.idLength = Oid->idLength - MIB_OidPrefix.idLength -
MIB_DomLogonPrefix.idLength - 1;
TempOid.ids = &Oid->ids[MIB_OidPrefix.idLength+MIB_DomLogonPrefix.idLength+1];
*Pos = 0;
while ( *Pos < MIB_DomLogonTable.Len )
{
nResult = SnmpUtilOidCmp( &TempOid, &MIB_DomLogonTable.Table[*Pos].Oid );
if ( !nResult )
{
nResult = MIB_TBL_POS_FOUND;
goto Exit;
}
if ( nResult < 0 )
{
nResult = MIB_TBL_POS_BEFORE;
goto Exit;
}
(*Pos)++;
}
nResult = MIB_TBL_POS_END;
Exit:
return nResult;
}
//
// MIB_dlogons_copyfromtable
// Copy requested data from table structure into Var Bind.
//
// Notes:
//
// Return Codes:
// None.
//
// Error Codes:
// None.
//
UINT MIB_dlogons_copyfromtable(
IN UINT Entry,
IN UINT Field,
OUT RFC1157VarBind *VarBind
)
{
UINT ErrStat;
// Get the requested field and save in var bind
switch( Field )
{
case DLOG_USER_FIELD:
// Alloc space for string
VarBind->value.asnValue.string.stream = SnmpUtilMemAlloc( sizeof(char)
* MIB_DomLogonTable.Table[Entry].domLogonUser.length );
if ( VarBind->value.asnValue.string.stream == NULL )
{
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
// Copy string into return position
memcpy( VarBind->value.asnValue.string.stream,
MIB_DomLogonTable.Table[Entry].domLogonUser.stream,
MIB_DomLogonTable.Table[Entry].domLogonUser.length );
// Set string length
VarBind->value.asnValue.string.length =
MIB_DomLogonTable.Table[Entry].domLogonUser.length;
VarBind->value.asnValue.string.dynamic = TRUE;
// Set type of var bind
VarBind->value.asnType = ASN_RFC1213_DISPSTRING;
break;
case DLOG_MACHINE_FIELD:
// Alloc space for string
VarBind->value.asnValue.string.stream = SnmpUtilMemAlloc( sizeof(char)
* MIB_DomLogonTable.Table[Entry].domLogonMachine.length );
if ( VarBind->value.asnValue.string.stream == NULL )
{
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
// Copy string into return position
memcpy( VarBind->value.asnValue.string.stream,
MIB_DomLogonTable.Table[Entry].domLogonMachine.stream,
MIB_DomLogonTable.Table[Entry].domLogonMachine.length );
// Set string length
VarBind->value.asnValue.string.length =
MIB_DomLogonTable.Table[Entry].domLogonMachine.length;
VarBind->value.asnValue.string.dynamic = TRUE;
// Set type of var bind
VarBind->value.asnType = ASN_RFC1213_DISPSTRING;
break;
default:
SNMPDBG(( SNMP_LOG_TRACE, "LMMIB2: Internal Error Domain Logon Table.\n" ));
ErrStat = SNMP_ERRORSTATUS_GENERR;
goto Exit;
}
ErrStat = SNMP_ERRORSTATUS_NOERROR;
Exit:
return ErrStat;
} // MIB_dlogons_copyfromtable
//-------------------------------- END --------------------------------------