| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734 | {******************************************************************************}{                                                                              }{ Lan Manager DFS API interface Unit for Object Pascal                         }{                                                                              }{ Portions created by Microsoft are Copyright (C) 1995-2001 Microsoft          }{ Corporation. All Rights Reserved.                                            }{                                                                              }{ The original file is: lmdfs.h, released November 2001. The original Pascal   }{ code is: LmDfs.pas, released Februari 2002. 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: JwaLmDFS.pas,v 1.8 2005/09/06 16:36:50 marquardt Exp $unit JwaLmDFS;{$WEAKPACKAGEUNIT}{$HPPEMIT ''}{$HPPEMIT '#include "lmdfs.h"'}{$HPPEMIT ''}{$I jediapilib.inc}interfaceuses  JwaWindows, JwaLmCons;//// DFS Volume state//const  DFS_VOLUME_STATES             = $F;  {$EXTERNALSYM DFS_VOLUME_STATES}  DFS_VOLUME_STATE_OK           = 1;  {$EXTERNALSYM DFS_VOLUME_STATE_OK}  DFS_VOLUME_STATE_INCONSISTENT = 2;  {$EXTERNALSYM DFS_VOLUME_STATE_INCONSISTENT}  DFS_VOLUME_STATE_OFFLINE      = 3;  {$EXTERNALSYM DFS_VOLUME_STATE_OFFLINE}  DFS_VOLUME_STATE_ONLINE       = 4;  {$EXTERNALSYM DFS_VOLUME_STATE_ONLINE}//// These are valid for setting the volume state on the root// These are available to force a resynchronize on the root// volume or to put it in a standby mode.//  DFS_VOLUME_STATE_RESYNCHRONIZE = $10;  {$EXTERNALSYM DFS_VOLUME_STATE_RESYNCHRONIZE}  DFS_VOLUME_STATE_STANDBY       = $20;  {$EXTERNALSYM DFS_VOLUME_STATE_STANDBY}//// These are valid on getting the volume state on the root// These are available to determine the flavor of DFS// A few bits are reserved to determine the flavor of the DFS root.// To get the flavor, and the state with DFS_VOLUME_FLAVORS.//// (_state & DFS_VOLUME_FLAVORS) will tell you the flavor of the dfs root.////  DFS_VOLUME_FLAVORS = $0300;  {$EXTERNALSYM DFS_VOLUME_FLAVORS}  DFS_VOLUME_FLAVOR_UNUSED1    = $0000;  {$EXTERNALSYM DFS_VOLUME_FLAVOR_UNUSED1}  DFS_VOLUME_FLAVOR_STANDALONE = $0100;  {$EXTERNALSYM DFS_VOLUME_FLAVOR_STANDALONE}  DFS_VOLUME_FLAVOR_AD_BLOB    = $0200;  {$EXTERNALSYM DFS_VOLUME_FLAVOR_AD_BLOB}  DFS_STORAGE_FLAVOR_UNUSED2   = $0300;  {$EXTERNALSYM DFS_STORAGE_FLAVOR_UNUSED2}//// DFS Storage State//  DFS_STORAGE_STATES        = $F;  {$EXTERNALSYM DFS_STORAGE_STATES}  DFS_STORAGE_STATE_OFFLINE = 1;  {$EXTERNALSYM DFS_STORAGE_STATE_OFFLINE}  DFS_STORAGE_STATE_ONLINE  = 2;  {$EXTERNALSYM DFS_STORAGE_STATE_ONLINE}  DFS_STORAGE_STATE_ACTIVE  = 4;  {$EXTERNALSYM DFS_STORAGE_STATE_ACTIVE}//// Level 1://type  LPDFS_INFO_1 = ^DFS_INFO_1;  {$EXTERNALSYM LPDFS_INFO_1}  PDFS_INFO_1 = ^DFS_INFO_1;  {$EXTERNALSYM PDFS_INFO_1}  _DFS_INFO_1 = record    EntryPath: LPWSTR; // Dfs name for the top of this piece of storage  end;  {$EXTERNALSYM _DFS_INFO_1}  DFS_INFO_1 = _DFS_INFO_1;  {$EXTERNALSYM DFS_INFO_1}  TDfsInfo1 = DFS_INFO_1;  PDfsInfo1 = PDFS_INFO_1;//// Level 2://  LPDFS_INFO_2 = ^DFS_INFO_2;  {$EXTERNALSYM LPDFS_INFO_2}  PDFS_INFO_2 = ^DFS_INFO_2;  {$EXTERNALSYM PDFS_INFO_2}  _DFS_INFO_2 = record    EntryPath: LPWSTR; // Dfs name for the top of this volume    Comment: LPWSTR; // Comment for this volume    State: DWORD; // State of this volume, one of DFS_VOLUME_STATE_*    NumberOfStorages: DWORD; // Number of storages for this volume  end;  {$EXTERNALSYM _DFS_INFO_2}  DFS_INFO_2 = _DFS_INFO_2;  {$EXTERNALSYM DFS_INFO_2}  TDfsInfo2 = DFS_INFO_2;  PDfsInfo2 = PDFS_INFO_2;  LPDFS_STORAGE_INFO = ^DFS_STORAGE_INFO;  {$EXTERNALSYM LPDFS_STORAGE_INFO}  PDFS_STORAGE_INFO = ^DFS_STORAGE_INFO;  {$EXTERNALSYM PDFS_STORAGE_INFO}  _DFS_STORAGE_INFO = record    State: ULONG; // State of this storage, one of DFS_STORAGE_STATE_*    // possibly OR'd with DFS_STORAGE_STATE_ACTIVE    ServerName: LPWSTR; // Name of server hosting this storage    ShareName: LPWSTR; // Name of share hosting this storage  end;  {$EXTERNALSYM _DFS_STORAGE_INFO}  DFS_STORAGE_INFO = _DFS_STORAGE_INFO;  {$EXTERNALSYM DFS_STORAGE_INFO}  TDfsStorageInfo = DFS_STORAGE_INFO;  PDfsStorageInfo = PDFS_STORAGE_INFO;//// Level 3://  LPDFS_INFO_3 = ^DFS_INFO_3;  {$EXTERNALSYM LPDFS_INFO_3}  PDFS_INFO_3 = ^DFS_INFO_3;  {$EXTERNALSYM PDFS_INFO_3}  _DFS_INFO_3 = record    EntryPath: LPWSTR; // Dfs name for the top of this volume    Comment: LPWSTR; // Comment for this volume    State: DWORD; // State of this volume, one of DFS_VOLUME_STATE_*    NumberOfStorages: DWORD; // Number of storage servers for this volume    Storage: LPDFS_STORAGE_INFO; // An array (of NumberOfStorages elements) of storage-specific information.  end;  {$EXTERNALSYM _DFS_INFO_3}  DFS_INFO_3 = _DFS_INFO_3;  {$EXTERNALSYM DFS_INFO_3}  TDfsInfo3 = DFS_INFO_3;  PDfsInfo3 = PDFS_INFO_3;//// Level 4://  LPDFS_INFO_4 = ^DFS_INFO_4;  {$EXTERNALSYM LPDFS_INFO_4}  PDFS_INFO_4 = ^DFS_INFO_4;  {$EXTERNALSYM PDFS_INFO_4}  _DFS_INFO_4 = record    EntryPath: LPWSTR; // Dfs name for the top of this volume    Comment: LPWSTR; // Comment for this volume    State: DWORD; // State of this volume, one of DFS_VOLUME_STATE_*    Timeout: ULONG; // Timeout, in seconds, of this junction point    Guid: GUID; // Guid of this junction point    NumberOfStorages: DWORD; // Number of storage servers for this volume    Storage: LPDFS_STORAGE_INFO; // An array (of NumberOfStorages elements) of storage-specific information.  end;  {$EXTERNALSYM _DFS_INFO_4}  DFS_INFO_4 = _DFS_INFO_4;  {$EXTERNALSYM DFS_INFO_4}  TDfsInfo4 = DFS_INFO_4;  PDfsInfo4 = PDFS_INFO_4;//// Level 100://  LPDFS_INFO_100 = ^DFS_INFO_100;  {$EXTERNALSYM LPDFS_INFO_100}  PDFS_INFO_100 = ^DFS_INFO_100;  {$EXTERNALSYM PDFS_INFO_100}  _DFS_INFO_100 = record    Comment: LPWSTR; // Comment for this volume or storage  end;  {$EXTERNALSYM _DFS_INFO_100}  DFS_INFO_100 = _DFS_INFO_100;  {$EXTERNALSYM DFS_INFO_100}  TDfsInfo100 = DFS_INFO_100;  PDfsInfo100 = PDFS_INFO_100;//// Level 101://  LPDFS_INFO_101 = ^DFS_INFO_101;  {$EXTERNALSYM LPDFS_INFO_101}  PDFS_INFO_101 = ^DFS_INFO_101;  {$EXTERNALSYM PDFS_INFO_101}  _DFS_INFO_101 = record    State: DWORD; // State of this storage, one of DFS_STORAGE_STATE_*    // possibly OR'd with DFS_STORAGE_STATE_ACTIVE  end;  {$EXTERNALSYM _DFS_INFO_101}  DFS_INFO_101 = _DFS_INFO_101;  {$EXTERNALSYM DFS_INFO_101}  TDfsInfo101 = DFS_INFO_101;  PDfsInfo101 = PDFS_INFO_101;//// Level 102://  LPDFS_INFO_102 = ^DFS_INFO_102;  {$EXTERNALSYM LPDFS_INFO_102}  PDFS_INFO_102 = ^DFS_INFO_102;  {$EXTERNALSYM PDFS_INFO_102}  _DFS_INFO_102 = record    Timeout: ULONG; // Timeout, in seconds, of the junction  end;  {$EXTERNALSYM _DFS_INFO_102}  DFS_INFO_102 = _DFS_INFO_102;  {$EXTERNALSYM DFS_INFO_102}  TDfsInfo102 = DFS_INFO_102;  PDfsInfo102 = PDFS_INFO_102;//// Level 200://  LPDFS_INFO_200 = ^DFS_INFO_200;  {$EXTERNALSYM LPDFS_INFO_200}  PDFS_INFO_200 = ^DFS_INFO_200;  {$EXTERNALSYM PDFS_INFO_200}  _DFS_INFO_200 = record    FtDfsName: LPWSTR; // FtDfs name  end;  {$EXTERNALSYM _DFS_INFO_200}  DFS_INFO_200 = _DFS_INFO_200;  {$EXTERNALSYM DFS_INFO_200}  TDfsInfo200 = DFS_INFO_200;  PDfsInfo200 = PDFS_INFO_200;//// Level 300://  LPDFS_INFO_300 = ^DFS_INFO_300;  {$EXTERNALSYM LPDFS_INFO_300}  PDFS_INFO_300 = ^DFS_INFO_300;  {$EXTERNALSYM PDFS_INFO_300}  _DFS_INFO_300 = record    Flags: DWORD;    DfsName: LPWSTR; // Dfs name  end;  {$EXTERNALSYM _DFS_INFO_300}  DFS_INFO_300 = _DFS_INFO_300;  {$EXTERNALSYM DFS_INFO_300}  TDfsInfo300 = DFS_INFO_300;  PDfsInfo300 = PDFS_INFO_300;//// Add a new volume or additional storage for an existing volume at// DfsEntryPath.//function NetDfsAdd(DfsEntryPath, ServerName, ShareName, Comment: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsAdd}//// Flags://const  DFS_ADD_VOLUME     = 1; // Add a new volume to the DFS if not already there  {$EXTERNALSYM DFS_ADD_VOLUME}  DFS_RESTORE_VOLUME = 2; // Volume/Replica is being restored - do not verify share etc.  {$EXTERNALSYM DFS_RESTORE_VOLUME}//// Setup/teardown API's for standard and FtDfs roots.//function NetDfsAddStdRoot(ServerName, RootShare, Comment: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsAddStdRoot}function NetDfsRemoveStdRoot(ServerName, RootShare: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsRemoveStdRoot}function NetDfsAddFtRoot(ServerName, RootShare, FtDfsName, Comment: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsAddFtRoot}function NetDfsRemoveFtRoot(ServerName, RootShare, FtDfsName: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsRemoveFtRoot}function NetDfsRemoveFtRootForced(DomainName, ServerName, RootShare, FtDfsName: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsRemoveFtRootForced}//// Call to reinitialize the dfsmanager on a machine//function NetDfsManagerInitialize(ServerName: LPWSTR; Flags: DWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsManagerInitialize}function NetDfsAddStdRootForced(ServerName, RootShare, Comment, Store: LPWSTR): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsAddStdRootForced}function NetDfsGetDcAddress(ServerName: LPWSTR; var DcIpAddress: LPWSTR; var IsRoot: BOOLEAN; Timeout: PULONG): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsGetDcAddress}//// Flags for NetDfsSetDcAddress()//const  NET_DFS_SETDC_FLAGS   = $00000000;  {$EXTERNALSYM NET_DFS_SETDC_FLAGS}  NET_DFS_SETDC_TIMEOUT = $00000001;  {$EXTERNALSYM NET_DFS_SETDC_TIMEOUT}  NET_DFS_SETDC_INITPKT = $00000002;  {$EXTERNALSYM NET_DFS_SETDC_INITPKT}//// Structures used for site reporting//type  LPDFS_SITENAME_INFO = ^DFS_SITENAME_INFO;  {$EXTERNALSYM LPDFS_SITENAME_INFO}  PDFS_SITENAME_INFO = ^DFS_SITENAME_INFO;  {$EXTERNALSYM PDFS_SITENAME_INFO}  DFS_SITENAME_INFO = record    SiteFlags: ULONG; // Below    SiteName: LPWSTR;  end;  {$EXTERNALSYM DFS_SITENAME_INFO}  TDfsSiteNameInfo = DFS_SITENAME_INFO;  PDfsSiteNameInfo = PDFS_SITENAME_INFO;// SiteFlagsconst  DFS_SITE_PRIMARY = $1; // This site returned by DsGetSiteName()  {$EXTERNALSYM DFS_SITE_PRIMARY}type  LPDFS_SITELIST_INFO = ^DFS_SITELIST_INFO;  {$EXTERNALSYM LPDFS_SITELIST_INFO}  PDFS_SITELIST_INFO = ^DFS_SITELIST_INFO;  {$EXTERNALSYM PDFS_SITELIST_INFO}  DFS_SITELIST_INFO = record    cSites: ULONG;    Site: array [0..0] of DFS_SITENAME_INFO;  end;  {$EXTERNALSYM DFS_SITELIST_INFO}  TDfsSiteListInfo = DFS_SITELIST_INFO;  PDfsSiteListInfo = PDFS_SITELIST_INFO;//// Remove a volume or additional storage for volume from the Dfs at// DfsEntryPath. When applied to the last storage in a volume, removes// the volume from the DFS.//function NetDfsRemove(DfsEntryPath, ServerName, ShareName: LPWSTR): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsRemove}//// Get information about all of the volumes in the Dfs. DfsName is// the "server" part of the UNC name used to refer to this particular Dfs.//// Valid levels are 1-4, 200//function NetDfsEnum(DfsName: LPWSTR; Level, PrefMaxLen: DWORD; var Buffer: LPBYTE; EntriesRead, ResumeHandle: LPDWORD): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsEnum}//// Get information about the volume or storage.// If ServerName and ShareName are specified, the information returned// is specific to that server and share, else the information is specific// to the volume as a whole.//// Valid levels are 1-4, 100//function NetDfsGetInfo(DfsEntryPath, ServerName, ShareName: LPWSTR; Level: DWORD; var Buffer: LPBYTE): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsGetInfo}//// Set info about the volume or storage.// If ServerName and ShareName are specified, the information set is// specific to that server and share, else the information is specific// to the volume as a whole.//// Valid levels are 100, 101 and 102//function NetDfsSetInfo(DfsEntryPath, ServerName, ShareName: LPWSTR; Level: DWORD; Buffer: LPBYTE): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsSetInfo}//// Get client's cached information about the volume or storage.// If ServerName and ShareName are specified, the information returned// is specific to that server and share, else the information is specific// to the volume as a whole.//// Valid levels are 1-4//function NetDfsGetClientInfo(DfsEntryPath, ServerName, ShareName: LPWSTR; Level: DWORD; var Buffer: LPBYTE): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsGetClientInfo}//// Set client's cached info about the volume or storage.// If ServerName and ShareName are specified, the information set is// specific to that server and share, else the information is specific// to the volume as a whole.//// Valid levels are 101 and 102.//function NetDfsSetClientInfo(DfsEntryPath, ServerName, ShareName: LPWSTR; Level: DWORD; Buffer: LPBYTE): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsSetClientInfo}//// Move a DFS volume and all subordinate volumes from one place in the// DFS to another place in the DFS.//function NetDfsMove(DfsEntryPath: LPWSTR; DfsNewEntryPath: LPWSTR): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsMove}function NetDfsRename(Path: LPWSTR; NewPath: LPWSTR): NET_API_STATUS; stdcall;{$EXTERNALSYM NetDfsRename}implementationuses  JwaWinDLLNames;{$IFDEF DYNAMIC_LINK}var  _NetDfsAdd: Pointer;function NetDfsAdd;begin  GetProcedureAddress(_NetDfsAdd, netapi32, 'NetDfsAdd');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsAdd]  end;end;var  _NetDfsAddStdRoot: Pointer;function NetDfsAddStdRoot;begin  GetProcedureAddress(_NetDfsAddStdRoot, netapi32, 'NetDfsAddStdRoot');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsAddStdRoot]  end;end;var  _NetDfsRemoveStdRoot: Pointer;function NetDfsRemoveStdRoot;begin  GetProcedureAddress(_NetDfsRemoveStdRoot, netapi32, 'NetDfsRemoveStdRoot');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsRemoveStdRoot]  end;end;var  _NetDfsAddFtRoot: Pointer;function NetDfsAddFtRoot;begin  GetProcedureAddress(_NetDfsAddFtRoot, netapi32, 'NetDfsAddFtRoot');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsAddFtRoot]  end;end;var  _NetDfsRemoveFtRoot: Pointer;function NetDfsRemoveFtRoot;begin  GetProcedureAddress(_NetDfsRemoveFtRoot, netapi32, 'NetDfsRemoveFtRoot');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsRemoveFtRoot]  end;end;var  _NetDfsRemoveFtRootForced: Pointer;function NetDfsRemoveFtRootForced;begin  GetProcedureAddress(_NetDfsRemoveFtRootForced, netapi32, 'NetDfsRemoveFtRootForced');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsRemoveFtRootForced]  end;end;var  _NetDfsManagerInitialize: Pointer;function NetDfsManagerInitialize;begin  GetProcedureAddress(_NetDfsManagerInitialize, netapi32, 'NetDfsManagerInitialize');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsManagerInitialize]  end;end;var  _NetDfsAddStdRootForced: Pointer;function NetDfsAddStdRootForced;begin  GetProcedureAddress(_NetDfsAddStdRootForced, netapi32, 'NetDfsAddStdRootForced');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsAddStdRootForced]  end;end;var  _NetDfsGetDcAddress: Pointer;function NetDfsGetDcAddress;begin  GetProcedureAddress(_NetDfsGetDcAddress, netapi32, 'NetDfsGetDcAddress');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsGetDcAddress]  end;end;var  _NetDfsRemove: Pointer;function NetDfsRemove;begin  GetProcedureAddress(_NetDfsRemove, netapi32, 'NetDfsRemove');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsRemove]  end;end;var  _NetDfsEnum: Pointer;function NetDfsEnum;begin  GetProcedureAddress(_NetDfsEnum, netapi32, 'NetDfsEnum');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsEnum]  end;end;var  _NetDfsGetInfo: Pointer;function NetDfsGetInfo;begin  GetProcedureAddress(_NetDfsGetInfo, netapi32, 'NetDfsGetInfo');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsGetInfo]  end;end;var  _NetDfsSetInfo: Pointer;function NetDfsSetInfo;begin  GetProcedureAddress(_NetDfsSetInfo, netapi32, 'NetDfsSetInfo');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsSetInfo]  end;end;var  _NetDfsGetClientInfo: Pointer;function NetDfsGetClientInfo;begin  GetProcedureAddress(_NetDfsGetClientInfo, netapi32, 'NetDfsGetClientInfo');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsGetClientInfo]  end;end;var  _NetDfsSetClientInfo: Pointer;function NetDfsSetClientInfo;begin  GetProcedureAddress(_NetDfsSetClientInfo, netapi32, 'NetDfsSetClientInfo');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsSetClientInfo]  end;end;var  _NetDfsMove: Pointer;function NetDfsMove;begin  GetProcedureAddress(_NetDfsMove, netapi32, 'NetDfsMove');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsMove]  end;end;var  _NetDfsRename: Pointer;function NetDfsRename;begin  GetProcedureAddress(_NetDfsRename, netapi32, 'NetDfsRename');  asm        MOV     ESP, EBP        POP     EBP        JMP     [_NetDfsRename]  end;end;{$ELSE}function NetDfsAdd; external netapi32 name 'NetDfsAdd';function NetDfsAddStdRoot; external netapi32 name 'NetDfsAddStdRoot';function NetDfsRemoveStdRoot; external netapi32 name 'NetDfsRemoveStdRoot';function NetDfsAddFtRoot; external netapi32 name 'NetDfsAddFtRoot';function NetDfsRemoveFtRoot; external netapi32 name 'NetDfsRemoveFtRoot';function NetDfsRemoveFtRootForced; external netapi32 name 'NetDfsRemoveFtRootForced';function NetDfsManagerInitialize; external netapi32 name 'NetDfsManagerInitialize';function NetDfsAddStdRootForced; external netapi32 name 'NetDfsAddStdRootForced';function NetDfsGetDcAddress; external netapi32 name 'NetDfsGetDcAddress';function NetDfsRemove; external netapi32 name 'NetDfsRemove';function NetDfsEnum; external netapi32 name 'NetDfsEnum';function NetDfsGetInfo; external netapi32 name 'NetDfsGetInfo';function NetDfsSetInfo; external netapi32 name 'NetDfsSetInfo';function NetDfsGetClientInfo; external netapi32 name 'NetDfsGetClientInfo';function NetDfsSetClientInfo; external netapi32 name 'NetDfsSetClientInfo';function NetDfsMove; external netapi32 name 'NetDfsMove';function NetDfsRename; external netapi32 name 'NetDfsRename';{$ENDIF DYNAMIC_LINK}end.
 |