/*++ Copyright (c) 2000 Microsoft Corporation Module Name: ftpif.h Abstract: This module contains declarations for the FTP transparent proxy's interface management. Author: Qiang Wang (qiangw) 10-Apr-2000 Revision History: --*/ #ifndef _NATHLP_FTPIF_H_ #define _NATHLP_FTPIF_H_ // // Structure: FTP_BINDING // // This structure holds information used for I/O on a logical network. // Each interface's 'BindingArray' contains an entry for each binding-entry // supplied during 'BindInterface'. // typedef struct _FTP_BINDING { ULONG Address; ULONG Mask; SOCKET ListeningSocket; HANDLE ListeningRedirectHandle[2]; } FTP_BINDING, *PFTP_BINDING; // // Structure: FTP_INTERFACE // // This structure holds operational information for an interface. // // Each interface is inserted into the list of FTP transparent proxy // interfaces, sorted by 'Index'. // // Synchronization on an interface makes use of an interface-list lock // ('FtpInterfaceLock'), a per-interface reference count, and a per-interface // critical-section: // // Acquiring a reference to an interface guarantees the interface's existence; // acquiring the interface's lock guarantees the interface's consistency. // // To acquire a reference, first acquire the interface-list lock; // to traverse the interface-list, first acquire the interface-list lock. // // An interface's lock can only be acquired if // (a) a reference to the interface has been acquired, or // (b) the interface-list lock is currently held. // Note that holding the list lock alone does not guarantee consistency. // // Fields marked read-only can be read so long as the interface is referenced. // typedef struct _FTP_INTERFACE { LIST_ENTRY Link; CRITICAL_SECTION Lock; ULONG ReferenceCount; ULONG Index; // read-only ULONG AdapterIndex; // read-only ULONG Characteristics; //read-only after activation NET_INTERFACE_TYPE Type; // read-only IP_FTP_INTERFACE_INFO Info; IP_NAT_PORT_MAPPING PortMapping; ULONG Flags; ULONG BindingCount; PFTP_BINDING BindingArray; LIST_ENTRY ConnectionList; LIST_ENTRY EndpointList; } FTP_INTERFACE, *PFTP_INTERFACE; // // Flags // #define FTP_INTERFACE_FLAG_DELETED 0x80000000 #define FTP_INTERFACE_DELETED(i) \ ((i)->Flags & FTP_INTERFACE_FLAG_DELETED) #define FTP_INTERFACE_FLAG_BOUND 0x40000000 #define FTP_INTERFACE_BOUND(i) \ ((i)->Flags & FTP_INTERFACE_FLAG_BOUND) #define FTP_INTERFACE_FLAG_ENABLED 0x20000000 #define FTP_INTERFACE_ENABLED(i) \ ((i)->Flags & FTP_INTERFACE_FLAG_ENABLED) #define FTP_INTERFACE_FLAG_CONFIGURED 0x10000000 #define FTP_INTERFACE_CONFIGURED(i) \ ((i)->Flags & FTP_INTERFACE_FLAG_CONFIGURED) #define FTP_INTERFACE_FLAG_MAPPED 0x01000000 #define FTP_INTERFACE_MAPPED(i) \ ((i)->Flags & FTP_INTERFACE_FLAG_MAPPED) #define FTP_INTERFACE_ACTIVE(i) \ (((i)->Flags & (FTP_INTERFACE_FLAG_BOUND|FTP_INTERFACE_FLAG_ENABLED)) \ == (FTP_INTERFACE_FLAG_BOUND|FTP_INTERFACE_FLAG_ENABLED)) #define FTP_INTERFACE_ADMIN_DISABLED(i) \ ((i)->Flags & IP_FTP_INTERFACE_FLAG_DISABLED) // // Synchronization // #define FTP_REFERENCE_INTERFACE(i) \ REFERENCE_OBJECT(i, FTP_INTERFACE_DELETED) #define FTP_DEREFERENCE_INTERFACE(i) \ DEREFERENCE_OBJECT(i, FtpCleanupInterface) // // GLOBAL DATA DECLARATIONS // extern LIST_ENTRY FtpInterfaceList; extern CRITICAL_SECTION FtpInterfaceLock; extern ULONG FtpFirewallIfCount; // // FUNCTION DECLARATIONS // ULONG FtpAcceptConnectionInterface( PFTP_INTERFACE Interfacep, SOCKET ListeningSocket, SOCKET AcceptedSocket OPTIONAL, PNH_BUFFER Bufferp OPTIONAL, OUT PHANDLE DynamicRedirectHandlep OPTIONAL ); ULONG FtpActivateInterface( PFTP_INTERFACE Interfacep ); ULONG FtpBindInterface( ULONG Index, PIP_ADAPTER_BINDING_INFO BindingInfo ); VOID FtpCleanupInterface( PFTP_INTERFACE Interfacep ); ULONG FtpConfigureInterface( ULONG Index, PIP_FTP_INTERFACE_INFO InterfaceInfo ); ULONG FtpCreateInterface( ULONG Index, NET_INTERFACE_TYPE Type, PIP_FTP_INTERFACE_INFO InterfaceInfo, PFTP_INTERFACE* InterfaceCreated ); VOID FtpDeactivateInterface( PFTP_INTERFACE Interfacep ); ULONG FtpDeleteInterface( ULONG Index ); ULONG FtpDisableInterface( ULONG Index ); ULONG FtpEnableInterface( ULONG Index ); ULONG FtpInitializeInterfaceManagement( VOID ); PFTP_INTERFACE FtpLookupInterface( ULONG Index, OUT PLIST_ENTRY* InsertionPoint OPTIONAL ); ULONG FtpQueryInterface( ULONG Index, PVOID InterfaceInfo, PULONG InterfaceInfoSize ); VOID FtpShutdownInterfaceManagement( VOID ); VOID FtpSignalNatInterface( ULONG Index, BOOLEAN Boundary ); ULONG FtpUnbindInterface( ULONG Index ); #endif // _NATHLP_FTPIF_H_