2020-09-30 16:53:55 +02:00

836 lines
25 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*++ BUILD Version: 0001 Increment if a change has global effects
Copyright (c) 1998-1999 Microsoft Corporation
Module Name:
ntfrsapi.h
Abstract:
Header file for the application programmer's interfaces to the
File Replication Service (NtFrs) that support they system volumes
and DC Promotion / Demotion.
Environment:
User Mode - Win32
Notes:
--*/
#ifndef _NTFRSAPI_H_
#define _NTFRSAPI_H_
#ifdef __cplusplus
extern "C" {
#endif
//
// Pull in public headers for compat.
//
#include <frsapip.h>
//
// If a file or dir create has a name that starts with the following GUID
// then FRS does not replicate the created file or dir. Note: For dirs
// this means that the directory is never entered in the FRS directory filter
// table so FRS will never replicate the dir (even after it is renamed) or
// any changes to the dir (like ACLs or added streams or attrib changes) or
// any children created under the dir.
//
#define NTFRS_REPL_SUPPRESS_PREFIX L"2ca04e7e-44c8-4076-8890a424b8ad193e"
DWORD
WINAPI
NtFrsApi_PrepareForPromotionW(
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service seeds the system volume during the promotion
of a server to a Domain Controller (DC). The files and directories
for the system volume come from the same machine that is supplying
the initial Directory Service (DS).
This function prepares the NtFrs service on this machine for
promotion by stopping the service, deleting old promotion
state in the registry, and restarting the service.
This function is not idempotent and isn't MT safe.
Arguments:
None.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_PrepareForDemotionUsingCredW(
IN SEC_WINNT_AUTH_IDENTITY *Credentials, OPTIONAL
IN HANDLE ClientToken,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
Replication is stopped by tombstoning the system volume's replica
set.
This function prepares the NtFrs service on this machine for
demotion by stopping the service, deleting old demotion
state in the registry, and restarting the service.
This function is not idempotent and isn't MT safe.
Arguments:
Credentials -- Credentionals to use in ldap binding call, if supplied.
ClientToken -- Impersonation token to use if no Credentials supplied.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_PrepareForDemotionW(
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
Replication is stopped by tombstoning the system volume's replica
set.
This function prepares the NtFrs service on this machine for
demotion by stopping the service, deleting old demotion
state in the registry, and restarting the service.
This function is not idempotent and isn't MT safe.
Arguments:
None.
Return Value:
Win32 Status
--*/
#define NTFRSAPI_SERVICE_STATE_IS_UNKNOWN (00)
#define NTFRSAPI_SERVICE_PROMOTING (10)
#define NTFRSAPI_SERVICE_DEMOTING (20)
#define NTFRSAPI_SERVICE_DONE (99)
DWORD
WINAPI
NtFrsApi_StartPromotionW(
IN PWCHAR ParentComputer, OPTIONAL
IN PWCHAR ParentAccount, OPTIONAL
IN PWCHAR ParentPassword, OPTIONAL
IN DWORD DisplayCallBack(IN PWCHAR Display), OPTIONAL
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG), OPTIONAL
IN PWCHAR ReplicaSetName,
IN PWCHAR ReplicaSetType,
IN DWORD ReplicaSetPrimary,
IN PWCHAR ReplicaSetStage,
IN PWCHAR ReplicaSetRoot
);
/*++
Routine Description:
The NtFrs service seeds the system volume during the promotion
of a server to a Domain Controller (DC). The files and directories
for the system volume come from the same machine that is supplying
the initial Directory Service (DS).
This function kicks off a thread that updates the sysvol information
in the registry and initiates the seeding process. The thread tracks
the progress of the seeding and periodically informs the caller.
The threads started by NtFrsApi_StartPromotionW can be forcefully
terminated with NtFrsApi_AbortPromotionW.
The threads started by NtFrsApi_StartPromotionW can be waited on
with NtFrsApi_WaitForPromotionW.
Arguments:
ParentComputer - An RPC-bindable name of the computer that is
supplying the Directory Service (DS) with its
initial state. The files and directories for
the system volume are replicated from this
parent computer.
ParentAccount - A logon account on ParentComputer.
ParentPassword - The logon account's password on ParentComputer.
DisplayCallBack - Called periodically with a progress display.
ReplicaSetName - Name of the replica set.
ReplicaSetType - Type of replica set (enterprise or domain)
ReplicaSetPrimary - Is this the primary member of the replica set?
- 1 = primary; 0 = not.
ReplicaSetStage - Staging path.
ReplicaSetRoot - Root path.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_StartDemotionW(
IN PWCHAR ReplicaSetName,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
Replication is stopped by tombstoning the system volume's replica
set.
This function kicks off a thread that stops replication of the
system volume on this machine by telling the NtFrs service on
this machine to tombstone the system volume's replica set.
The threads started by NtFrsApi_StartDemotionW can be forcefully
terminated with NtFrsApi_AbortDemotionW.
The threads started by NtFrsApi_StartDemotionW can be waited on
with NtFrsApi_WaitForDemotionW.
Arguments:
ReplicaSetName - Name of the replica set.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_WaitForPromotionW(
IN DWORD TimeoutInMilliSeconds,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service seeds the system volume during the promotion
of a server to a Domain Controller (DC). The files and directories
for the system volume come from the same machine that is supplying
the initial Directory Service (DS).
This function waits for the seeding to finish or to stop w/error.
Arguments:
TimeoutInMilliSeconds - Timeout in milliseconds for waiting for
seeding to finish. INFINITE if no timeout.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_WaitForDemotionW(
IN DWORD TimeoutInMilliSeconds,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
Replication is stopped by tombstoning the system volume's replica
set.
This function waits for the tombstoning to finish or to stop w/error.
Arguments:
TimeoutInMilliSeconds - Timeout in milliseconds for waiting for
seeding to finish. INFINITE if no timeout.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_CommitPromotionW(
IN DWORD TimeoutInMilliSeconds,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
WARNING - This function assumes the caller will reboot the system
soon after this call!
The NtFrs service seeds the system volume during the promotion
of a server to a Domain Controller (DC). The files and directories
for the system volume come from the same machine that is supplying
the initial Directory Service (DS).
This function waits for the seeding to finish, stops the service,
and commits the state in the registry. On reboot, the NtFrs Service
updates the DS on this machine with the information in the registry.
Arguments:
TimeoutInMilliSeconds - Timeout in milliseconds for waiting for
seeding to finish. INFINITE if no timeout.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_CommitDemotionW(
IN DWORD TimeoutInMilliSeconds,
IN DWORD ErrorCallBack(IN PWCHAR, IN ULONG) OPTIONAL
);
/*++
Routine Description:
WARNING - This function assumes the caller will reboot the system
soon after this call!
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
Replication is stopped by tombstoning the system volume's replica
set.
This function waits for the tombstoning to finish, tells the service
to forcibly delete the system volumes' replica sets, stops the service,
and commits the state in the registry. On reboot, the NtFrs Service
updates the DS on this machine with the information in the registry.
Arguments:
TimeoutInMilliSeconds - Timeout in milliseconds for waiting for
tombstoning to finish. INFINITE if no timeout.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_AbortPromotionW(
VOID
);
/*++
Routine Description:
The NtFrs service seeds the system volume during the promotion
of a server to a Domain Controller (DC). The files and directories
for the system volume come from the same machine that is supplying
the initial Directory Service (DS).
This function aborts the seeding process by stopping the service,
deleting the promotion state out of the registry, cleaning up
the active threads and the active RPC calls, and finally resetting
the service to its pre-seeding state.
Arguments:
None.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_AbortDemotionW(
VOID
);
/*++
Routine Description:
The NtFrs service replicates the enterprise system volume to all
Domain Controllers (DCs) and replicates the domain system volume
to the DCs in a domain until the DC is demoted to a member server.
During demotion, NtFrsApi_StartDemotionW stops replication of
the system volume on this machine by telling the NtFrs service
on this machine to tombstone the system volume's replica set.
This function aborts the tombstoning process by stopping the service,
deleting the demotion state out of the registry, cleaning up
the active threads and the active RPC calls, and finally resetting
the service to its pre-tombstoning state.
Arguments:
None.
Return Value:
Win32 Status
--*/
//
// Type of internal information returned by NtFrsApi_InfoW()
//
#define NTFRSAPI_INFO_TYPE_MIN (0)
#define NTFRSAPI_INFO_TYPE_VERSION (0)
#define NTFRSAPI_INFO_TYPE_SETS (1)
#define NTFRSAPI_INFO_TYPE_DS (2)
#define NTFRSAPI_INFO_TYPE_MEMORY (3)
#define NTFRSAPI_INFO_TYPE_IDTABLE (4)
#define NTFRSAPI_INFO_TYPE_OUTLOG (5)
#define NTFRSAPI_INFO_TYPE_INLOG (6)
#define NTFRSAPI_INFO_TYPE_THREADS (7)
#define NTFRSAPI_INFO_TYPE_STAGE (8)
#define NTFRSAPI_INFO_TYPE_CONFIGTABLE (9)
#define NTFRSAPI_INFO_TYPE_MAX (10)
//
// FRS Writer commands. freeze freezes the frs service
// thaw releases frozen command servers.
// FRS guarantees that snapshots taken while
// FRS is in frozen state will not have partial files.
//
#define NTFRSAPI_WRITER_COMMAND_FREEZE (1)
#define NTFRSAPI_WRITER_COMMAND_THAW (2)
#define NTFRSAPI_WRITER_COMMAND_MAX (3)
//
// Internal constants
//
//
// NTFRSAPI_DEFAULT_INFO_SIZE must not be larger than range specified
// in frsapi.idl
//
#define NTFRSAPI_DEFAULT_INFO_SIZE (64 * 1024)
#define NTFRSAPI_MINIMUM_INFO_SIZE ( 1 * 1024)
//
// Opaque information from NtFrs.
// Parse with NtFrsApi_InfoLineW().
// Free with NtFrsApi_InfoFreeW();
//
typedef struct _NTFRSAPI_INFO {
ULONG Major; // Major rev of ntfrsapi.dll
ULONG Minor; // Minor rev of ntfrsapi.dll
ULONG NtFrsMajor; // Major rev of NtFrs service.
ULONG NtFrsMinor; // Minor rev of NtFrs service.
ULONG SizeInChars; // Size of this struct.
ULONG Flags; //
ULONG TypeOfInfo; // Info type code above.
ULONG TotalChars; // Cumulative chars returned.
ULONG CharsToSkip; // Chars to skip over in the next call.
ULONG OffsetToLines; // Offset to start of returned data.
ULONG OffsetToFree; // Offset to next free byte in this struct.
CHAR Lines[1]; // Start of var len return data buffer.
} NTFRSAPI_INFO, *PNTFRSAPI_INFO;
//
// RPC Blob must be at least this size so we can check Major/Minor rev and
// buffer size parameters.
//
#define NTFRSAPI_INFO_HEADER_SIZE (5 * sizeof(ULONG))
//
// NtFrsApi Information Flags
//
// Returned Version info is valid.
//
#define NTFRSAPI_INFO_FLAGS_VERSION (0x00000001)
//
// Returned data buffer is full.
//
#define NTFRSAPI_INFO_FLAGS_FULL (0x00000002)
DWORD
WINAPI
NtFrsApi_InfoW(
IN PWCHAR ComputerName, OPTIONAL
IN ULONG TypeOfInfo,
IN ULONG SizeInChars,
IN OUT PVOID *NtFrsApiInfo
);
/*++
Routine Description:
Return a buffer full of the requested information. The information
can be extracted from the buffer with NtFrsApi_InfoLineW().
*NtFrsApiInfo should be NULL on the first call. On subsequent calls,
*NtFrsApiInfo will be filled in with more data if any is present.
Otherwise, *NtFrsApiInfo is set to NULL and the memory is freed.
The SizeInChars is a suggested size; the actual memory usage
may be different. The function chooses the memory usage if
SizeInChars is 0.
The format of the returned information can change without notice.
Arguments:
ComputerName - Poke the service on this computer. The computer
name can be any RPC-bindable name. Usually, the
NetBIOS or DNS name works just fine. The NetBIOS
name can be found with GetComputerName() or
hostname. The DNS name can be found with
gethostbyname() or ipconfig /all. If NULL, the
service on this computer is contacted. The service
is contacted using Secure RPC.
TypeOfInfo - See the constants beginning with NTFRSAPI_INFO_
in ntfrsapi.h.
SizeInChars - Suggested memory usage; actual may be different.
0 == Function chooses memory usage
NtFrsApiInfo - Opaque. Parse with NtFrsApi_InfoLineW().
Free with NtFrsApi_InfoFreeW();
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_InfoLineW(
IN PNTFRSAPI_INFO NtFrsApiInfo,
IN OUT PVOID *InOutLine
);
/*++
Routine Description:
Extract the wchar lines of information from NtFrsApiInformation.
Returns the address of the next L'\0' terminated line of information.
NULL if none.
Arguments:
NtFrsApiInfo - Opaque. Returned by NtFrsApi_InfoW().
Parse with NtFrsApi_InfoLineW().
Free with NtFrsApi_InfoFreeW().
Return Value:
Win32 Status
--*/
BOOL
WINAPI
NtFrsApi_InfoMoreW(
IN PNTFRSAPI_INFO NtFrsApiInfo
);
/*++
Routine Description:
All of the information may not have fit in the buffer. The additional
information can be fetched by calling NtFrsApi_InfoW() again with the
same NtFrsApiInfo struct. NtFrsApi_InfoW() will return NULL in
NtFrsApiInfo if there is no more information.
However, the information returned in subsequent calls to _InfoW() may be
out of sync with the previous information. If the user requires a
coherent information set, then the information buffer should be freed
with NtFrsApi_InfoFreeW() and another call made to NtFrsApi_InfoW()
with an increased SizeInChars. Repeat the procedure until
NtFrsApi_InfoMoreW() returns FALSE.
Arguments:
NtFrsApiInfo - Opaque. Returned by NtFrsApi_InfoW().
Parse with NtFrsApi_InfoLineW().
Free with NtFrsApi_InfoFreeW().
Return Value:
TRUE - The information buffer does *NOT* contain all of the info.
FALSE - The information buffer does contain all of the info.
--*/
DWORD
WINAPI
NtFrsApi_InfoFreeW(
IN PVOID *NtFrsApiInfo
);
/*++
Routine Description:
Free the information buffer allocated by NtFrsApi_InfoW();
Arguments:
NtFrsApiInfo - Opaque. Returned by NtFrsApi_InfoW().
Parse with NtFrsApi_InfoLineW().
Free with NtFrsApi_InfoFreeW().
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_DeleteSysvolMember(
IN PSEC_WINNT_AUTH_IDENTITY_W pCreds,
IN PWCHAR BindingDC,
IN PWCHAR NTDSSettingsDn,
IN OPTIONAL PWCHAR ComputerDn
);
/*++
Routine Description:
This API is written to be called from NTDSUTIL.EXE to remove
FRS member and subscriber object for a server that is being
removed (without dcpromo-demote) from the list of DCs.
Arguments:
pCreds p Credentials used to bind to the DS.
BindingDC - Name of a DC to perform the delete on.
NTDSSettingsDn - Dn of the "NTDS Settings" object for the server
that is being removed from the sysvol replica set.
ComputerDn - Dn of the computer object for the server that is
being removed from the sysvol replica set.
Return Value:
Win32 Status
--*/
//
// ReplicaSetType -- (From Frs-Replica-Set-Type in NTFRS-Replica-Set Object)
//
#define FRS_RSTYPE_ENTERPRISE_SYSVOL 1 // This replica set is enterprise system volume
#define FRS_RSTYPE_DOMAIN_SYSVOL 2 // This replica set is domain system volume
#define FRS_RSTYPE_DFS 3 // A DFS alternate set
#define FRS_RSTYPE_OTHER 4 // None of the above.
DWORD
WINAPI
NtFrsApi_IsPathReplicated(
IN OPTIONAL PWCHAR ComputerName,
IN PWCHAR Path,
IN ULONG ReplicaSetTypeOfInterest,
OUT BOOL *Replicated,
OUT ULONG *Primary,
OUT BOOL *Root,
OUT GUID *ReplicaSetGuid
);
/*++
Routine Description:
Checks if the Path given is part of a replica set of type
ReplicaSetTypeOfInterest. If ReplicaSetTypeOfInterest is 0, will match for
any replica set type.On successful execution the OUT parameters are set as
follows:
Replicated == TRUE iff Path is part of a replica set of type
ReplicaSetTypeOfInterest
Primary == 0 if this machine is not the primary for the replica set
1 if this machine is the primary for the replica set
2 if there is no primary for the replica set
Root == TRUE iff Path is the root path for the replica
Arguments:
ComputerName - Bind to the service on this computer. The computer
name can be any RPC-bindable name. Usually, the
NetBIOS or DNS name works just fine. The NetBIOS
name can be found with GetComputerName() or
hostname. The DNS name can be found with
gethostbyname() or ipconfig /all. If NULL, the
service on this computer is contacted.
Path - the local path to check
ReplicaSetTypeOfInterest - The type of replica set to match against. Set to
0 to match any replica set.
Replicated - set TRUE iff Path is part of a replica set of type
ReplicaSetTypeOfInterest.
If Replicated is FALSE, the other OUT parameters are not set.
Primary - set to 0 if this machine is not the primary for the replica set
1 if this machine is the primary for the replica set
2 if there is no primary for the replica set
Root - set TRUE iff Path is the root path for the replica.
ReplicaSetGuid - GUID of the matching replica set.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApi_WriterCommand(
IN OPTIONAL PWCHAR ComputerName,
IN ULONG Command
);
/*++
Routine Description:
Arguments:
ComputerName - Bind to the service on this computer. The computer
name can be any RPC-bindable name. Usually, the
NetBIOS or DNS name works just fine. The NetBIOS
name can be found with GetComputerName() or
hostname. The DNS name can be found with
gethostbyname() or ipconfig /all. If NULL, the
service on this computer is contacted.
Command - Freeze and thaw commands.
Return Value:
Win32 Status
--*/
DWORD
WINAPI
NtFrsApiGetBackupRestoreSetType(
IN PVOID BurContext,
IN PVOID BurSet,
OUT PWCHAR SetType,
IN OUT DWORD *SetTypeSizeInBytes
);
/*++
Routine Description:
Return the type of the replica set. The type is
returned as a string. The types are defined in the
frsapip.h file.
Arguments:
BurContext - From NtFrsApiInitializeBackupRestore()
BurSet - Opaque struct representing a replicating directory.
Returned by NtFrsApiEnumBackupRestoreSets(). Not
valid across calls to NtFrsApiGetBackupRestoreSets().
SetType - type of the replica set in a string format.
SetTypeSizeInBytes - Length of the passed in buffer.
Return Value:
ERROR_MORE_DATE - If the passed in buffer is not big enough
to hold the type. SetTypeSizeInBytes is set
to the size of buffer required.
ERROR_INVALID_PARAMETER - Parameter validation.
ERROR_NOT_FOUND - If passed in set is not found in the context
or if it does not have a type specified in
the registry.
ERROR_SUCCESS - When everything goes fine. SetTypeSizeInBytes
returns the number of bytes written to the
buffer.
Win32 Status
--*/
DWORD
WINAPI
NtFrsApiGetBackupRestoreSetGuid(
IN PVOID BurContext,
IN PVOID BurSet,
OUT PWCHAR SetGuid,
IN OUT DWORD *SetGuidSizeInBytes
);
/*++
Routine Description:
Return the type of the replica set. The type is
returned as a string. The types are defined in the
frsapip.h file.
Arguments:
BurContext - From NtFrsApiInitializeBackupRestore()
BurSet - Opaque struct representing a replicating directory.
Returned by NtFrsApiEnumBackupRestoreSets(). Not
valid across calls to NtFrsApiGetBackupRestoreSets().
SetGuid - Guid of the replica set in a string format.
SetGuidSizeInBytes - Length of the passed in buffer.
Return Value:
ERROR_MORE_DATE - If the passed in buffer is not big enough
to hold the guid. SetGuidSizeInBytes is set
to the size of buffer required.
ERROR_INVALID_PARAMETER - Parameter validation.
ERROR_NOT_FOUND - If passed in set is not found in the context.
ERROR_SUCCESS - When everything goes fine. SetGuidSizeInBytes
returns the number of bytes written to the
buffer.
Win32 Status
--*/
#ifdef __cplusplus
}
#endif
#endif _NTFRSAPI_H_