| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159 | {******************************************************************************}{                                                                              }{ Directory Backup and Restore API interface Unit for Object Pascal            }{                                                                              }{ Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft          }{ Corporation. All Rights Reserved.                                            }{                                                                              }{ The original file is: ntdsbcli.h, released June 2000. The original Pascal    }{ code is: NtDsbCli.pas, released December 2000. The initial developer of the  }{ Pascal code is Marcel van Brakel (brakelm att chello dott nl).               }{                                                                              }{ Portions created by Marcel van Brakel are Copyright (C) 1999-2001            }{ Marcel van Brakel. All Rights Reserved.                                      }{                                                                              }{ Obtained through: Joint Endeavour of Delphi Innovators (Project JEDI)        }{                                                                              }{ You may retrieve the latest version of this file at the Project JEDI         }{ APILIB home page, located at http://jedi-apilib.sourceforge.net              }{                                                                              }{ The contents of this file are used with permission, subject to the Mozilla   }{ Public License Version 1.1 (the "License"); you may not use this file except }{ in compliance with the License. You may obtain a copy of the License at      }{ http://www.mozilla.org/MPL/MPL-1.1.html                                      }{                                                                              }{ Software distributed under the License is distributed on an "AS IS" basis,   }{ WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for }{ the specific language governing rights and limitations under the License.    }{                                                                              }{ Alternatively, the contents of this file may be used under the terms of the  }{ GNU Lesser General Public License (the  "LGPL License"), in which case the   }{ provisions of the LGPL License are applicable instead of those above.        }{ If you wish to allow use of your version of this file only under the terms   }{ of the LGPL License and not to allow others to use your version of this file }{ under the MPL, indicate your decision by deleting  the provisions above and  }{ replace  them with the notice and other provisions required by the LGPL      }{ License.  If you do not delete the provisions above, a recipient may use     }{ your version of this file under either the MPL or the LGPL License.          }{                                                                              }{ For more information about the LGPL: http://www.gnu.org/copyleft/lesser.html }{                                                                              }{******************************************************************************}// $Id: JwaNtDsbCli.pas,v 1.10 2005/09/06 16:36:50 marquardt Exp $unit JwaNtDsbCli;{$WEAKPACKAGEUNIT}{$HPPEMIT ''}{$HPPEMIT '#include ":ntdsbcli.h"'}{$HPPEMIT ''}{$I jediapilib.inc}interfaceuses  JwaWindows;const  g_wszBackupAnnotation = 'NTDS Backup Interface';  {$EXTERNALSYM g_wszBackupAnnotation}  g_aszBackupAnnotation = 'NTDS Backup Interface';  {$EXTERNALSYM g_aszBackupAnnotation}  g_wszRestoreAnnotation = 'NTDS Restore Interface';  {$EXTERNALSYM g_wszRestoreAnnotation}  g_aszRestoreAnnotation = 'NTDS Restore Interface';  {$EXTERNALSYM g_aszRestoreAnnotation}  {$IFDEF UNICODE}  g_szBackupAnnotation  = g_wszBackupAnnotation;  {$EXTERNALSYM g_szBackupAnnotation}  g_szRestoreAnnotation = g_wszRestoreAnnotation;  {$EXTERNALSYM g_szRestoreAnnotation}  {$ELSE}  g_szBackupAnnotation  = g_aszBackupAnnotation;  {$EXTERNALSYM g_szBackupAnnotation}  g_szRestoreAnnotation = g_aszRestoreAnnotation;  {$EXTERNALSYM g_szRestoreAnnotation}  {$ENDIF UNICODE}// Type of Backup passed to DsBackupPrepare()// BACKUP_TYPE_FULL: Requesting backup of the complete DS (DIT, Log files, and Patch files)// BACKUP_TYPE_LOGS_ONLY: Requesting backup of only the log files// BACKUP_TYPE_INCREMENTAL: Requesting incremental backup i.e. backing up only changes that happened since last backup  BACKUP_TYPE_FULL        = $01;  {$EXTERNALSYM BACKUP_TYPE_FULL}  BACKUP_TYPE_LOGS_ONLY   = $02;  {$EXTERNALSYM BACKUP_TYPE_LOGS_ONLY}  BACKUP_TYPE_INCREMENTAL = $04; // not supported in product1  {$EXTERNALSYM BACKUP_TYPE_INCREMENTAL}// Type of Restore passed to DsRestorePrepare()// RESTORE_TYPE_AUTHORATATIVE: The restored version wins throughout the enterprise// RESTORE_TYPE_ONLINE: Restoration is done when NTDS is online.// RESTORE_TYPE_CATCHUP: The restored version is reconciled through the standard reconciliation logic so that the//                          restored DIT can catchup with the rest of the enterprise.  RESTORE_TYPE_AUTHORATATIVE = $01;  {$EXTERNALSYM RESTORE_TYPE_AUTHORATATIVE}  RESTORE_TYPE_ONLINE        = $02; // not supported in product1  {$EXTERNALSYM RESTORE_TYPE_ONLINE}  RESTORE_TYPE_CATCHUP       = $04; // this is the default restore mode  {$EXTERNALSYM RESTORE_TYPE_CATCHUP}// Setting the current log # to this value would disable incremental/differential backup  BACKUP_DISABLE_INCREMENTAL = DWORD($ffffffff);  {$EXTERNALSYM BACKUP_DISABLE_INCREMENTAL}// BFT is the bit flag used to represent file types (directory/dit/logfile/etc.)// We keep them as a character so that we can append/prepend them to the actual file// path. The code in the Backup API's rely on the fact that values 0-256 in 8 bit ascii// map to the values 0-256 in unicode.type  {$IFDEF UNICODE}  BFT = WCHAR;  {$EXTERNALSYM BFT}  {$ELSE}  BFT = Char;  {$EXTERNALSYM BFT}  {$ENDIF UNICODE}// Bit flags://  BFT_DIRECTORY               - indicates path specified is a directory//  BFT_DATABASE_DIRECTORY      - indicates that file goes into database directory//  BFT_LOG_DIRECTORY           - indicates that the file goes into log directoryconst  BFT_DIRECTORY          = $80;  {$EXTERNALSYM BFT_DIRECTORY}  BFT_DATABASE_DIRECTORY = $40;  {$EXTERNALSYM BFT_DATABASE_DIRECTORY}  BFT_LOG_DIRECTORY      = $20;  {$EXTERNALSYM BFT_LOG_DIRECTORY}// Following combinations are defined for easy use of the filetype and the directory into// into which it goes  BFT_LOG            = BFT($01 or BFT_LOG_DIRECTORY);  BFT_LOG_DIR        = BFT($02 or BFT_DIRECTORY);  BFT_CHECKPOINT_DIR = BFT($03 or BFT_DIRECTORY);  BFT_NTDS_DATABASE  = BFT($04 or BFT_DATABASE_DIRECTORY);  BFT_PATCH_FILE     = BFT($05 or BFT_LOG_DIRECTORY);  BFT_UNKNOWN        = BFT($0F);// #include <ntdsbmsg.h>// Backup Context Handletype  HBC = Pointer;  {$EXTERNALSYM HBC}  PEDB_RSTMAPA = ^EDB_RSTMAPA;  {$EXTERNALSYM PEDB_RSTMAPA}  tagEDB_RSTMAPA = record    szDatabaseName: PChar;    szNewDtabaseName: PChar;  end;  {$EXTERNALSYM tagEDB_RSTMAPA}  EDB_RSTMAPA = tagEDB_RSTMAPA;  {$EXTERNALSYM EDB_RSTMAPA}  TEdbRstMapA = EDB_RSTMAPA;  PEdbRstMapA = PEDB_RSTMAPA;// required for NTDS unicode support.// UNDONE: NYI  PEDB_RSTMAPW = ^EDB_RSTMAPW;  {$EXTERNALSYM PEDB_RSTMAPW}  tagEDB_RSTMAPW = record    wszDatabaseName: PWCHAR;    wszNewDatabaseName: PWCHAR;  end;  {$EXTERNALSYM tagEDB_RSTMAPW}  EDB_RSTMAPW = tagEDB_RSTMAPW;  {$EXTERNALSYM EDB_RSTMAPW}  TEdbRstMapW = EDB_RSTMAPW;  PEdbRstMapW = PEDB_RSTMAPW;  {$IFDEF UNICODE}  EDB_RSTMAP = EDB_RSTMAPW;  {$EXTERNALSYM EDB_RSTMAP}  PEDB_RSTMAP = PEDB_RSTMAPW;  {$EXTERNALSYM PEDB_RSTMAP}  TEdbRstMap = TEdbRstMapW;  PEdbRstMap = PEdbRstMapW;  {$ELSE}  EDB_RSTMAP = EDB_RSTMAPA;  {$EXTERNALSYM EDB_RSTMAP}  PEDB_RSTMAP = PEDB_RSTMAPA;  {$EXTERNALSYM PEDB_RSTMAP}  TEdbRstMap = TEdbRstMapA;  PEdbRstMap = PEdbRstMapA;  {$ENDIF UNICODE}{*************************************************************************************Routine Description:      DsIsNTDSOnline        Checks to see if the NTDS is Online on the given server. This call is        guaranteed to return quickly.  Arguments:    [in] szServerName - UNC name of the server to check    [out] pfNTDSOnline - pointer to receive the bool result (TRUE if NTDS is                            online; FALSE, otherwise)Return Value:    ERROR_SUCCESS if the call executed successfully;    Failure code otherwise.**************************************************************************************}function DsIsNTDSOnlineA(szServerName: LPCSTR; var pfNTDSOnline: BOOL): HRESULT; stdcall;{$EXTERNALSYM DsIsNTDSOnlineA}function DsIsNTDSOnlineW(szServerName: LPCWSTR; var pfNTDSOnline: BOOL): HRESULT; stdcall;{$EXTERNALSYM DsIsNTDSOnlineW}function DsIsNTDSOnline(szServerName: LPCTSTR; var pfNTDSOnline: BOOL): HRESULT; stdcall;{$EXTERNALSYM DsIsNTDSOnline}{*************************************************************************************Routine Description:      DsBackupPrepare        Prepares the DS for the online backup and returns a Backup Context Handle        which should be used in the subsequent calls to other backup functions.  Arguments:    [in]    szBackupServer - UNC name of the server to be prepared for online backup    [in]    grbit - flag to be passed to jet while backing up dbs    [in]    btFlag - BACKUP_TYPE_FULL or BACKUP_TYPE_LOGS_ONLY    [out]   ppvExpiryToken - pointer that will receive the pointer to the                Expiry Token associated with this backup; Client should save                this token and send it back through DsRestorePrepare() when                attempting a restore; allocated memory should be freed using                DsBackupFree() API by the caller when it is no longer needed.    [out]   pcbExpiryTokenSize - pointer to receive the size of the expiry token                returned.    [out]   phbc - pointer that will receive the backup context handleReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupPrepareA(szBackupServer: LPCSTR; grbit: ULONG; btFlag: ULONG;  var ppvExpiryToken: PVOID; var pcbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupPrepareA}function DsBackupPrepareW(szBackupServer: LPCWSTR; grbit: ULONG; btFlag: ULONG;  var ppvExpiryToken: PVOID; var pcbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupPrepareW}function DsBackupPrepare(szBackupServer: LPCTSTR; grbit: ULONG; btFlag: ULONG;  var ppvExpiryToken: PVOID; var pcbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupPrepare}{*************************************************************************************Routine Description:      DsBackupGetDatabaseNames        Gives the list of data bases that need to be backed up for the given        backup context  Arguments:    [in]    hbc - backup context handle    [out]   pszAttachmentInfo - pointer that will receive the pointer to the attachment                info; allocated memory should be freed using DsBackupFree() API by the                caller when it is no longer needed; Attachment info is an array of                null-terminated filenames and and the list is terminated by two-nulls.    [out]   pcbSize - will receive the number of bytes returnedReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupGetDatabaseNamesA(hbc: HBC; var pszAttachmentInfo: LPSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetDatabaseNamesA}function DsBackupGetDatabaseNamesW(hbc: HBC; var pszAttachmentInfo: LPWSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetDatabaseNamesW}function DsBackupGetDatabaseNames(hbc: HBC; var pszAttachmentInfo: LPTSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetDatabaseNames}{*************************************************************************************Routine Description:      DsBackupOpenFile        Opens the given attachment for read.  Arguments:    [in]    hbc - backup context handle    [in]    szAttachmentName - name of the attachment to be opened for read    [in]    cbReadHintSize - suggested size in bytes that might be used during the                subsequent reads on this attachement    [out]   pliFileSize - pointer to a large integer that would receive the size in                bytes of the given attachmentReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupOpenFileA(hbc: HBC; szAttachmentName: LPCSTR; cbReadHintSize: DWORD;  var pliFileSize: LARGE_INTEGER): HRESULT; stdcall;{$EXTERNALSYM DsBackupOpenFileA}function DsBackupOpenFileW(hbc: HBC; szAttachmentName: LPCWSTR; cbReadHintSize: DWORD;  var pliFileSize: LARGE_INTEGER): HRESULT; stdcall;{$EXTERNALSYM DsBackupOpenFileW}function DsBackupOpenFile(hbc: HBC; szAttachmentName: LPCTSTR; cbReadHintSize: DWORD;  var pliFileSize: LARGE_INTEGER): HRESULT; stdcall;{$EXTERNALSYM DsBackupOpenFile}{*************************************************************************************Routine Description:      DsBackupRead        Reads the currently open attachment bytes into the given buffer. The client        application is expected to call this function repeatedly until it gets the        entire file (the application would have received the file size through the        DsBackupOpenFile() call before.  Arguments:    [in]    hbc - backup context handle    [in]    pvBuffer - pointer to the buffer that would receive the read data.    [in]    cbBuffer - specifies the size of the above buffer    [out]   pcbRead - pointer to receive the actual number of bytes read.Return Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupRead(hbc: HBC; pvBuffer: PVOID; cbBuffer: DWORD; var pcbRead: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupRead}{*************************************************************************************Routine Description:      DsBackupClose        To be called by the application after it completes reading all the data in        the currently opened attachement.  Arguments:    [in]    hbc - backup context handleReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupClose(hbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupClose}{*************************************************************************************Routine Description:      DsBackupGetBackupLogs        Gives the list of log files that need to be backed up for the given        backup context  Arguments:    [in]    hbc - backup context handle    [out]   pszBackupLogFiles - pointer that will receive the pointer to the list of                log files; allocated memory should be freed using DsBackupFree() API by the                caller when it is no longer needed; Log files are returned in an array of                null-terminated filenames and and the list is terminated by two-nulls.    [out]   pcbSize - will receive the number of bytes returnedReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupGetBackupLogsA(hbc: HBC; var pszBackupLogFiles: LPSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetBackupLogsA}function DsBackupGetBackupLogsW(hbc: HBC; var pszBackupLogFiles: LPWSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetBackupLogsW}function DsBackupGetBackupLogs(hbc: HBC; var pszBackupLogFiles: LPTSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsBackupGetBackupLogs}{*************************************************************************************Routine Description:      DsBackupTruncateLogs        Called to truncate the already read backup logs.  Arguments:    [in]    hbc - backup context handleReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupTruncateLogs(hbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupTruncateLogs}{*************************************************************************************Routine Description:      DsBackupEnd        Called to end the current backup session.  Arguments:    [in]    hbc - backup context handle of the backup sessionReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsBackupEnd(hbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsBackupEnd}{*************************************************************************************Routine Description:      DsBackupFree        Should be used by the application to free any buffer allocated by the        NTDSBCLI dll.  Arguments:    [in]    pvBuffer - pointer to the buffer that is to be freed.  Return Value:    None.**************************************************************************************}procedure DsBackupFree(pvBuffer: PVOID); stdcall;{$EXTERNALSYM DsBackupFree}{*************************************************************************************Routine Description:      DsRestoreGetDatabaseLocations        Called both at backup time as well at restoration time to get the data base        locations for different types of files.  Arguments:    [in]    hbc - backup context handle which would have been obtained through                    DsBackupPrepare() in the backup case and through DsRestorePrepare()                    in the restore case.    [out]   pszDatabaseLocationList - pointer that will receive the pointer to the list of                database locations; allocated memory should be freed using DsBackupFree() API by the                caller when it is no longer needed; locations are returned in an array of                null-terminated names and and the list is terminated by two-nulls.                The first character of each name is the BFT character that indicates the type                of the file and the rest of the name tells gives the path into which that                particular type of file should be restored.    [out]   pcbSize - will receive the number of bytes returnedReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsRestoreGetDatabaseLocationsA(hbc: HBC; var pszDatabaseLocationList: LPSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsRestoreGetDatabaseLocationsA}function DsRestoreGetDatabaseLocationsW(hbc: HBC; var pszDatabaseLocationList: LPWSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsRestoreGetDatabaseLocationsW}function DsRestoreGetDatabaseLocations(hbc: HBC; var pszDatabaseLocationList: LPTSTR;  var pcbSize: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsRestoreGetDatabaseLocations}{*************************************************************************************Routine Description:      DsRestorePrepare        Called to indicate beginning of a restore session.  Arguments:    [in]    szServerName - UNC name of the server into which the restore operation is                            going to be performed.    [in]    rtFlag -  Or'ed combination of RESTORE_TYPE_* flags; 0 if no special flags                            are to be specified    [in]    pvExpiryToken - pointer to the expiry token associated with this                            backup. The client would have received this when they backed up the DS.    [in]    cbExpiryTokenSize - size of the expiry token.    [out]   phbc - pointer to receive the backup context handle which is to be passed                            to the subsequent restore APIsReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsRestorePrepareA(szServerName: LPCSTR; rtFlag: ULONG; pvExpiryToken: PVOID;  cbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsRestorePrepareA}function DsRestorePrepareW(szServerName: LPCWSTR; rtFlag: ULONG; pvExpiryToken: PVOID;  cbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsRestorePrepareW}function DsRestorePrepare(szServerName: LPCTSTR; rtFlag: ULONG; pvExpiryToken: PVOID;  cbExpiryTokenSize: DWORD; var phbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsRestorePrepare}{*************************************************************************************Routine Description:      DsRestoreRegister        This will register a restore operation. It will interlock all sbsequent restore        operations, and will prevent the restore target from starting until the call        to DsRestoreRegisterComplete() is made.  Arguments:    [in]    hbc - backup context handle for the restore session.    [in]    szCheckPointFilePath - path where the check point files are restored    [in]    szLogPath - path where the log files are restored    [in]    rgrstmap - restore map    [in]    crstmap - tells if ther is a new restore map    [in]    szBackupLogPath - path where the backup logs are located    [in]    genLow - Lowest log# that was restored in this restore session    [in]    genHigh - Highest log# that was restored in this restore session  Return Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsRestoreRegisterA(hbc: HBC; szCheckPointFilePath, szLogPath: LPCSTR;  rgrstmap: PEDB_RSTMAPA; crstmap: LONG; szBackupLogPath: LPCSTR; genLow, genHigh: ULONG): HRESULT; stdcall;{$EXTERNALSYM DsRestoreRegisterA}function DsRestoreRegisterW(hbc: HBC; szCheckPointFilePath, szLogPath: LPCWSTR;  rgrstmap: PEDB_RSTMAPW; crstmap: LONG; szBackupLogPath: LPCWSTR; genLow, genHigh: ULONG): HRESULT; stdcall;{$EXTERNALSYM DsRestoreRegisterW}function DsRestoreRegister(hbc: HBC; szCheckPointFilePath, szLogPath: LPCTSTR;  rgrstmap: PEDB_RSTMAP; crstmap: LONG; szBackupLogPath: LPCTSTR; genLow, genHigh: ULONG): HRESULT; stdcall;{$EXTERNALSYM DsRestoreRegister}{*************************************************************************************Routine Description:      DsRestoreRegisterComplete        Called to indicate that a previously registered restore is complete.  Arguments:    [in]    hbc - backup context handle    [in]    hrRestoreState - success code if the restore was successfulReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsRestoreRegisterComplete(hbc: HBC; hrRestoreState: HRESULT): HRESULT; stdcall;{$EXTERNALSYM DsRestoreRegisterComplete}{*************************************************************************************Routine Description:      DsRestoreEnd        Called to end a restore session  Arguments:    [in]    hbc - backup context handleReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsRestoreEnd(hbc: HBC): HRESULT; stdcall;{$EXTERNALSYM DsRestoreEnd}{*************************************************************************************Routine Description:      DsSetCurrentBackupLog        Called to set the current backup log number after a successful restore  Arguments:    [in]    szServerName - UNC name of the server for which the current backup log has                                to be set    [in]    dwCurrentLog -  current log numberReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsSetCurrentBackupLogA(szServerName: LPCSTR; dwCurrentLog: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsSetCurrentBackupLogA}function DsSetCurrentBackupLogW(szServerName: LPCWSTR; dwCurrentLog: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsSetCurrentBackupLogW}function DsSetCurrentBackupLog(szServerName: LPCTSTR; dwCurrentLog: DWORD): HRESULT; stdcall;{$EXTERNALSYM DsSetCurrentBackupLog}{*************************************************************************************Routine Description:      DsSetAuthIdentity        Used to set the security context under which the client APIs are to be        called. If this function is not called, security context of the current        process is assumed.  Arguments:    [in]    szUserName - name of the user    [in]    szDomainName -  name of the domain the user belongs to    [in]    szPassword - password of the user in the specified domainReturn Value:    One of the standard HRESULT success codes;    Failure code otherwise.**************************************************************************************}function DsSetAuthIdentityA(szUserName, szDomainName, szPassword: LPCSTR): HRESULT; stdcall;{$EXTERNALSYM DsSetAuthIdentityA}function DsSetAuthIdentityW(szUserName, szDomainName, szPassword: LPCWSTR): HRESULT; stdcall;{$EXTERNALSYM DsSetAuthIdentityW}function DsSetAuthIdentity(szUserName, szDomainName, szPassword: LPCTSTR): HRESULT; stdcall;{$EXTERNALSYM DsSetAuthIdentity}implementationuses  JwaWinDLLNames;{$IFDEF DYNAMIC_LINK}var  _DsIsNTDSOnlineA: Pointer;function DsIsNTDSOnlineA;begin  GetProcedureAddress(_DsIsNTDSOnlineA, ntdsbclilib, 'DsIsNTDSOnlineA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsIsNTDSOnlineA]  end;end;var  _DsIsNTDSOnlineW: Pointer;function DsIsNTDSOnlineW;begin  GetProcedureAddress(_DsIsNTDSOnlineW, ntdsbclilib, 'DsIsNTDSOnlineW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsIsNTDSOnlineW]  end;end;var  _DsIsNTDSOnline: Pointer;function DsIsNTDSOnline;begin  GetProcedureAddress(_DsIsNTDSOnline, ntdsbclilib, 'DsIsNTDSOnline' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsIsNTDSOnline]  end;end;var  _DsBackupPrepareA: Pointer;function DsBackupPrepareA;begin  GetProcedureAddress(_DsBackupPrepareA, ntdsbclilib, 'DsBackupPrepareA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupPrepareA]  end;end;var  _DsBackupPrepareW: Pointer;function DsBackupPrepareW;begin  GetProcedureAddress(_DsBackupPrepareW, ntdsbclilib, 'DsBackupPrepareW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupPrepareW]  end;end;var  _DsBackupPrepare: Pointer;function DsBackupPrepare;begin  GetProcedureAddress(_DsBackupPrepare, ntdsbclilib, 'DsBackupPrepare' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupPrepare]  end;end;var  _DsBackupGetDatabaseNamesA: Pointer;function DsBackupGetDatabaseNamesA;begin  GetProcedureAddress(_DsBackupGetDatabaseNamesA, ntdsbclilib, 'DsBackupGetDatabaseNamesA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetDatabaseNamesA]  end;end;var  _DsBackupGetDatabaseNamesW: Pointer;function DsBackupGetDatabaseNamesW;begin  GetProcedureAddress(_DsBackupGetDatabaseNamesW, ntdsbclilib, 'DsBackupGetDatabaseNamesW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetDatabaseNamesW]  end;end;var  _DsBackupGetDatabaseNames: Pointer;function DsBackupGetDatabaseNames;begin  GetProcedureAddress(_DsBackupGetDatabaseNames, ntdsbclilib, 'DsBackupGetDatabaseNames' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetDatabaseNames]  end;end;var  _DsBackupOpenFileA: Pointer;function DsBackupOpenFileA;begin  GetProcedureAddress(_DsBackupOpenFileA, ntdsbclilib, 'DsBackupOpenFileA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupOpenFileA]  end;end;var  _DsBackupOpenFileW: Pointer;function DsBackupOpenFileW;begin  GetProcedureAddress(_DsBackupOpenFileW, ntdsbclilib, 'DsBackupOpenFileW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupOpenFileW]  end;end;var  _DsBackupOpenFile: Pointer;function DsBackupOpenFile;begin  GetProcedureAddress(_DsBackupOpenFile, ntdsbclilib, 'DsBackupOpenFile' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupOpenFile]  end;end;var  _DsBackupRead: Pointer;function DsBackupRead;begin  GetProcedureAddress(_DsBackupRead, ntdsbclilib, 'DsBackupRead');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupRead]  end;end;var  _DsBackupClose: Pointer;function DsBackupClose;begin  GetProcedureAddress(_DsBackupClose, ntdsbclilib, 'DsBackupClose');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupClose]  end;end;var  _DsBackupGetBackupLogsA: Pointer;function DsBackupGetBackupLogsA;begin  GetProcedureAddress(_DsBackupGetBackupLogsA, ntdsbclilib, 'DsBackupGetBackupLogsA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetBackupLogsA]  end;end;var  _DsBackupGetBackupLogsW: Pointer;function DsBackupGetBackupLogsW;begin  GetProcedureAddress(_DsBackupGetBackupLogsW, ntdsbclilib, 'DsBackupGetBackupLogsW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetBackupLogsW]  end;end;var  _DsBackupGetBackupLogs: Pointer;function DsBackupGetBackupLogs;begin  GetProcedureAddress(_DsBackupGetBackupLogs, ntdsbclilib, 'DsBackupGetBackupLogs' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupGetBackupLogs]  end;end;var  _DsBackupTruncateLogs: Pointer;function DsBackupTruncateLogs;begin  GetProcedureAddress(_DsBackupTruncateLogs, ntdsbclilib, 'DsBackupTruncateLogs');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupTruncateLogs]  end;end;var  _DsBackupEnd: Pointer;function DsBackupEnd;begin  GetProcedureAddress(_DsBackupEnd, ntdsbclilib, 'DsBackupEnd');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupEnd]  end;end;var  _DsBackupFree: Pointer;procedure DsBackupFree;begin  GetProcedureAddress(_DsBackupFree, ntdsbclilib, 'DsBackupFree');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsBackupFree]  end;end;var  _DsRestoreGetDatabaseLocationsA: Pointer;function DsRestoreGetDatabaseLocationsA;begin  GetProcedureAddress(_DsRestoreGetDatabaseLocationsA, ntdsbclilib, 'DsRestoreGetDatabaseLocationsA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreGetDatabaseLocationsA]  end;end;var  _DsRestoreGetDatabaseLocationsW: Pointer;function DsRestoreGetDatabaseLocationsW;begin  GetProcedureAddress(_DsRestoreGetDatabaseLocationsW, ntdsbclilib, 'DsRestoreGetDatabaseLocationsW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreGetDatabaseLocationsW]  end;end;var  _DsRestoreGetDatabaseLocations: Pointer;function DsRestoreGetDatabaseLocations;begin  GetProcedureAddress(_DsRestoreGetDatabaseLocations, ntdsbclilib, 'DsRestoreGetDatabaseLocations' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreGetDatabaseLocations]  end;end;var  _DsRestorePrepareA: Pointer;function DsRestorePrepareA;begin  GetProcedureAddress(_DsRestorePrepareA, ntdsbclilib, 'DsRestorePrepareA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestorePrepareA]  end;end;var  _DsRestorePrepareW: Pointer;function DsRestorePrepareW;begin  GetProcedureAddress(_DsRestorePrepareW, ntdsbclilib, 'DsRestorePrepareW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestorePrepareW]  end;end;var  _DsRestorePrepare: Pointer;function DsRestorePrepare;begin  GetProcedureAddress(_DsRestorePrepare, ntdsbclilib, 'DsRestorePrepare' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestorePrepare]  end;end;var  _DsRestoreRegisterA: Pointer;function DsRestoreRegisterA;begin  GetProcedureAddress(_DsRestoreRegisterA, ntdsbclilib, 'DsRestoreRegisterA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreRegisterA]  end;end;var  _DsRestoreRegisterW: Pointer;function DsRestoreRegisterW;begin  GetProcedureAddress(_DsRestoreRegisterW, ntdsbclilib, 'DsRestoreRegisterW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreRegisterW]  end;end;var  _DsRestoreRegister: Pointer;function DsRestoreRegister;begin  GetProcedureAddress(_DsRestoreRegister, ntdsbclilib, 'DsRestoreRegister' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreRegister]  end;end;var  _DsRestoreRegisterComplete: Pointer;function DsRestoreRegisterComplete;begin  GetProcedureAddress(_DsRestoreRegisterComplete, ntdsbclilib, 'DsRestoreRegisterComplete');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreRegisterComplete]  end;end;var  _DsRestoreEnd: Pointer;function DsRestoreEnd;begin  GetProcedureAddress(_DsRestoreEnd, ntdsbclilib, 'DsRestoreEnd');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsRestoreEnd]  end;end;var  _DsSetCurrentBackupLogA: Pointer;function DsSetCurrentBackupLogA;begin  GetProcedureAddress(_DsSetCurrentBackupLogA, ntdsbclilib, 'DsSetCurrentBackupLogA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetCurrentBackupLogA]  end;end;var  _DsSetCurrentBackupLogW: Pointer;function DsSetCurrentBackupLogW;begin  GetProcedureAddress(_DsSetCurrentBackupLogW, ntdsbclilib, 'DsSetCurrentBackupLogW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetCurrentBackupLogW]  end;end;var  _DsSetCurrentBackupLog: Pointer;function DsSetCurrentBackupLog;begin  GetProcedureAddress(_DsSetCurrentBackupLog, ntdsbclilib, 'DsSetCurrentBackupLog' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetCurrentBackupLog]  end;end;var  _DsSetAuthIdentityA: Pointer;function DsSetAuthIdentityA;begin  GetProcedureAddress(_DsSetAuthIdentityA, ntdsbclilib, 'DsSetAuthIdentityA');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetAuthIdentityA]  end;end;var  _DsSetAuthIdentityW: Pointer;function DsSetAuthIdentityW;begin  GetProcedureAddress(_DsSetAuthIdentityW, ntdsbclilib, 'DsSetAuthIdentityW');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetAuthIdentityW]  end;end;var  _DsSetAuthIdentity: Pointer;function DsSetAuthIdentity;begin  GetProcedureAddress(_DsSetAuthIdentity, ntdsbclilib, 'DsSetAuthIdentity' + AWSuffix);  asm        MOV     ESP, EBP        POP     EBP        JMP     [_DsSetAuthIdentity]  end;end;{$ELSE}function DsIsNTDSOnlineA; external ntdsbclilib name 'DsIsNTDSOnlineA';function DsIsNTDSOnlineW; external ntdsbclilib name 'DsIsNTDSOnlineW';function DsIsNTDSOnline; external ntdsbclilib name 'DsIsNTDSOnline' + AWSuffix;function DsBackupPrepareA; external ntdsbclilib name 'DsBackupPrepareA';function DsBackupPrepareW; external ntdsbclilib name 'DsBackupPrepareW';function DsBackupPrepare; external ntdsbclilib name 'DsBackupPrepare' + AWSuffix;function DsBackupGetDatabaseNamesA; external ntdsbclilib name 'DsBackupGetDatabaseNamesA';function DsBackupGetDatabaseNamesW; external ntdsbclilib name 'DsBackupGetDatabaseNamesW';function DsBackupGetDatabaseNames; external ntdsbclilib name 'DsBackupGetDatabaseNames' + AWSuffix;function DsBackupOpenFileA; external ntdsbclilib name 'DsBackupOpenFileA';function DsBackupOpenFileW; external ntdsbclilib name 'DsBackupOpenFileW';function DsBackupOpenFile; external ntdsbclilib name 'DsBackupOpenFile' + AWSuffix;function DsBackupRead; external ntdsbclilib name 'DsBackupRead';function DsBackupClose; external ntdsbclilib name 'DsBackupClose';function DsBackupGetBackupLogsA; external ntdsbclilib name 'DsBackupGetBackupLogsA';function DsBackupGetBackupLogsW; external ntdsbclilib name 'DsBackupGetBackupLogsW';function DsBackupGetBackupLogs; external ntdsbclilib name 'DsBackupGetBackupLogs' + AWSuffix;function DsBackupTruncateLogs; external ntdsbclilib name 'DsBackupTruncateLogs';function DsBackupEnd; external ntdsbclilib name 'DsBackupEnd';procedure DsBackupFree; external ntdsbclilib name 'DsBackupFree';function DsRestoreGetDatabaseLocationsA; external ntdsbclilib name 'DsRestoreGetDatabaseLocationsA';function DsRestoreGetDatabaseLocationsW; external ntdsbclilib name 'DsRestoreGetDatabaseLocationsW';function DsRestoreGetDatabaseLocations; external ntdsbclilib name 'DsRestoreGetDatabaseLocations' + AWSuffix;function DsRestorePrepareA; external ntdsbclilib name 'DsRestorePrepareA';function DsRestorePrepareW; external ntdsbclilib name 'DsRestorePrepareW';function DsRestorePrepare; external ntdsbclilib name 'DsRestorePrepare' + AWSuffix;function DsRestoreRegisterA; external ntdsbclilib name 'DsRestoreRegisterA';function DsRestoreRegisterW; external ntdsbclilib name 'DsRestoreRegisterW';function DsRestoreRegister; external ntdsbclilib name 'DsRestoreRegister' + AWSuffix;function DsRestoreRegisterComplete; external ntdsbclilib name 'DsRestoreRegisterComplete';function DsRestoreEnd; external ntdsbclilib name 'DsRestoreEnd';function DsSetCurrentBackupLogA; external ntdsbclilib name 'DsSetCurrentBackupLogA';function DsSetCurrentBackupLogW; external ntdsbclilib name 'DsSetCurrentBackupLogW';function DsSetCurrentBackupLog; external ntdsbclilib name 'DsSetCurrentBackupLog' + AWSuffix;function DsSetAuthIdentityA; external ntdsbclilib name 'DsSetAuthIdentityA';function DsSetAuthIdentityW; external ntdsbclilib name 'DsSetAuthIdentityW';function DsSetAuthIdentity; external ntdsbclilib name 'DsSetAuthIdentity' + AWSuffix;{$ENDIF DYNAMIC_LINK}end.
 |