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.
 
 
 
 
 
 

246 lines
6.8 KiB

/**********************************************************************/
/** Microsoft Windows/NT **/
/** Copyright(c) Microsoft Corp., 1991 **/
/**********************************************************************/
/*
lmomisc.cxx
Misc. objects
LOGON_USER - wrapper class which handles NetWkstaSetUID2() net
api call
TIME_DAY_SERVER - wrapper class which handles NetRemoteTOD() net
api
LM_MESSAGE - wrapper class which handles NetMessageBuffSend()
net api
FILE HISTORY:
terryk 04-Sep-91 Created
terryk 11-Sep-91 Code review changed. Attend: terryk jimh
yi-hsins jonn
terryk 19-Sep-91 Move LOGON_USER from lmouser.hxx to
here.
terryk 07-Oct-91 type changes for NT
terryk 17-Oct-91 Change TIME_OF_DAY's variable to pointer
terryk 21-Oct-91 Remove LOGON_USER from NT
*/
#ifndef _LMOMISC_HXX_
#define _LMOMISC_HXX_
#include "lmobj.hxx"
#ifndef WIN32
enum LOGON_USER_STATE
{
INVALID_STATE,
LOGGED_ON,
LOGGED_OFF
};
/*************************************************************************
NAME: LOGON_USER
SYNOPSIS: user object for logon and logoff the network
INTERFACE:
LOGON_USER() - constructor
Logon() - logon the user to the network
Logoff() - logoff the user from the network
Query functions which calls after Logon call:
TCHAR * QueryLogonComputer() - logon computer name
const TCHAR * QueryLogonDomain() - logon domain name
QueryPriv() - privilege level. It will return:
USER_PRIV_GUESST - guest privilege
USER_PRIV_USER - user privilege
USER_PRIV_ADMIN - admin privilege
LONG QueryPasswdAge() - password age. Specifies the
time (in seconds) since the user password was
changed
ULONG QueryPasswdCanChange() - specifies the time when
the user is allowed to change the password. This value
is stored as the number of seconds elapsed since
00:00:00, January 1, 1970. A value of -1 means the
user can never change the password.
ULONG QueryPasswdMustChange() - specifies the time when
the user must change the passwd. The value is stored as
the number of seconds elapsed since 00:00:00, January 1,
1970.
// QueryLogoffXXX()
ULONG QueryLogoffDuration() - specifies the number of
seconds elapsed since the user logged on.
ULONG QueryLogoffNumLogons() - specifies the number of
times this user is logged on. A value of -1 means the
number of logons is unknown.
PARENT: BASE
USES: NLS_STR
CAVEATS:
NOTES: CODEWORK: if we need more logon information, we will
need to implement more QueryLogonXXX() functions.
HISTORY:
terryk 6-Sep-91 Created
terryk 20-Sep-91 Change from USER to BASE
**************************************************************************/
DLL_CLASS LOGON_USER : public BASE
{
private:
enum LOGON_USER_STATE _state;
TCHAR *_pszPasswd;
BOOL _fValid;
NLS_STR _nlsUsername;
NLS_STR _nlsDomain;
BUFFER _buffer;
protected:
struct user_logon_info_1 * QueryLogonInfo() const;
struct user_logoff_info_1 * QueryLogoffInfo() const;
public:
LOGON_USER( const TCHAR * pszUsername, const TCHAR * pszDomain );
APIERR Logon( const TCHAR * pszPasswd, APIERR *pLogonRetCode );
APIERR Logoff( UINT uslogoff_level, APIERR *pLogoffRetCode );
const TCHAR * QueryUsername() const
{ return _nlsUsername.QueryPch(); }
// QueryLogonXXX()
const TCHAR * QueryLogonComputer() const;
const TCHAR * QueryLogonDomain() const;
UINT QueryPriv() const;
LONG QueryPasswdAge() const;
ULONG QueryPasswdCanChange() const;
ULONG QueryPasswdMustChange() const;
// QueryLogoffXXX()
ULONG QueryLogoffDuration() const;
ULONG QueryLogoffNumLogons() const;
};
#endif
/*************************************************************************
NAME: LM_MESSAGE
SYNOPSIS: class for message sending
INTERFACE:
LM_MESSAGE() - constructor
SendBuffer() - send out the message to the recipient
PARENT: LOC_LM_OBJ
CAVEATS:
NOTES:
HISTORY:
terryk 6-Sep-91 Created
**************************************************************************/
DLL_CLASS LM_MESSAGE: public LOC_LM_OBJ
{
public:
LM_MESSAGE( const TCHAR * pszLocation = NULL );
LM_MESSAGE( enum LOCATION_TYPE loctype );
LM_MESSAGE( LOCATION & loc );
APIERR SendBuffer( const TCHAR * pszRecipient, const BUFFER & buffer );
APIERR SendBuffer( const TCHAR * pszRecipient, const TCHAR * pbBuffer,
UINT cbBuffer );
};
/*************************************************************************
NAME: TIME_OF_DAY
SYNOPSIS: This object will get the remote server time/date
information after the GetInfo functionc call.
INTERFACE:
TIME_OF_DAY() - constructor
QueryElapsedt() - return the elapsed time
QueryMsecs() - return the msecs
QueryHours() - return the hours
QueryMins() - return the mins
QuerySecs() - return the secs
QueryHunds() - return the hunds
QueryTimezone() - return the time zone
QueryTInterval() - return the time interval
QueryDay() - return the day
QueryMonth() - return the Month
QueryYear() - return the Year
QueyWeekday() - return the Weekday
PARENT: LOC_LM_OBJ
HISTORY:
terryk 5-Sep-91 Created
**************************************************************************/
DLL_CLASS TIME_OF_DAY: public LOC_LM_OBJ
{
private:
struct time_of_day_info *_ptodi;
protected:
virtual APIERR I_GetInfo();
public:
TIME_OF_DAY( const TCHAR *pszLocation );
TIME_OF_DAY( enum LOCATION_TYPE loctype );
TIME_OF_DAY( LOCATION & loc );
~TIME_OF_DAY();
ULONG QueryElapsedt() const
{ CHECK_OK( 0 );
return _ptodi->tod_elapsedt; }
ULONG QueryMsecs() const
{ CHECK_OK( 0 );
return _ptodi->tod_msecs; }
ULONG QueryHours() const
{ CHECK_OK( 0 );
return _ptodi->tod_hours; }
ULONG QueryMins() const
{ CHECK_OK( 0 );
return _ptodi->tod_mins; }
ULONG QuerySecs() const
{ CHECK_OK( 0 );
return _ptodi->tod_secs; }
ULONG QueryHunds() const
{ CHECK_OK( 0 );
return _ptodi->tod_hunds; }
ULONG QueryTimezone() const
{ CHECK_OK( 0 );
return _ptodi->tod_timezone; }
ULONG QueryTInterval() const
{ CHECK_OK( 0 );
return _ptodi->tod_tinterval; }
ULONG QueryDay() const
{ CHECK_OK( 0 );
return _ptodi->tod_day; }
ULONG QueryMonth() const
{ CHECK_OK( 0 );
return _ptodi->tod_month; }
ULONG QueryYear() const
{ CHECK_OK( 0 );
return _ptodi->tod_year; }
ULONG QueryWeekday() const
{ CHECK_OK( 0 );
return _ptodi->tod_weekday; }
};
#endif // _LMOMISC_HXX_