364 lines
7.1 KiB
C
364 lines
7.1 KiB
C
/*++
|
|
|
|
Microsoft Windows
|
|
|
|
Copyright (C) Microsoft Corporation, 1998 - 2001
|
|
|
|
Module Name:
|
|
|
|
netdom.h
|
|
|
|
Abstract:
|
|
|
|
Common includes and definitions to be used in netdom5
|
|
|
|
--*/
|
|
#ifndef __NETDOM_H__
|
|
#define __NETDOM_H__
|
|
|
|
#include <netdom5.h>
|
|
|
|
extern HINSTANCE g_hInstance;
|
|
|
|
#define FLAG_ON(flag,bits) ((flag) & (bits))
|
|
|
|
#define LOG_VERBOSE( __x__ ) { if ( Verbose ) { NetDompDisplayMessage __x__ ; } }
|
|
#define ERROR_VERBOSE( __error__) { if ( Verbose && __error__ != ERROR_SUCCESS ) { \
|
|
NetDompDisplayErrorMessage( __error__); } }
|
|
#if DBG == 1
|
|
#define DBG_VERBOSE( __x__ ) { if ( Verbose ) { printf __x__ ;} }
|
|
#define CHECK_WIN32(err, cmd) \
|
|
if (ERROR_SUCCESS != err) \
|
|
{ \
|
|
if (Verbose) \
|
|
{ \
|
|
printf("Error %d at line %d in file %s\n", err, __LINE__, __FILE__); \
|
|
} \
|
|
cmd; \
|
|
}
|
|
#else
|
|
#define DBG_VERBOSE( __x__ )
|
|
#define CHECK_WIN32(err, cmd) \
|
|
if (ERROR_SUCCESS != err) \
|
|
{ \
|
|
cmd; \
|
|
}
|
|
#endif
|
|
|
|
#define NETDOM_STR_LEN 64
|
|
|
|
extern BOOL Verbose;
|
|
|
|
typedef struct _ND5_AUTH_INFO {
|
|
PWSTR User;
|
|
PWSTR Password;
|
|
PWSTR pwzUserWoDomain;
|
|
PWSTR pwzUsersDomain;
|
|
|
|
} ND5_AUTH_INFO, *PND5_AUTH_INFO;
|
|
|
|
#define NETDOM_TRUST_FLAG_DOMAIN_NOT_FOUND 1
|
|
#define NETDOM_TRUST_FLAG_PARENT 2
|
|
#define NETDOM_TRUST_FLAG_CHILD 4
|
|
#define NETDOM_TRUST_PDC_REQUIRED 8
|
|
#define NETDOM_TRUST_TYPE_MIT 10
|
|
#define NETDOM_TRUST_TYPE_INDIRECT 20
|
|
|
|
typedef struct _ND5_TRUST_INFO {
|
|
|
|
PWSTR Server;
|
|
PUNICODE_STRING DomainName;
|
|
PUNICODE_STRING FlatName;
|
|
PSID Sid;
|
|
LSA_HANDLE LsaHandle; // LSA Policy handle
|
|
LSA_HANDLE TrustHandle; // TDO handle
|
|
ULONG Flags;
|
|
BOOL Uplevel;
|
|
BOOL Connected;
|
|
PVOID BlobToFree;
|
|
BOOL fWasDownlevel;
|
|
|
|
} ND5_TRUST_INFO, *PND5_TRUST_INFO;
|
|
|
|
bool
|
|
CmdFlagOn(ARG_RECORD * rgNetDomArgs, NETDOM_ARG_ENUM eArgIndex);
|
|
|
|
DWORD
|
|
NetDompGetTrustDirection(
|
|
IN PND5_TRUST_INFO TrustingInfo,
|
|
IN PND5_TRUST_INFO TrustedInfo,
|
|
IN OUT PDWORD Direction
|
|
);
|
|
|
|
//
|
|
// From ndutil.cxx
|
|
//
|
|
DWORD
|
|
NetDompValidateSecondaryArguments(ARG_RECORD * rgNetDomArgs,
|
|
NETDOM_ARG_ENUM eFirstValidParam, ...);
|
|
|
|
DWORD
|
|
NetDompGetUserAndPasswordForOperation(ARG_RECORD * rgNetDomArgs,
|
|
NETDOM_ARG_ENUM eUserType,
|
|
PWSTR DefaultDomain,
|
|
PND5_AUTH_INFO AuthIdent);
|
|
|
|
VOID
|
|
NetDompFreeAuthIdent(
|
|
IN PND5_AUTH_INFO AuthIdent
|
|
);
|
|
|
|
DWORD
|
|
NetDompGetDomainForOperation(ARG_RECORD * rgNetDomArgs,
|
|
PWSTR Server OPTIONAL,
|
|
BOOL CanDefaultToCurrent,
|
|
PWSTR *DomainName);
|
|
|
|
DWORD
|
|
NetDompGetArgumentString(ARG_RECORD * rgNetDomArgs,
|
|
NETDOM_ARG_ENUM eArgToGet,
|
|
PWSTR *ArgString);
|
|
|
|
BOOL
|
|
NetDompGetArgumentBoolean(ARG_RECORD * rgNetDomArgs,
|
|
NETDOM_ARG_ENUM eArgToGet);
|
|
|
|
DWORD
|
|
NetDompControlService(
|
|
IN PWSTR Server,
|
|
IN PWSTR Service,
|
|
IN DWORD ServiceOptions
|
|
);
|
|
|
|
DWORD
|
|
NetDompRestartAsRequired(ARG_RECORD * rgNetDomArgs,
|
|
PWSTR Machine,
|
|
PWSTR User,
|
|
DWORD PreliminaryStatus,
|
|
DWORD MsgID);
|
|
|
|
DWORD
|
|
NetDompCheckDomainMembership(
|
|
IN PWSTR Server,
|
|
IN PND5_AUTH_INFO AuthInfo,
|
|
IN BOOL EstablishSessionIfRequried,
|
|
IN OUT BOOL * DomainMember
|
|
);
|
|
|
|
DWORD
|
|
NetDompGenerateRandomPassword(
|
|
IN PWSTR Buffer,
|
|
IN ULONG Length
|
|
);
|
|
|
|
BOOL
|
|
NetDompGetUserConfirmation(
|
|
IN DWORD PromptResId,
|
|
IN PWSTR pwzName
|
|
);
|
|
|
|
//
|
|
// From netdom5.cxx
|
|
//
|
|
VOID
|
|
DisplayHelp(NETDOM_ARG_ENUM HelpOp);
|
|
|
|
VOID
|
|
NetDompDisplayMessage(
|
|
IN DWORD MessageId,
|
|
...
|
|
);
|
|
|
|
VOID
|
|
NetDompDisplayMessageAndError(
|
|
IN DWORD MessageId,
|
|
IN DWORD Error,
|
|
IN PWSTR String OPTIONAL
|
|
);
|
|
|
|
VOID
|
|
NetDompDisplayUnexpectedParameter(
|
|
IN PWSTR UnexpectedParameter
|
|
);
|
|
|
|
VOID
|
|
NetDompDisplayErrorMessage(
|
|
IN DWORD Error
|
|
);
|
|
|
|
|
|
//
|
|
// From join.cxx
|
|
//
|
|
DWORD
|
|
NetDompHandleAdd(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleRemove(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleJoin(ARG_RECORD * rgNetDomArgs, BOOL AllowMove);
|
|
|
|
DWORD
|
|
NetDompHandleMove(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleReset(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleResetPwd(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleVerify(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompVerifyServerSC(
|
|
IN PWSTR Domain,
|
|
IN PWSTR Server,
|
|
IN PND5_AUTH_INFO AuthInfo,
|
|
IN ULONG OkMessageId,
|
|
IN ULONG FailedMessageId
|
|
);
|
|
|
|
DWORD
|
|
NetDompResetServerSC(
|
|
IN PWSTR Domain,
|
|
IN PWSTR Server,
|
|
IN PWSTR DomainController, OPTIONAL
|
|
IN PND5_AUTH_INFO AuthInfo,
|
|
IN ULONG OkMessageId,
|
|
IN ULONG FailedMessageId
|
|
);
|
|
|
|
|
|
//
|
|
// From trust.cxx
|
|
//
|
|
DWORD
|
|
NetDompHandleTrust(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompTrustGetDomInfo(
|
|
IN PWSTR Domain,
|
|
IN PWSTR DomainController OPTIONAL,
|
|
IN PND5_AUTH_INFO AuthInfo,
|
|
IN OUT PND5_TRUST_INFO TrustInfo,
|
|
IN BOOL ManageTrust,
|
|
IN BOOL Force,
|
|
IN BOOL fUseNullSession
|
|
);
|
|
|
|
VOID
|
|
NetDompFreeDomInfo(
|
|
IN OUT PND5_TRUST_INFO TrustInfo
|
|
);
|
|
|
|
DWORD
|
|
NetDompVerifyTrust(
|
|
IN PND5_TRUST_INFO TrustingInfo,
|
|
IN PND5_TRUST_INFO TrustedInfo,
|
|
BOOL fShowResults
|
|
);
|
|
|
|
DWORD
|
|
NetDompResetTrustPasswords(
|
|
IN PWSTR TrustingDomain,
|
|
IN PWSTR TrustedDomain,
|
|
IN PND5_AUTH_INFO TrustingCreds,
|
|
IN PND5_AUTH_INFO TrustedCreds
|
|
);
|
|
|
|
DWORD
|
|
NetDompSetMitTrustPW(
|
|
IN PWSTR TrustingDomain,
|
|
IN PWSTR TrustedDomain,
|
|
IN PND5_AUTH_INFO TrustingCreds,
|
|
IN PND5_AUTH_INFO TrustedCreds,
|
|
IN PWSTR pwzNewTrustPW
|
|
);
|
|
|
|
|
|
DWORD
|
|
NetDompIsParentChild(
|
|
IN PND5_TRUST_INFO pFirstDomainInfo,
|
|
IN PND5_TRUST_INFO pSecondDomainName,
|
|
OUT BOOL * pfParentChild
|
|
);
|
|
|
|
//
|
|
// From query.cxx
|
|
//
|
|
DWORD
|
|
NetDompHandleQuery(ARG_RECORD * rgNetDomArgs);
|
|
|
|
//
|
|
// From time.cxx
|
|
//
|
|
DWORD
|
|
NetDompHandleTime(ARG_RECORD * rgNetDomArgs);
|
|
|
|
//
|
|
// From rename.cxx
|
|
//
|
|
DWORD
|
|
NetDompHandleRename(ARG_RECORD * rgNetDomArgs);
|
|
|
|
DWORD
|
|
NetDompHandleRenameComputer(ARG_RECORD * rgNetDomArgs);
|
|
|
|
//
|
|
// From ldap.cxx
|
|
//
|
|
DWORD
|
|
NetDompLdapBind(
|
|
IN LPWSTR DC,
|
|
IN LPWSTR Domain,
|
|
IN LPWSTR User,
|
|
IN LPWSTR Password,
|
|
IN ULONG BindType,
|
|
OUT PLDAP *Ldap
|
|
);
|
|
|
|
|
|
DWORD
|
|
NetDompLdapUnbind(
|
|
IN PLDAP Ldap
|
|
);
|
|
|
|
DWORD
|
|
NetDompLdapReadOneAttribute(
|
|
IN PLDAP Ldap,
|
|
IN PWSTR ObjectPath,
|
|
IN PWSTR Attribute,
|
|
OUT PWSTR *ReadAttribute
|
|
);
|
|
|
|
BOOL
|
|
IsLocalMachine( LPWSTR Machine );
|
|
|
|
DWORD
|
|
NetDompJoinDownlevel(
|
|
IN PWSTR Server,
|
|
IN PWSTR Account,
|
|
IN PWSTR Password,
|
|
IN PWSTR Dc,
|
|
IN ULONG DcFlags,
|
|
IN BOOL AllowMove
|
|
);
|
|
|
|
DWORD
|
|
NetDompManageGroupMembership(
|
|
IN PWSTR Server,
|
|
IN PSID DomainSid,
|
|
IN BOOL Delete
|
|
);
|
|
|
|
DWORD
|
|
NetDompManageMachineSecret(
|
|
IN LSA_HANDLE PolicyHandle,
|
|
IN LPWSTR lpPassword,
|
|
IN INT fControl
|
|
);
|
|
|
|
#endif //ifndef __NETDOM_H__
|