Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

459 lines
12 KiB

  1. //+-------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. //
  5. // Copyright (C) Microsoft Corporation, 1997 - 1999
  6. //
  7. // File: xfer.h
  8. //
  9. //--------------------------------------------------------------------------
  10. #ifndef _XFER_H_
  11. #define _XFER_H_
  12. #include <stdio.h>
  13. #define SERVICE_NAME_1 "OBEX:IrXfer"
  14. #define SERVICE_NAME_2 "OBEX"
  15. #define GUARD_MAGIC 0x45454545
  16. #define TIMEOUT_INFINITE (~0UL)
  17. #define ERROR_DESCRIPTION_LENGTH 1000
  18. #define IRDA_DEVICE_NAME_LENGTH 22
  19. //
  20. // OBEX parameter codes
  21. //
  22. #define OBEX_PARAM_UNICODE 0x00
  23. #define OBEX_PARAM_STREAM 0x40
  24. #define OBEX_PARAM_1BYTE 0x80
  25. #define OBEX_PARAM_4BYTE 0xC0
  26. #define OBEX_PARAM_TYPE_MASK 0xC0
  27. #define OBEX_PARAM_COUNT ( 0x00 | OBEX_PARAM_4BYTE )
  28. #define OBEX_PARAM_NAME ( 0x01 | OBEX_PARAM_UNICODE )
  29. #define OBEX_PARAM_LENGTH ( 0x03 | OBEX_PARAM_4BYTE )
  30. #define OBEX_PARAM_UNIX_TIME ( 0x04 | OBEX_PARAM_4BYTE )
  31. #define OBEX_PARAM_ISO_TIME ( 0x04 | OBEX_PARAM_STREAM )
  32. #define OBEX_PARAM_BODY ( 0x08 | OBEX_PARAM_STREAM )
  33. #define OBEX_PARAM_BODY_END ( 0x09 | OBEX_PARAM_STREAM )
  34. #define OBEX_PARAM_WHO ( 0x0A | OBEX_PARAM_STREAM )
  35. // #define OBEX_PARAM_LEN 1
  36. #define PRIVATE_PARAM_WIN32_ERROR ( 0x30 | OBEX_PARAM_4BYTE )
  37. // for xfer.c
  38. typedef struct {
  39. BOOL fXferInProgress; // transfer in progress
  40. __int64 dwTotalSize; // total size of transfer
  41. __int64 dwTotalSent; // number of bytes sent in this transfer
  42. __int64 dwFileSize; // total size of current file
  43. __int64 dwFileSent; // number of bytes sent of the current file
  44. } DATA_XFER, *LPDATA_XFER;
  45. typedef struct {
  46. FILETIME filetime; // file time
  47. WCHAR szFileName[MAX_PATH]; // name of file
  48. WCHAR szFileSave[MAX_PATH]; // path+name of final file
  49. WCHAR szFileTemp[MAX_PATH]; // path+name of temp file used
  50. HANDLE hFile; // file handle (of szFileTemp)
  51. } DATA_FILE, *LPDATA_FILE;
  52. // for obex.c
  53. typedef struct {
  54. BYTE1 b1Flags; // setpath flags
  55. BYTE1 b1Constants; // setpath constants
  56. } DATA_PATH, *LPDATA_PATH;
  57. typedef struct {
  58. BOOL fWaiting; // indicates if waiting for a reply
  59. BYTE1 b1Status; // response status (error/success)
  60. } DATA_REPLY, *LPDATA_REPLY;
  61. typedef enum {
  62. osIDLE = 0,
  63. osCONN = 1,
  64. osFILE = 2
  65. } OBEXSTATE;
  66. typedef struct {
  67. LPSTORE lpStore;
  68. OBEXSTATE state;
  69. BYTE1 b1Version; // peer's version of obex
  70. BYTE1 b1Flags; // connection flags
  71. BYTE2 b2MaxPacket; // peer's maximum packet size
  72. } DATA_CONN, *LPDATA_CONN;
  73. // for status.c
  74. typedef struct {
  75. DWORD dwDeviceID;
  76. BOOL fClear;
  77. } TARGET_ITEM, *LPTARGET_ITEM;
  78. //-------------------------------------
  79. enum TRANSFER_STATE
  80. {
  81. BLANK,
  82. CONNECTING,
  83. ACCEPTING,
  84. READING,
  85. WRITING,
  86. CLOSING
  87. };
  88. enum OBEX_DIALECT
  89. {
  90. dialUnknown = 0,
  91. dialWin95,
  92. dialNt5
  93. };
  94. typedef class FILE_TRANSFER * PFILE_TRANSFER;
  95. class FILE_TRANSFER
  96. {
  97. public:
  98. FILE_TRANSFER( );
  99. ~FILE_TRANSFER();
  100. BOOL
  101. Xfer_Init(
  102. wchar_t * files,
  103. unsigned length,
  104. OBEX_DIALECT dialect ,
  105. OBEX_DEVICE_TYPE DeviceType,
  106. BOOL CreateSocket,
  107. SOCKET ListenSocket
  108. );
  109. BOOL
  110. SendReplyObex(
  111. BYTE1 ObexCode
  112. );
  113. BOOL
  114. SendReplyWin32(
  115. BYTE1 b1Opcode,
  116. DWORD status
  117. );
  118. void
  119. BeginSend(
  120. DWORD DeviceId,
  121. OBEX_DEVICE_TYPE DeviceType,
  122. error_status_t * pStatus,
  123. FAILURE_LOCATION * pLocation
  124. );
  125. void Deactivate();
  126. DWORD
  127. SyncAccept(
  128. VOID
  129. );
  130. handle_t _rpcHandle;
  131. COOKIE _cookie;
  132. inline long
  133. DecrementRefCount()
  134. {
  135. EnterCriticalSection(&m_Lock);
  136. long count = --_refs;
  137. DbgLog3(SEV_INFO, "[%x] %p: refs = %d\n", (DWORD) _cookie, this, count);
  138. if (0 == count) {
  139. #if DBG
  140. DbgPrint("irmon: freeing transfer\n");
  141. #endif
  142. LeaveCriticalSection(&m_Lock);
  143. delete this;
  144. return count;
  145. } else {
  146. LeaveCriticalSection(&m_Lock);
  147. }
  148. return count;
  149. }
  150. inline BOOL
  151. IsActive(
  152. VOID
  153. )
  154. {
  155. return (_state != ACCEPTING);
  156. }
  157. inline long
  158. IncrementRefCount()
  159. {
  160. EnterCriticalSection(&m_Lock);
  161. long count = ++_refs;
  162. DbgLog3(SEV_INFO, "[%x] %p: refs = %d\n", (DWORD) _cookie, this, count);
  163. LeaveCriticalSection(&m_Lock);
  164. return count;
  165. }
  166. void Cancel()
  167. {
  168. _fCancelled = TRUE;
  169. }
  170. COOKIE
  171. GetCookie(
  172. VOID
  173. )
  174. {
  175. return _cookie;
  176. }
  177. void Send();
  178. void RecordDeviceName( SOCKADDR_IRDA * s );
  179. VOID
  180. StopListening(
  181. VOID
  182. )
  183. {
  184. IncrementRefCount();
  185. EnterCriticalSection(&m_Lock);
  186. m_StopListening=TRUE;
  187. if (m_ListenSocket != INVALID_SOCKET) {
  188. closesocket(m_ListenSocket);
  189. m_ListenSocket=INVALID_SOCKET;
  190. }
  191. LeaveCriticalSection(&m_Lock);
  192. DecrementRefCount();
  193. return;
  194. }
  195. private:
  196. CRITICAL_SECTION m_Lock;
  197. BOOL m_StopListening;
  198. SOCKET m_ListenSocket;
  199. OBEX_DEVICE_TYPE m_DeviceType;
  200. BOOL _fCancelled;
  201. BOOL _fInUiReceiveList;
  202. XFER_TYPE _xferType;
  203. TRANSFER_STATE _state;
  204. SOCKET _socket;
  205. wchar_t * _files;
  206. long _refs;
  207. HANDLE _event;
  208. BOOL _fWriteable;
  209. OBEX_DIALECT _dialect;
  210. wchar_t _DeviceName[MAX_PATH];
  211. HANDLE _waitHandle;
  212. BYTE _buffer[ cbSOCK_BUFFER_SIZE + 16 + sizeof(SOCKADDR_IRDA) + 16 + sizeof(SOCKADDR_IRDA) ];
  213. DWORD _guard;
  214. void
  215. HandleClosure(
  216. DWORD error
  217. );
  218. // for sock.c
  219. error_status_t Sock_Request( LPVOID lpvData, DWORD dwDataSize );
  220. error_status_t Sock_Respond( LPVOID lpvData, DWORD dwDataSize );
  221. error_status_t Sock_EstablishConnection( DWORD dwDeviceID ,OBEX_DEVICE_TYPE DeviceType);
  222. VOID Sock_BreakConnection( SOCKET * pSock );
  223. error_status_t _SendDataOnSocket( SOCKET sock, LPVOID lpvData, DWORD dwDataSize );
  224. VOID _BreakConnection( SOCKET sock );
  225. VOID _ReadConnection( SOCKET sock );
  226. error_status_t Sock_CheckForReply( long Timeout );
  227. // for xfer.c
  228. UINT _uObjsReceived;
  229. WCHAR _szRecvFolder[MAX_PATH];
  230. DATA_FILE _dataFileRecv;
  231. DATA_XFER _dataXferRecv;
  232. BOOL Xfer_FileSetSize( BYTE4 b4Size );
  233. error_status_t Xfer_FileWriteBody( LPVOID lpvData, BYTE2 b2Size, BOOL fFinal );
  234. VOID Xfer_ConnEnd( VOID );
  235. error_status_t Xfer_ConnStart( VOID );
  236. VOID Xfer_FileAbort( VOID );
  237. VOID Xfer_FileInit( VOID );
  238. error_status_t Xfer_FileSetName( LPWSTR szName );
  239. VOID Xfer_FileSetTime( FILETIME * FileTime );
  240. error_status_t Xfer_SetPath( LPWSTR szPath );
  241. VOID Xfer_SetSize( BYTE4 b4Size );
  242. error_status_t _PutFileBody( HANDLE hFile, wchar_t FileName[] );
  243. error_status_t _SendFile( LPWSTR szFile );
  244. error_status_t _SendFolder( LPWSTR szFolder );
  245. error_status_t _FileStart( VOID );
  246. error_status_t _FileEnd( BOOL fSave );
  247. VOID _Send_StartXfer( __int64 dwTotalSize, LPWSTR szDst );
  248. VOID _Send_EndXfer( VOID );
  249. error_status_t _SetReceiveFolder( LPWSTR szFolder );
  250. // for progress.c
  251. DWORD _dwTimeStart;
  252. DWORD _dwSecondsLeft;
  253. int _CurrentPercentage;
  254. VOID _FormatTime( LPWSTR sz, DWORD dwSeconds );
  255. // for obex.c
  256. DATA_CONN _dataRecv;
  257. DATA_PATH _dataPath;
  258. DATA_REPLY _dataReply;
  259. ULONG _blocksSent;
  260. ULONG _blocksAcked;
  261. ULONG _blockSize;
  262. __int64 _completedFilesSize;
  263. __int64 _currentFileSize;
  264. __int64 _currentFileAcked;
  265. DWORD _lastAckTime;
  266. error_status_t Obex_Abort( error_status_t status );
  267. error_status_t Obex_Connect( __int64 dwTotalSize );
  268. error_status_t Obex_Disconnect( error_status_t status );
  269. error_status_t Obex_PutBegin( LPWSTR wszObj, __int64 dwObjSize, FILETIME * pFileTime );
  270. error_status_t Obex_PutBody( wchar_t FileName[], LPBYTE1 pb1Data, BYTE2 b2DataSize, BOOL fFinal );
  271. error_status_t Obex_SetPath( LPWSTR wszPath );
  272. BOOL Obex_ConsumePackets( XFER_TYPE xferType, error_status_t * pStatus );
  273. BOOL Obex_Init( VOID );
  274. BOOL Obex_ReceiveData( XFER_TYPE xferType, LPVOID lpvData, DWORD dwDataSize );
  275. VOID Obex_Reset( VOID );
  276. error_status_t _WaitForReply( DWORD dwTimeout, BYTE1 b1NeededReply );
  277. error_status_t _Put( LPWSTR wszObj, __int64 dwObjSize, FILETIME * Time, LPBYTE1 pb1Data, BYTE2 b2DataSize, BOOL fFinal );
  278. error_status_t _Request( LPSTORE lpStore, BYTE1 b1NeededReply );
  279. error_status_t _Respond( LPSTORE lpStore );
  280. INT _ValidOpcode( OBEXSTATE state, BYTE1 b1Opcode );
  281. BOOL _HandleAbort( BYTE1 b1Opcode, BYTE2 b2Length );
  282. BOOL _HandleBadRequest( BYTE1 b1Opcode );
  283. BOOL _HandleConnect( BYTE1 b1Opcode, BYTE2 b2Length );
  284. BOOL _HandleDisconnect( BYTE1 b1Opcode, BYTE2 b2Length );
  285. BOOL _HandleNotImplemented( BYTE1 b1Opcode );
  286. error_status_t _HandlePut( BYTE1 b1Opcode, BYTE2 b2Length, BOOL fFinal );
  287. error_status_t _HandleResponse( BYTE1 b1Status, BYTE2 b2Length );
  288. error_status_t _HandleRequest( BYTE1 b1Opcode, BYTE2 b2Length );
  289. error_status_t _HandleSetPath( BYTE1 b1Opcode, BYTE2 b2Length );
  290. error_status_t _ParseParams( BYTE1 b1Opcode, BYTE2 b2Length );
  291. BOOL _PokePacketSizeIntoStore( LPSTORE lpStore );
  292. VOID _SetState( LPDATA_CONN lpDataConn, OBEXSTATE os );
  293. VOID _WaitInit( VOID );
  294. VOID _WriteBody( LPVOID lpvData, BYTE2 b2Size, BOOL fFinal );
  295. BYTE2 _SkipHeader( BYTE1 b1Param, LPSTORE lpStore );
  296. BYTE1
  297. StatusToReplyCode(
  298. BYTE1 b1Opcode,
  299. DWORD status
  300. );
  301. error_status_t
  302. ObexStatusToWin32(
  303. BYTE1 ObexStatus
  304. );
  305. BOOL Activate();
  306. };
  307. error_status_t
  308. _GetObjListStats(
  309. LPWSTR lpszObjList,
  310. LPDWORD lpdwFiles,
  311. LPDWORD lpdwFolders,
  312. __int64 * pTotalSize
  313. );
  314. DWORD
  315. ReportFileError( DWORD mc,
  316. WCHAR * file,
  317. DWORD error
  318. );
  319. BYTE1 WinErrorToObexError( DWORD Win32Error );
  320. extern RPC_BINDING_HANDLE rpcBinding;
  321. extern BOOL g_fAllowReceives;
  322. extern wchar_t g_DuplicateFileTemplate[];
  323. extern wchar_t g_UnknownDeviceName[];
  324. extern MUTEX * g_Mutex;
  325. #include <stdio.h>
  326. extern "C" {
  327. FILE_TRANSFER* InitializeSocket(
  328. char ServiceName[]
  329. );
  330. FILE_TRANSFER *
  331. ListenForTransfer(
  332. SOCKET ListenSocket,
  333. OBEX_DEVICE_TYPE DeviceType
  334. );
  335. }
  336. #endif // _XFER_H_