Source code of Windows XP (NT5)
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.

3061 lines
94 KiB

  1. /*++
  2. Copyright (c) 1995-1997 Microsoft Corporation
  3. Module Name:
  4. wininet.h
  5. Abstract:
  6. Contains manifests, macros, types and prototypes for Microsoft Windows
  7. Internet Extensions
  8. --*/
  9. #if !defined(_WININET_)
  10. #define _WININET_
  11. /*
  12. * Set up Structure Packing to be 4 bytes
  13. * for all wininet structures
  14. */
  15. #pragma pack(push, wininet, 4)
  16. #if defined(__cplusplus)
  17. extern "C" {
  18. #endif
  19. #if !defined(_WINX32_)
  20. #define INTERNETAPI DECLSPEC_IMPORT
  21. #define URLCACHEAPI DECLSPEC_IMPORT
  22. #else
  23. #define INTERNETAPI
  24. #define URLCACHEAPI
  25. #endif
  26. #define BOOLAPI INTERNETAPI BOOL WINAPI
  27. //
  28. // internet types
  29. //
  30. typedef LPVOID HINTERNET;
  31. typedef HINTERNET * LPHINTERNET;
  32. typedef WORD INTERNET_PORT;
  33. typedef INTERNET_PORT * LPINTERNET_PORT;
  34. //
  35. // Internet APIs
  36. //
  37. //
  38. // manifests
  39. //
  40. #define INTERNET_INVALID_PORT_NUMBER 0 // use the protocol-specific default
  41. #define INTERNET_DEFAULT_FTP_PORT 21 // default for FTP servers
  42. #define INTERNET_DEFAULT_GOPHER_PORT 70 // " " gopher "
  43. #define INTERNET_DEFAULT_HTTP_PORT 80 // " " HTTP "
  44. #define INTERNET_DEFAULT_HTTPS_PORT 443 // " " HTTPS "
  45. #define INTERNET_DEFAULT_SOCKS_PORT 1080 // default for SOCKS firewall servers.
  46. //
  47. // maximum field lengths (arbitrary)
  48. //
  49. #define INTERNET_MAX_HOST_NAME_LENGTH 256
  50. #define INTERNET_MAX_USER_NAME_LENGTH 128
  51. #define INTERNET_MAX_PASSWORD_LENGTH 128
  52. #define INTERNET_MAX_PORT_NUMBER_LENGTH 5 // INTERNET_PORT is unsigned short
  53. #define INTERNET_MAX_PORT_NUMBER_VALUE 65535 // maximum unsigned short value
  54. #define INTERNET_MAX_PATH_LENGTH 2048
  55. #define INTERNET_MAX_SCHEME_LENGTH 32 // longest protocol name length
  56. #define INTERNET_MAX_URL_LENGTH (INTERNET_MAX_SCHEME_LENGTH \
  57. + sizeof("://") \
  58. + INTERNET_MAX_PATH_LENGTH)
  59. //
  60. // values returned by InternetQueryOption() with INTERNET_OPTION_KEEP_CONNECTION:
  61. //
  62. #define INTERNET_KEEP_ALIVE_UNKNOWN ((DWORD)-1)
  63. #define INTERNET_KEEP_ALIVE_ENABLED 1
  64. #define INTERNET_KEEP_ALIVE_DISABLED 0
  65. //
  66. // flags returned by InternetQueryOption() with INTERNET_OPTION_REQUEST_FLAGS
  67. //
  68. #define INTERNET_REQFLAG_FROM_CACHE 0x00000001 // response came from cache
  69. #define INTERNET_REQFLAG_ASYNC 0x00000002 // request was made asynchronously
  70. #define INTERNET_REQFLAG_VIA_PROXY 0x00000004 // request was made via a proxy
  71. #define INTERNET_REQFLAG_NO_HEADERS 0x00000008 // orginal response contained no headers
  72. #define INTERNET_REQFLAG_PASSIVE 0x00000010 // FTP: passive-mode connection
  73. #define INTERNET_REQFLAG_CACHE_WRITE_DISABLED 0x00000040 // HTTPS: this request not cacheable
  74. //
  75. // flags common to open functions (not InternetOpen()):
  76. //
  77. #define INTERNET_FLAG_RELOAD 0x80000000 // retrieve the original item
  78. //
  79. // flags for InternetOpenUrl():
  80. //
  81. #define INTERNET_FLAG_RAW_DATA 0x40000000 // FTP/gopher find: receive the item as raw (structured) data
  82. #define INTERNET_FLAG_EXISTING_CONNECT 0x20000000 // FTP: use existing InternetConnect handle for server if possible
  83. //
  84. // flags for InternetOpen():
  85. //
  86. #define INTERNET_FLAG_ASYNC 0x10000000 // this request is asynchronous (where supported)
  87. //
  88. // protocol-specific flags:
  89. //
  90. #define INTERNET_FLAG_PASSIVE 0x08000000 // used for FTP connections
  91. //
  92. // additional cache flags
  93. //
  94. #define INTERNET_FLAG_NO_CACHE_WRITE 0x04000000 // don't write this item to the cache
  95. #define INTERNET_FLAG_DONT_CACHE INTERNET_FLAG_NO_CACHE_WRITE
  96. #define INTERNET_FLAG_MAKE_PERSISTENT 0x02000000 // make this item persistent in cache
  97. #define INTERNET_FLAG_FROM_CACHE 0x01000000 // use offline semantics
  98. #define INTERNET_FLAG_OFFLINE INTERNET_FLAG_FROM_CACHE
  99. //
  100. // additional flags
  101. //
  102. #define INTERNET_FLAG_SECURE 0x00800000 // use PCT/SSL if applicable (HTTP)
  103. #define INTERNET_FLAG_KEEP_CONNECTION 0x00400000 // use keep-alive semantics
  104. #define INTERNET_FLAG_NO_AUTO_REDIRECT 0x00200000 // don't handle redirections automatically
  105. #define INTERNET_FLAG_READ_PREFETCH 0x00100000 // do background read prefetch
  106. #define INTERNET_FLAG_NO_COOKIES 0x00080000 // no automatic cookie handling
  107. #define INTERNET_FLAG_NO_AUTH 0x00040000 // no automatic authentication handling
  108. #define INTERNET_FLAG_CACHE_IF_NET_FAIL 0x00010000 // return cache file if net request fails
  109. //
  110. // Security Ignore Flags, Allow HttpOpenRequest to overide
  111. // Secure Channel (SSL/PCT) failures of the following types.
  112. //
  113. #define INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTP 0x00008000 // ex: https:// to http://
  114. #define INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTPS 0x00004000 // ex: http:// to https://
  115. #define INTERNET_FLAG_IGNORE_CERT_DATE_INVALID 0x00002000 // expired X509 Cert.
  116. #define INTERNET_FLAG_IGNORE_CERT_CN_INVALID 0x00001000 // bad common name in X509 Cert.
  117. //
  118. // more caching flags
  119. //
  120. #define INTERNET_FLAG_RESYNCHRONIZE 0x00000800 // asking wininet to update an item if it is newer
  121. #define INTERNET_FLAG_HYPERLINK 0x00000400 // asking wininet to do hyperlinking semantic which works right for scripts
  122. #define INTERNET_FLAG_NO_UI 0x00000200 // no cookie popup
  123. #define INTERNET_FLAG_PRAGMA_NOCACHE 0x00000100 // asking wininet to add "pragma: no-cache"
  124. #define INTERNET_FLAG_CACHE_ASYNC 0x00000080 // ok to perform lazy cache-write
  125. #define INTERNET_FLAG_FORMS_SUBMIT 0x00000040 // this is a forms submit
  126. #define INTERNET_FLAG_NEED_FILE 0x00000010 // need a file for this request
  127. #define INTERNET_FLAG_MUST_CACHE_REQUEST INTERNET_FLAG_NEED_FILE
  128. //
  129. // flags for FTP
  130. //
  131. #define INTERNET_FLAG_TRANSFER_ASCII FTP_TRANSFER_TYPE_ASCII // 0x00000001
  132. #define INTERNET_FLAG_TRANSFER_BINARY FTP_TRANSFER_TYPE_BINARY // 0x00000002
  133. //
  134. // flags field masks
  135. //
  136. #define SECURITY_INTERNET_MASK (INTERNET_FLAG_IGNORE_CERT_CN_INVALID | \
  137. INTERNET_FLAG_IGNORE_CERT_DATE_INVALID | \
  138. INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTPS | \
  139. INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTP )
  140. #define INTERNET_FLAGS_MASK (INTERNET_FLAG_RELOAD \
  141. | INTERNET_FLAG_RAW_DATA \
  142. | INTERNET_FLAG_EXISTING_CONNECT \
  143. | INTERNET_FLAG_ASYNC \
  144. | INTERNET_FLAG_PASSIVE \
  145. | INTERNET_FLAG_NO_CACHE_WRITE \
  146. | INTERNET_FLAG_MAKE_PERSISTENT \
  147. | INTERNET_FLAG_FROM_CACHE \
  148. | INTERNET_FLAG_SECURE \
  149. | INTERNET_FLAG_KEEP_CONNECTION \
  150. | INTERNET_FLAG_NO_AUTO_REDIRECT \
  151. | INTERNET_FLAG_READ_PREFETCH \
  152. | INTERNET_FLAG_NO_COOKIES \
  153. | INTERNET_FLAG_NO_AUTH \
  154. | INTERNET_FLAG_CACHE_IF_NET_FAIL \
  155. | SECURITY_INTERNET_MASK \
  156. | INTERNET_FLAG_RESYNCHRONIZE \
  157. | INTERNET_FLAG_HYPERLINK \
  158. | INTERNET_FLAG_NO_UI \
  159. | INTERNET_FLAG_PRAGMA_NOCACHE \
  160. | INTERNET_FLAG_CACHE_ASYNC \
  161. | INTERNET_FLAG_FORMS_SUBMIT \
  162. | INTERNET_FLAG_NEED_FILE \
  163. | INTERNET_FLAG_TRANSFER_BINARY \
  164. | INTERNET_FLAG_TRANSFER_ASCII \
  165. )
  166. #define INTERNET_ERROR_MASK_INSERT_CDROM 0x1
  167. #define INTERNET_OPTIONS_MASK (~INTERNET_FLAGS_MASK)
  168. //
  169. // common per-API flags (new APIs)
  170. //
  171. #define WININET_API_FLAG_ASYNC 0x00000001 // force async operation
  172. #define WININET_API_FLAG_SYNC 0x00000004 // force sync operation
  173. #define WININET_API_FLAG_USE_CONTEXT 0x00000008 // use value supplied in dwContext (even if 0)
  174. //
  175. // INTERNET_NO_CALLBACK - if this value is presented as the dwContext parameter
  176. // then no call-backs will be made for that API
  177. //
  178. #define INTERNET_NO_CALLBACK 0
  179. //
  180. // structures/types
  181. //
  182. //
  183. // INTERNET_SCHEME - enumerated URL scheme type
  184. //
  185. typedef enum {
  186. INTERNET_SCHEME_PARTIAL = -2,
  187. INTERNET_SCHEME_UNKNOWN = -1,
  188. INTERNET_SCHEME_DEFAULT = 0,
  189. INTERNET_SCHEME_FTP,
  190. INTERNET_SCHEME_GOPHER,
  191. INTERNET_SCHEME_HTTP,
  192. INTERNET_SCHEME_HTTPS,
  193. INTERNET_SCHEME_FILE,
  194. INTERNET_SCHEME_NEWS,
  195. INTERNET_SCHEME_MAILTO,
  196. INTERNET_SCHEME_SOCKS,
  197. INTERNET_SCHEME_FIRST = INTERNET_SCHEME_FTP,
  198. INTERNET_SCHEME_LAST = INTERNET_SCHEME_SOCKS
  199. } INTERNET_SCHEME, * LPINTERNET_SCHEME;
  200. //
  201. // INTERNET_ASYNC_RESULT - this structure is returned to the application via
  202. // the callback with INTERNET_STATUS_REQUEST_COMPLETE. It is not sufficient to
  203. // just return the result of the async operation. If the API failed then the
  204. // app cannot call GetLastError() because the thread context will be incorrect.
  205. // Both the value returned by the async API and any resultant error code are
  206. // made available. The app need not check dwError if dwResult indicates that
  207. // the API succeeded (in this case dwError will be ERROR_SUCCESS)
  208. //
  209. typedef struct {
  210. //
  211. // dwResult - the HINTERNET, DWORD or BOOL return code from an async API
  212. //
  213. DWORD dwResult;
  214. //
  215. // dwError - the error code if the API failed
  216. //
  217. DWORD dwError;
  218. } INTERNET_ASYNC_RESULT, * LPINTERNET_ASYNC_RESULT;
  219. //
  220. // INTERNET_PROXY_INFO - structure supplied with INTERNET_OPTION_PROXY to get/
  221. // set proxy information on a InternetOpen() handle
  222. //
  223. typedef struct {
  224. //
  225. // dwAccessType - INTERNET_OPEN_TYPE_DIRECT, INTERNET_OPEN_TYPE_PROXY, or
  226. // INTERNET_OPEN_TYPE_PRECONFIG (set only)
  227. //
  228. DWORD dwAccessType;
  229. //
  230. // lpszProxy - proxy server list
  231. //
  232. LPCTSTR lpszProxy;
  233. //
  234. // lpszProxyBypass - proxy bypass list
  235. //
  236. LPCTSTR lpszProxyBypass;
  237. } INTERNET_PROXY_INFO, * LPINTERNET_PROXY_INFO;
  238. //
  239. // INTERNET_VERSION_INFO - version information returned via
  240. // InternetQueryOption(..., INTERNET_OPTION_VERSION, ...)
  241. //
  242. typedef struct {
  243. DWORD dwMajorVersion;
  244. DWORD dwMinorVersion;
  245. } INTERNET_VERSION_INFO, * LPINTERNET_VERSION_INFO;
  246. //
  247. // HTTP_VERSION_INFO - query or set global HTTP version (1.0 or 1.1)
  248. //
  249. typedef struct {
  250. DWORD dwMajorVersion;
  251. DWORD dwMinorVersion;
  252. } HTTP_VERSION_INFO, * LPHTTP_VERSION_INFO;
  253. //
  254. // INTERNET_CONNECTED_INFO - information used to set the global connected state
  255. //
  256. typedef struct {
  257. //
  258. // dwConnectedState - new connected/disconnected state.
  259. // See INTERNET_STATE_CONNECTED, etc.
  260. //
  261. DWORD dwConnectedState;
  262. //
  263. // dwFlags - flags controlling connected->disconnected (or disconnected->
  264. // connected) transition. See below
  265. //
  266. DWORD dwFlags;
  267. } INTERNET_CONNECTED_INFO, * LPINTERNET_CONNECTED_INFO;
  268. //
  269. // flags for INTERNET_CONNECTED_INFO dwFlags
  270. //
  271. //
  272. // ISO_FORCE_DISCONNECTED - if set when putting Wininet into disconnected mode,
  273. // all outstanding requests will be aborted with a cancelled error
  274. //
  275. #define ISO_FORCE_DISCONNECTED 0x00000001
  276. //
  277. // URL_COMPONENTS - the constituent parts of an URL. Used in InternetCrackUrl()
  278. // and InternetCreateUrl()
  279. //
  280. // For InternetCrackUrl(), if a pointer field and its corresponding length field
  281. // are both 0 then that component is not returned. If the pointer field is NULL
  282. // but the length field is not zero, then both the pointer and length fields are
  283. // returned if both pointer and corresponding length fields are non-zero then
  284. // the pointer field points to a buffer where the component is copied. The
  285. // component may be un-escaped, depending on dwFlags
  286. //
  287. // For InternetCreateUrl(), the pointer fields should be NULL if the component
  288. // is not required. If the corresponding length field is zero then the pointer
  289. // field is the address of a zero-terminated string. If the length field is not
  290. // zero then it is the string length of the corresponding pointer field
  291. //
  292. typedef struct {
  293. DWORD dwStructSize; // size of this structure. Used in version check
  294. LPSTR lpszScheme; // pointer to scheme name
  295. DWORD dwSchemeLength; // length of scheme name
  296. INTERNET_SCHEME nScheme; // enumerated scheme type (if known)
  297. LPSTR lpszHostName; // pointer to host name
  298. DWORD dwHostNameLength; // length of host name
  299. INTERNET_PORT nPort; // converted port number
  300. LPSTR lpszUserName; // pointer to user name
  301. DWORD dwUserNameLength; // length of user name
  302. LPSTR lpszPassword; // pointer to password
  303. DWORD dwPasswordLength; // length of password
  304. LPSTR lpszUrlPath; // pointer to URL-path
  305. DWORD dwUrlPathLength; // length of URL-path
  306. LPSTR lpszExtraInfo; // pointer to extra information (e.g. ?foo or #foo)
  307. DWORD dwExtraInfoLength; // length of extra information
  308. } URL_COMPONENTSA, * LPURL_COMPONENTSA;
  309. typedef struct {
  310. DWORD dwStructSize; // size of this structure. Used in version check
  311. LPWSTR lpszScheme; // pointer to scheme name
  312. DWORD dwSchemeLength; // length of scheme name
  313. INTERNET_SCHEME nScheme; // enumerated scheme type (if known)
  314. LPWSTR lpszHostName; // pointer to host name
  315. DWORD dwHostNameLength; // length of host name
  316. INTERNET_PORT nPort; // converted port number
  317. LPWSTR lpszUserName; // pointer to user name
  318. DWORD dwUserNameLength; // length of user name
  319. LPWSTR lpszPassword; // pointer to password
  320. DWORD dwPasswordLength; // length of password
  321. LPWSTR lpszUrlPath; // pointer to URL-path
  322. DWORD dwUrlPathLength; // length of URL-path
  323. LPWSTR lpszExtraInfo; // pointer to extra information (e.g. ?foo or #foo)
  324. DWORD dwExtraInfoLength; // length of extra information
  325. } URL_COMPONENTSW, * LPURL_COMPONENTSW;
  326. #ifdef UNICODE
  327. typedef URL_COMPONENTSW URL_COMPONENTS;
  328. typedef LPURL_COMPONENTSW LPURL_COMPONENTS;
  329. #else
  330. typedef URL_COMPONENTSA URL_COMPONENTS;
  331. typedef LPURL_COMPONENTSA LPURL_COMPONENTS;
  332. #endif // UNICODE
  333. //
  334. // INTERNET_CERTIFICATE_INFO lpBuffer - contains the certificate returned from
  335. // the server
  336. //
  337. typedef struct {
  338. //
  339. // ftExpiry - date the certificate expires.
  340. //
  341. FILETIME ftExpiry;
  342. //
  343. // ftStart - date the certificate becomes valid.
  344. //
  345. FILETIME ftStart;
  346. //
  347. // lpszSubjectInfo - the name of organization, site, and server
  348. // the cert. was issued for.
  349. //
  350. LPTSTR lpszSubjectInfo;
  351. //
  352. // lpszIssuerInfo - the name of orgainzation, site, and server
  353. // the cert was issues by.
  354. //
  355. LPTSTR lpszIssuerInfo;
  356. //
  357. // lpszProtocolName - the name of the protocol used to provide the secure
  358. // connection.
  359. //
  360. LPTSTR lpszProtocolName;
  361. //
  362. // lpszSignatureAlgName - the name of the algorithm used for signing
  363. // the certificate.
  364. //
  365. LPTSTR lpszSignatureAlgName;
  366. //
  367. // lpszEncryptionAlgName - the name of the algorithm used for
  368. // doing encryption over the secure channel (SSL/PCT) connection.
  369. //
  370. LPTSTR lpszEncryptionAlgName;
  371. //
  372. // dwKeySize - size of the key.
  373. //
  374. DWORD dwKeySize;
  375. } INTERNET_CERTIFICATE_INFO, * LPINTERNET_CERTIFICATE_INFO;
  376. //
  377. // INTERNET_BUFFERS - combines headers and data. May be chained for e.g. file
  378. // upload or scatter/gather operations. For chunked read/write, lpcszHeader
  379. // contains the chunked-ext
  380. //
  381. typedef struct _INTERNET_BUFFERSA {
  382. DWORD dwStructSize; // used for API versioning. Set to sizeof(INTERNET_BUFFERS)
  383. struct _INTERNET_BUFFERSA * Next; // chain of buffers
  384. LPCSTR lpcszHeader; // pointer to headers (may be NULL)
  385. DWORD dwHeadersLength; // length of headers if not NULL
  386. DWORD dwHeadersTotal; // size of headers if not enough buffer
  387. LPVOID lpvBuffer; // pointer to data buffer (may be NULL)
  388. DWORD dwBufferLength; // length of data buffer if not NULL
  389. DWORD dwBufferTotal; // total size of chunk, or content-length if not chunked
  390. DWORD dwOffsetLow; // used for read-ranges (only used in HttpSendRequest2)
  391. DWORD dwOffsetHigh;
  392. } INTERNET_BUFFERSA, * LPINTERNET_BUFFERSA;
  393. typedef struct _INTERNET_BUFFERSW {
  394. DWORD dwStructSize; // used for API versioning. Set to sizeof(INTERNET_BUFFERS)
  395. struct _INTERNET_BUFFERSW * Next; // chain of buffers
  396. LPCWSTR lpcszHeader; // pointer to headers (may be NULL)
  397. DWORD dwHeadersLength; // length of headers if not NULL
  398. DWORD dwHeadersTotal; // size of headers if not enough buffer
  399. LPVOID lpvBuffer; // pointer to data buffer (may be NULL)
  400. DWORD dwBufferLength; // length of data buffer if not NULL
  401. DWORD dwBufferTotal; // total size of chunk, or content-length if not chunked
  402. DWORD dwOffsetLow; // used for read-ranges (only used in HttpSendRequest2)
  403. DWORD dwOffsetHigh;
  404. } INTERNET_BUFFERSW, * LPINTERNET_BUFFERSW;
  405. #ifdef UNICODE
  406. typedef INTERNET_BUFFERSW INTERNET_BUFFERS;
  407. typedef LPINTERNET_BUFFERSW LPINTERNET_BUFFERS;
  408. #else
  409. typedef INTERNET_BUFFERSA INTERNET_BUFFERS;
  410. typedef LPINTERNET_BUFFERSA LPINTERNET_BUFFERS;
  411. #endif // UNICODE
  412. //
  413. // prototypes
  414. //
  415. BOOLAPI
  416. InternetTimeFromSystemTime(
  417. IN CONST SYSTEMTIME *pst, // input GMT time
  418. IN DWORD dwRFC, // RFC format
  419. OUT LPSTR lpszTime, // output string buffer
  420. IN DWORD cbTime // output buffer size
  421. );
  422. //
  423. // constants for InternetTimeFromSystemTime
  424. //
  425. #define INTERNET_RFC1123_FORMAT 0
  426. #define INTERNET_RFC1123_BUFSIZE 30
  427. BOOLAPI
  428. InternetTimeToSystemTime(
  429. IN LPCSTR lpszTime, // NULL terminated string
  430. OUT SYSTEMTIME *pst, // output in GMT time
  431. IN DWORD dwReserved
  432. );
  433. BOOLAPI
  434. InternetCrackUrlA(
  435. IN LPCSTR lpszUrl,
  436. IN DWORD dwUrlLength,
  437. IN DWORD dwFlags,
  438. IN OUT LPURL_COMPONENTSA lpUrlComponents
  439. );
  440. BOOLAPI
  441. InternetCrackUrlW(
  442. IN LPCWSTR lpszUrl,
  443. IN DWORD dwUrlLength,
  444. IN DWORD dwFlags,
  445. IN OUT LPURL_COMPONENTSW lpUrlComponents
  446. );
  447. #ifdef UNICODE
  448. #define InternetCrackUrl InternetCrackUrlW
  449. #else
  450. #define InternetCrackUrl InternetCrackUrlA
  451. #endif // !UNICODE
  452. BOOLAPI
  453. InternetCreateUrlA(
  454. IN LPURL_COMPONENTSA lpUrlComponents,
  455. IN DWORD dwFlags,
  456. OUT LPSTR lpszUrl,
  457. IN OUT LPDWORD lpdwUrlLength
  458. );
  459. BOOLAPI
  460. InternetCreateUrlW(
  461. IN LPURL_COMPONENTSW lpUrlComponents,
  462. IN DWORD dwFlags,
  463. OUT LPWSTR lpszUrl,
  464. IN OUT LPDWORD lpdwUrlLength
  465. );
  466. #ifdef UNICODE
  467. #define InternetCreateUrl InternetCreateUrlW
  468. #else
  469. #define InternetCreateUrl InternetCreateUrlA
  470. #endif // !UNICODE
  471. BOOLAPI
  472. InternetCanonicalizeUrlA(
  473. IN LPCSTR lpszUrl,
  474. OUT LPSTR lpszBuffer,
  475. IN OUT LPDWORD lpdwBufferLength,
  476. IN DWORD dwFlags
  477. );
  478. BOOLAPI
  479. InternetCanonicalizeUrlW(
  480. IN LPCWSTR lpszUrl,
  481. OUT LPWSTR lpszBuffer,
  482. IN OUT LPDWORD lpdwBufferLength,
  483. IN DWORD dwFlags
  484. );
  485. #ifdef UNICODE
  486. #define InternetCanonicalizeUrl InternetCanonicalizeUrlW
  487. #else
  488. #define InternetCanonicalizeUrl InternetCanonicalizeUrlA
  489. #endif // !UNICODE
  490. BOOLAPI
  491. InternetCombineUrlA(
  492. IN LPCSTR lpszBaseUrl,
  493. IN LPCSTR lpszRelativeUrl,
  494. OUT LPSTR lpszBuffer,
  495. IN OUT LPDWORD lpdwBufferLength,
  496. IN DWORD dwFlags
  497. );
  498. BOOLAPI
  499. InternetCombineUrlW(
  500. IN LPCWSTR lpszBaseUrl,
  501. IN LPCWSTR lpszRelativeUrl,
  502. OUT LPWSTR lpszBuffer,
  503. IN OUT LPDWORD lpdwBufferLength,
  504. IN DWORD dwFlags
  505. );
  506. #ifdef UNICODE
  507. #define InternetCombineUrl InternetCombineUrlW
  508. #else
  509. #define InternetCombineUrl InternetCombineUrlA
  510. #endif // !UNICODE
  511. //
  512. // flags for InternetCrackUrl() and InternetCreateUrl()
  513. //
  514. #define ICU_ESCAPE 0x80000000 // (un)escape URL characters
  515. #define ICU_USERNAME 0x40000000 // use internal username & password
  516. //
  517. // flags for InternetCanonicalizeUrl() and InternetCombineUrl()
  518. //
  519. #define ICU_NO_ENCODE 0x20000000 // Don't convert unsafe characters to escape sequence
  520. #define ICU_DECODE 0x10000000 // Convert %XX escape sequences to characters
  521. #define ICU_NO_META 0x08000000 // Don't convert .. etc. meta path sequences
  522. #define ICU_ENCODE_SPACES_ONLY 0x04000000 // Encode spaces only
  523. #define ICU_BROWSER_MODE 0x02000000 // Special encode/decode rules for browser
  524. INTERNETAPI
  525. HINTERNET
  526. WINAPI
  527. InternetOpenA(
  528. IN LPCSTR lpszAgent,
  529. IN DWORD dwAccessType,
  530. IN LPCSTR lpszProxy OPTIONAL,
  531. IN LPCSTR lpszProxyBypass OPTIONAL,
  532. IN DWORD dwFlags
  533. );
  534. INTERNETAPI
  535. HINTERNET
  536. WINAPI
  537. InternetOpenW(
  538. IN LPCWSTR lpszAgent,
  539. IN DWORD dwAccessType,
  540. IN LPCWSTR lpszProxy OPTIONAL,
  541. IN LPCWSTR lpszProxyBypass OPTIONAL,
  542. IN DWORD dwFlags
  543. );
  544. #ifdef UNICODE
  545. #define InternetOpen InternetOpenW
  546. #else
  547. #define InternetOpen InternetOpenA
  548. #endif // !UNICODE
  549. //
  550. // access types for InternetOpen()
  551. //
  552. #define INTERNET_OPEN_TYPE_PRECONFIG 0 // use registry configuration
  553. #define INTERNET_OPEN_TYPE_DIRECT 1 // direct to net
  554. #define INTERNET_OPEN_TYPE_PROXY 3 // via named proxy
  555. #define INTERNET_OPEN_TYPE_PRECONFIG_WITH_NO_AUTOPROXY 4 // prevent using java/script/INS
  556. //
  557. // old names for access types
  558. //
  559. #define PRE_CONFIG_INTERNET_ACCESS INTERNET_OPEN_TYPE_PRECONFIG
  560. #define LOCAL_INTERNET_ACCESS INTERNET_OPEN_TYPE_DIRECT
  561. #define CERN_PROXY_INTERNET_ACCESS INTERNET_OPEN_TYPE_PROXY
  562. BOOLAPI
  563. InternetCloseHandle(
  564. IN HINTERNET hInternet
  565. );
  566. INTERNETAPI
  567. HINTERNET
  568. WINAPI
  569. InternetConnectA(
  570. IN HINTERNET hInternet,
  571. IN LPCSTR lpszServerName,
  572. IN INTERNET_PORT nServerPort,
  573. IN LPCSTR lpszUserName OPTIONAL,
  574. IN LPCSTR lpszPassword OPTIONAL,
  575. IN DWORD dwService,
  576. IN DWORD dwFlags,
  577. IN DWORD dwContext
  578. );
  579. INTERNETAPI
  580. HINTERNET
  581. WINAPI
  582. InternetConnectW(
  583. IN HINTERNET hInternet,
  584. IN LPCWSTR lpszServerName,
  585. IN INTERNET_PORT nServerPort,
  586. IN LPCWSTR lpszUserName OPTIONAL,
  587. IN LPCWSTR lpszPassword OPTIONAL,
  588. IN DWORD dwService,
  589. IN DWORD dwFlags,
  590. IN DWORD dwContext
  591. );
  592. #ifdef UNICODE
  593. #define InternetConnect InternetConnectW
  594. #else
  595. #define InternetConnect InternetConnectA
  596. #endif // !UNICODE
  597. //
  598. // service types for InternetConnect()
  599. //
  600. #define INTERNET_SERVICE_URL 0
  601. #define INTERNET_SERVICE_FTP 1
  602. #define INTERNET_SERVICE_GOPHER 2
  603. #define INTERNET_SERVICE_HTTP 3
  604. //
  605. // InternetConnectUrl() - a macro which allows you to specify an URL instead of
  606. // the component parts to InternetConnect(). If any API which uses the returned
  607. // connect handle specifies a NULL path then the URL-path part of the URL
  608. // specified in InternetConnectUrl() will be used
  609. //
  610. #define InternetConnectUrl(hInternet, lpszUrl, dwFlags, dwContext) \
  611. InternetConnect(hInternet, \
  612. lpszUrl, \
  613. INTERNET_INVALID_PORT_NUMBER, \
  614. NULL, \
  615. NULL, \
  616. INTERNET_SERVICE_URL, \
  617. dwFlags, \
  618. dwContext \
  619. )
  620. INTERNETAPI
  621. HINTERNET
  622. WINAPI
  623. InternetOpenUrlA(
  624. IN HINTERNET hInternet,
  625. IN LPCSTR lpszUrl,
  626. IN LPCSTR lpszHeaders OPTIONAL,
  627. IN DWORD dwHeadersLength,
  628. IN DWORD dwFlags,
  629. IN DWORD dwContext
  630. );
  631. INTERNETAPI
  632. HINTERNET
  633. WINAPI
  634. InternetOpenUrlW(
  635. IN HINTERNET hInternet,
  636. IN LPCWSTR lpszUrl,
  637. IN LPCWSTR lpszHeaders OPTIONAL,
  638. IN DWORD dwHeadersLength,
  639. IN DWORD dwFlags,
  640. IN DWORD dwContext
  641. );
  642. #ifdef UNICODE
  643. #define InternetOpenUrl InternetOpenUrlW
  644. #else
  645. #define InternetOpenUrl InternetOpenUrlA
  646. #endif // !UNICODE
  647. BOOLAPI
  648. InternetReadFile(
  649. IN HINTERNET hFile,
  650. IN LPVOID lpBuffer,
  651. IN DWORD dwNumberOfBytesToRead,
  652. OUT LPDWORD lpdwNumberOfBytesRead
  653. );
  654. INTERNETAPI
  655. BOOL
  656. WINAPI
  657. InternetReadFileExA(
  658. IN HINTERNET hFile,
  659. OUT LPINTERNET_BUFFERSA lpBuffersOut,
  660. IN DWORD dwFlags,
  661. IN DWORD dwContext
  662. );
  663. INTERNETAPI
  664. BOOL
  665. WINAPI
  666. InternetReadFileExW(
  667. IN HINTERNET hFile,
  668. OUT LPINTERNET_BUFFERSW lpBuffersOut,
  669. IN DWORD dwFlags,
  670. IN DWORD dwContext
  671. );
  672. #ifdef UNICODE
  673. #define InternetReadFileEx InternetReadFileExW
  674. #else
  675. #define InternetReadFileEx InternetReadFileExA
  676. #endif // !UNICODE
  677. //
  678. // flags for InternetReadFileEx()
  679. //
  680. #define IRF_ASYNC WININET_API_FLAG_ASYNC
  681. #define IRF_SYNC WININET_API_FLAG_SYNC
  682. #define IRF_USE_CONTEXT WININET_API_FLAG_USE_CONTEXT
  683. #define IRF_NO_WAIT 0x00000008
  684. INTERNETAPI
  685. DWORD
  686. WINAPI
  687. InternetSetFilePointer(
  688. IN HINTERNET hFile,
  689. IN LONG lDistanceToMove,
  690. IN PVOID pReserved,
  691. IN DWORD dwMoveMethod,
  692. IN DWORD dwContext
  693. );
  694. BOOLAPI
  695. InternetWriteFile(
  696. IN HINTERNET hFile,
  697. IN LPCVOID lpBuffer,
  698. IN DWORD dwNumberOfBytesToWrite,
  699. OUT LPDWORD lpdwNumberOfBytesWritten
  700. );
  701. BOOLAPI
  702. InternetQueryDataAvailable(
  703. IN HINTERNET hFile,
  704. OUT LPDWORD lpdwNumberOfBytesAvailable OPTIONAL,
  705. IN DWORD dwFlags,
  706. IN DWORD dwContext
  707. );
  708. BOOLAPI
  709. InternetFindNextFileA(
  710. IN HINTERNET hFind,
  711. OUT LPVOID lpvFindData
  712. );
  713. BOOLAPI
  714. InternetFindNextFileW(
  715. IN HINTERNET hFind,
  716. OUT LPVOID lpvFindData
  717. );
  718. #ifdef UNICODE
  719. #define InternetFindNextFile InternetFindNextFileW
  720. #else
  721. #define InternetFindNextFile InternetFindNextFileA
  722. #endif // !UNICODE
  723. BOOLAPI
  724. InternetQueryOptionA(
  725. IN HINTERNET hInternet OPTIONAL,
  726. IN DWORD dwOption,
  727. OUT LPVOID lpBuffer OPTIONAL,
  728. IN OUT LPDWORD lpdwBufferLength
  729. );
  730. BOOLAPI
  731. InternetQueryOptionW(
  732. IN HINTERNET hInternet OPTIONAL,
  733. IN DWORD dwOption,
  734. OUT LPVOID lpBuffer OPTIONAL,
  735. IN OUT LPDWORD lpdwBufferLength
  736. );
  737. #ifdef UNICODE
  738. #define InternetQueryOption InternetQueryOptionW
  739. #else
  740. #define InternetQueryOption InternetQueryOptionA
  741. #endif // !UNICODE
  742. BOOLAPI
  743. InternetSetOptionA(
  744. IN HINTERNET hInternet OPTIONAL,
  745. IN DWORD dwOption,
  746. IN LPVOID lpBuffer,
  747. IN DWORD dwBufferLength
  748. );
  749. BOOLAPI
  750. InternetSetOptionW(
  751. IN HINTERNET hInternet OPTIONAL,
  752. IN DWORD dwOption,
  753. IN LPVOID lpBuffer,
  754. IN DWORD dwBufferLength
  755. );
  756. #ifdef UNICODE
  757. #define InternetSetOption InternetSetOptionW
  758. #else
  759. #define InternetSetOption InternetSetOptionA
  760. #endif // !UNICODE
  761. BOOLAPI
  762. InternetSetOptionExA(
  763. IN HINTERNET hInternet OPTIONAL,
  764. IN DWORD dwOption,
  765. IN LPVOID lpBuffer,
  766. IN DWORD dwBufferLength,
  767. IN DWORD dwFlags
  768. );
  769. BOOLAPI
  770. InternetSetOptionExW(
  771. IN HINTERNET hInternet OPTIONAL,
  772. IN DWORD dwOption,
  773. IN LPVOID lpBuffer,
  774. IN DWORD dwBufferLength,
  775. IN DWORD dwFlags
  776. );
  777. #ifdef UNICODE
  778. #define InternetSetOptionEx InternetSetOptionExW
  779. #else
  780. #define InternetSetOptionEx InternetSetOptionExA
  781. #endif // !UNICODE
  782. BOOLAPI
  783. InternetLockRequestFile(
  784. IN HINTERNET hInternet,
  785. OUT HANDLE * lphLockRequestInfo
  786. );
  787. BOOLAPI
  788. InternetUnlockRequestFile(
  789. IN HANDLE hLockRequestInfo
  790. );
  791. //
  792. // flags for InternetSetOptionEx()
  793. //
  794. #define ISO_GLOBAL 0x00000001 // modify option globally
  795. #define ISO_REGISTRY 0x00000002 // write option to registry (where applicable)
  796. #define ISO_VALID_FLAGS (ISO_GLOBAL | ISO_REGISTRY)
  797. //
  798. // options manifests for Internet{Query|Set}Option
  799. //
  800. #define INTERNET_OPTION_CALLBACK 1
  801. #define INTERNET_OPTION_CONNECT_TIMEOUT 2
  802. #define INTERNET_OPTION_CONNECT_RETRIES 3
  803. #define INTERNET_OPTION_CONNECT_BACKOFF 4
  804. #define INTERNET_OPTION_SEND_TIMEOUT 5
  805. #define INTERNET_OPTION_CONTROL_SEND_TIMEOUT INTERNET_OPTION_SEND_TIMEOUT
  806. #define INTERNET_OPTION_RECEIVE_TIMEOUT 6
  807. #define INTERNET_OPTION_CONTROL_RECEIVE_TIMEOUT INTERNET_OPTION_RECEIVE_TIMEOUT
  808. #define INTERNET_OPTION_DATA_SEND_TIMEOUT 7
  809. #define INTERNET_OPTION_DATA_RECEIVE_TIMEOUT 8
  810. #define INTERNET_OPTION_HANDLE_TYPE 9
  811. #define INTERNET_OPTION_LISTEN_TIMEOUT 11
  812. #define INTERNET_OPTION_READ_BUFFER_SIZE 12
  813. #define INTERNET_OPTION_WRITE_BUFFER_SIZE 13
  814. #define INTERNET_OPTION_ASYNC_ID 15
  815. #define INTERNET_OPTION_ASYNC_PRIORITY 16
  816. #define INTERNET_OPTION_PARENT_HANDLE 21
  817. #define INTERNET_OPTION_KEEP_CONNECTION 22
  818. #define INTERNET_OPTION_REQUEST_FLAGS 23
  819. #define INTERNET_OPTION_EXTENDED_ERROR 24
  820. #define INTERNET_OPTION_OFFLINE_MODE 26
  821. #define INTERNET_OPTION_CACHE_STREAM_HANDLE 27
  822. #define INTERNET_OPTION_USERNAME 28
  823. #define INTERNET_OPTION_PASSWORD 29
  824. #define INTERNET_OPTION_ASYNC 30
  825. #define INTERNET_OPTION_SECURITY_FLAGS 31
  826. #define INTERNET_OPTION_SECURITY_CERTIFICATE_STRUCT 32
  827. #define INTERNET_OPTION_DATAFILE_NAME 33
  828. #define INTERNET_OPTION_URL 34
  829. #define INTERNET_OPTION_SECURITY_CERTIFICATE 35
  830. #define INTERNET_OPTION_SECURITY_KEY_BITNESS 36
  831. #define INTERNET_OPTION_REFRESH 37
  832. #define INTERNET_OPTION_PROXY 38
  833. #define INTERNET_OPTION_SETTINGS_CHANGED 39
  834. #define INTERNET_OPTION_VERSION 40
  835. #define INTERNET_OPTION_USER_AGENT 41
  836. #define INTERNET_OPTION_END_BROWSER_SESSION 42
  837. #define INTERNET_OPTION_PROXY_USERNAME 43
  838. #define INTERNET_OPTION_PROXY_PASSWORD 44
  839. #define INTERNET_OPTION_CONTEXT_VALUE 45
  840. #define INTERNET_OPTION_CONNECT_LIMIT 46
  841. #define INTERNET_OPTION_SECURITY_SELECT_CLIENT_CERT 47
  842. #define INTERNET_OPTION_POLICY 48
  843. #define INTERNET_OPTION_DISCONNECTED_TIMEOUT 49
  844. #define INTERNET_OPTION_CONNECTED_STATE 50
  845. #define INTERNET_OPTION_IDLE_STATE 51
  846. #define INTERNET_OPTION_OFFLINE_SEMANTICS 52
  847. #define INTERNET_OPTION_SECONDARY_CACHE_KEY 53
  848. #define INTERNET_OPTION_CALLBACK_FILTER 54
  849. #define INTERNET_OPTION_CONNECT_TIME 55
  850. #define INTERNET_OPTION_SEND_THROUGHPUT 56
  851. #define INTERNET_OPTION_RECEIVE_THROUGHPUT 57
  852. #define INTERNET_OPTION_REQUEST_PRIORITY 58
  853. #define INTERNET_OPTION_HTTP_VERSION 59
  854. #define INTERNET_OPTION_RESET_URLCACHE_SESSION 60
  855. #define INTERNET_OPTION_ERROR_MASK 62
  856. #define INTERNET_FIRST_OPTION INTERNET_OPTION_CALLBACK
  857. #define INTERNET_LAST_OPTION INTERNET_OPTION_ERROR_MASK
  858. //
  859. // values for INTERNET_OPTION_PRIORITY
  860. //
  861. #define INTERNET_PRIORITY_FOREGROUND 1000
  862. //
  863. // handle types
  864. //
  865. #define INTERNET_HANDLE_TYPE_INTERNET 1
  866. #define INTERNET_HANDLE_TYPE_CONNECT_FTP 2
  867. #define INTERNET_HANDLE_TYPE_CONNECT_GOPHER 3
  868. #define INTERNET_HANDLE_TYPE_CONNECT_HTTP 4
  869. #define INTERNET_HANDLE_TYPE_FTP_FIND 5
  870. #define INTERNET_HANDLE_TYPE_FTP_FIND_HTML 6
  871. #define INTERNET_HANDLE_TYPE_FTP_FILE 7
  872. #define INTERNET_HANDLE_TYPE_FTP_FILE_HTML 8
  873. #define INTERNET_HANDLE_TYPE_GOPHER_FIND 9
  874. #define INTERNET_HANDLE_TYPE_GOPHER_FIND_HTML 10
  875. #define INTERNET_HANDLE_TYPE_GOPHER_FILE 11
  876. #define INTERNET_HANDLE_TYPE_GOPHER_FILE_HTML 12
  877. #define INTERNET_HANDLE_TYPE_HTTP_REQUEST 13
  878. //
  879. // values for INTERNET_OPTION_SECURITY_FLAGS
  880. //
  881. // query only
  882. #define SECURITY_FLAG_SECURE 0x00000001 // can query only
  883. #define SECURITY_FLAG_STRENGTH_WEAK 0x10000000
  884. #define SECURITY_FLAG_STRENGTH_MEDIUM 0x40000000
  885. #define SECURITY_FLAG_STRENGTH_STRONG 0x20000000
  886. #define SECURITY_FLAG_UNKNOWNBIT 0x80000000
  887. #define SECURITY_FLAG_NORMALBITNESS SECURITY_FLAG_STRENGTH_WEAK
  888. // The following are unused
  889. #define SECURITY_FLAG_SSL 0x00000002
  890. #define SECURITY_FLAG_SSL3 0x00000004
  891. #define SECURITY_FLAG_PCT 0x00000008
  892. #define SECURITY_FLAG_PCT4 0x00000010
  893. #define SECURITY_FLAG_IETFSSL4 0x00000020
  894. // The following are for backwards compatability only.
  895. #define SECURITY_FLAG_40BIT SECURITY_FLAG_STRENGTH_WEAK
  896. #define SECURITY_FLAG_128BIT SECURITY_FLAG_STRENGTH_STRONG
  897. #define SECURITY_FLAG_56BIT SECURITY_FLAG_STRENGTH_MEDIUM
  898. // setable flags
  899. #define SECURITY_FLAG_IGNORE_REVOCATION 0x00000080
  900. #define SECURITY_FLAG_IGNORE_UNKNOWN_CA 0x00000100
  901. #define SECURITY_FLAG_IGNORE_WRONG_USAGE 0x00000200
  902. #define SECURITY_FLAG_IGNORE_CERT_CN_INVALID INTERNET_FLAG_IGNORE_CERT_CN_INVALID
  903. #define SECURITY_FLAG_IGNORE_CERT_DATE_INVALID INTERNET_FLAG_IGNORE_CERT_DATE_INVALID
  904. #define SECURITY_FLAG_IGNORE_REDIRECT_TO_HTTPS INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTPS
  905. #define SECURITY_FLAG_IGNORE_REDIRECT_TO_HTTP INTERNET_FLAG_IGNORE_REDIRECT_TO_HTTP
  906. #define SECURITY_SET_MASK (SECURITY_FLAG_IGNORE_REVOCATION |\
  907. SECURITY_FLAG_IGNORE_UNKNOWN_CA |\
  908. SECURITY_FLAG_IGNORE_CERT_CN_INVALID |\
  909. SECURITY_FLAG_IGNORE_CERT_DATE_INVALID |\
  910. SECURITY_FLAG_IGNORE_WRONG_USAGE)
  911. BOOLAPI
  912. InternetGetLastResponseInfoA(
  913. OUT LPDWORD lpdwError,
  914. OUT LPSTR lpszBuffer OPTIONAL,
  915. IN OUT LPDWORD lpdwBufferLength
  916. );
  917. BOOLAPI
  918. InternetGetLastResponseInfoW(
  919. OUT LPDWORD lpdwError,
  920. OUT LPWSTR lpszBuffer OPTIONAL,
  921. IN OUT LPDWORD lpdwBufferLength
  922. );
  923. #ifdef UNICODE
  924. #define InternetGetLastResponseInfo InternetGetLastResponseInfoW
  925. #else
  926. #define InternetGetLastResponseInfo InternetGetLastResponseInfoA
  927. #endif // !UNICODE
  928. //
  929. // callback function for InternetSetStatusCallback
  930. //
  931. typedef
  932. VOID
  933. (CALLBACK * INTERNET_STATUS_CALLBACK)(
  934. IN HINTERNET hInternet,
  935. IN DWORD dwContext,
  936. IN DWORD dwInternetStatus,
  937. IN LPVOID lpvStatusInformation OPTIONAL,
  938. IN DWORD dwStatusInformationLength
  939. );
  940. typedef INTERNET_STATUS_CALLBACK * LPINTERNET_STATUS_CALLBACK;
  941. INTERNETAPI
  942. INTERNET_STATUS_CALLBACK
  943. WINAPI
  944. InternetSetStatusCallback(
  945. IN HINTERNET hInternet,
  946. IN INTERNET_STATUS_CALLBACK lpfnInternetCallback
  947. );
  948. //
  949. // status manifests for Internet status callback
  950. //
  951. #define INTERNET_STATUS_RESOLVING_NAME 10
  952. #define INTERNET_STATUS_NAME_RESOLVED 11
  953. #define INTERNET_STATUS_CONNECTING_TO_SERVER 20
  954. #define INTERNET_STATUS_CONNECTED_TO_SERVER 21
  955. #define INTERNET_STATUS_SENDING_REQUEST 30
  956. #define INTERNET_STATUS_REQUEST_SENT 31
  957. #define INTERNET_STATUS_RECEIVING_RESPONSE 40
  958. #define INTERNET_STATUS_RESPONSE_RECEIVED 41
  959. #define INTERNET_STATUS_CTL_RESPONSE_RECEIVED 42
  960. #define INTERNET_STATUS_PREFETCH 43
  961. #define INTERNET_STATUS_CLOSING_CONNECTION 50
  962. #define INTERNET_STATUS_CONNECTION_CLOSED 51
  963. #define INTERNET_STATUS_HANDLE_CREATED 60
  964. #define INTERNET_STATUS_HANDLE_CLOSING 70
  965. #define INTERNET_STATUS_REQUEST_COMPLETE 100
  966. #define INTERNET_STATUS_REDIRECT 110
  967. #define INTERNET_STATUS_INTERMEDIATE_RESPONSE 120
  968. #define INTERNET_STATUS_STATE_CHANGE 200
  969. //
  970. // the following can be indicated in a state change notification:
  971. //
  972. #define INTERNET_STATE_CONNECTED 0x00000001 // connected state (mutually exclusive with disconnected)
  973. #define INTERNET_STATE_DISCONNECTED 0x00000002 // disconnected from network
  974. #define INTERNET_STATE_DISCONNECTED_BY_USER 0x00000010 // disconnected by user request
  975. #define INTERNET_STATE_IDLE 0x00000100 // no network requests being made (by Wininet)
  976. #define INTERNET_STATE_BUSY 0x00000200 // network requests being made (by Wininet)
  977. //
  978. // if the following value is returned by InternetSetStatusCallback, then
  979. // probably an invalid (non-code) address was supplied for the callback
  980. //
  981. #define INTERNET_INVALID_STATUS_CALLBACK ((INTERNET_STATUS_CALLBACK)(-1L))
  982. //
  983. // FTP
  984. //
  985. //
  986. // manifests
  987. //
  988. #define FTP_TRANSFER_TYPE_UNKNOWN 0x00000000
  989. #define FTP_TRANSFER_TYPE_ASCII 0x00000001
  990. #define FTP_TRANSFER_TYPE_BINARY 0x00000002
  991. #define FTP_TRANSFER_TYPE_MASK (FTP_TRANSFER_TYPE_ASCII | FTP_TRANSFER_TYPE_BINARY)
  992. //
  993. // prototypes
  994. //
  995. INTERNETAPI
  996. HINTERNET
  997. WINAPI
  998. FtpFindFirstFileA(
  999. IN HINTERNET hConnect,
  1000. IN LPCSTR lpszSearchFile OPTIONAL,
  1001. OUT LPWIN32_FIND_DATA lpFindFileData OPTIONAL,
  1002. IN DWORD dwFlags,
  1003. IN DWORD dwContext
  1004. );
  1005. INTERNETAPI
  1006. HINTERNET
  1007. WINAPI
  1008. FtpFindFirstFileW(
  1009. IN HINTERNET hConnect,
  1010. IN LPCWSTR lpszSearchFile OPTIONAL,
  1011. OUT LPWIN32_FIND_DATA lpFindFileData OPTIONAL,
  1012. IN DWORD dwFlags,
  1013. IN DWORD dwContext
  1014. );
  1015. #ifdef UNICODE
  1016. #define FtpFindFirstFile FtpFindFirstFileW
  1017. #else
  1018. #define FtpFindFirstFile FtpFindFirstFileA
  1019. #endif // !UNICODE
  1020. BOOLAPI
  1021. FtpGetFileA(
  1022. IN HINTERNET hConnect,
  1023. IN LPCSTR lpszRemoteFile,
  1024. IN LPCSTR lpszNewFile,
  1025. IN BOOL fFailIfExists,
  1026. IN DWORD dwFlagsAndAttributes,
  1027. IN DWORD dwFlags,
  1028. IN DWORD dwContext
  1029. );
  1030. BOOLAPI
  1031. FtpGetFileW(
  1032. IN HINTERNET hConnect,
  1033. IN LPCWSTR lpszRemoteFile,
  1034. IN LPCWSTR lpszNewFile,
  1035. IN BOOL fFailIfExists,
  1036. IN DWORD dwFlagsAndAttributes,
  1037. IN DWORD dwFlags,
  1038. IN DWORD dwContext
  1039. );
  1040. #ifdef UNICODE
  1041. #define FtpGetFile FtpGetFileW
  1042. #else
  1043. #define FtpGetFile FtpGetFileA
  1044. #endif // !UNICODE
  1045. BOOLAPI
  1046. FtpPutFileA(
  1047. IN HINTERNET hConnect,
  1048. IN LPCSTR lpszLocalFile,
  1049. IN LPCSTR lpszNewRemoteFile,
  1050. IN DWORD dwFlags,
  1051. IN DWORD dwContext
  1052. );
  1053. BOOLAPI
  1054. FtpPutFileW(
  1055. IN HINTERNET hConnect,
  1056. IN LPCWSTR lpszLocalFile,
  1057. IN LPCWSTR lpszNewRemoteFile,
  1058. IN DWORD dwFlags,
  1059. IN DWORD dwContext
  1060. );
  1061. #ifdef UNICODE
  1062. #define FtpPutFile FtpPutFileW
  1063. #else
  1064. #define FtpPutFile FtpPutFileA
  1065. #endif // !UNICODE
  1066. BOOLAPI
  1067. FtpDeleteFileA(
  1068. IN HINTERNET hConnect,
  1069. IN LPCSTR lpszFileName
  1070. );
  1071. BOOLAPI
  1072. FtpDeleteFileW(
  1073. IN HINTERNET hConnect,
  1074. IN LPCWSTR lpszFileName
  1075. );
  1076. #ifdef UNICODE
  1077. #define FtpDeleteFile FtpDeleteFileW
  1078. #else
  1079. #define FtpDeleteFile FtpDeleteFileA
  1080. #endif // !UNICODE
  1081. BOOLAPI
  1082. FtpRenameFileA(
  1083. IN HINTERNET hConnect,
  1084. IN LPCSTR lpszExisting,
  1085. IN LPCSTR lpszNew
  1086. );
  1087. BOOLAPI
  1088. FtpRenameFileW(
  1089. IN HINTERNET hConnect,
  1090. IN LPCWSTR lpszExisting,
  1091. IN LPCWSTR lpszNew
  1092. );
  1093. #ifdef UNICODE
  1094. #define FtpRenameFile FtpRenameFileW
  1095. #else
  1096. #define FtpRenameFile FtpRenameFileA
  1097. #endif // !UNICODE
  1098. INTERNETAPI
  1099. HINTERNET
  1100. WINAPI
  1101. FtpOpenFileA(
  1102. IN HINTERNET hConnect,
  1103. IN LPCSTR lpszFileName,
  1104. IN DWORD dwAccess,
  1105. IN DWORD dwFlags,
  1106. IN DWORD dwContext
  1107. );
  1108. INTERNETAPI
  1109. HINTERNET
  1110. WINAPI
  1111. FtpOpenFileW(
  1112. IN HINTERNET hConnect,
  1113. IN LPCWSTR lpszFileName,
  1114. IN DWORD dwAccess,
  1115. IN DWORD dwFlags,
  1116. IN DWORD dwContext
  1117. );
  1118. #ifdef UNICODE
  1119. #define FtpOpenFile FtpOpenFileW
  1120. #else
  1121. #define FtpOpenFile FtpOpenFileA
  1122. #endif // !UNICODE
  1123. BOOLAPI
  1124. FtpCreateDirectoryA(
  1125. IN HINTERNET hConnect,
  1126. IN LPCSTR lpszDirectory
  1127. );
  1128. BOOLAPI
  1129. FtpCreateDirectoryW(
  1130. IN HINTERNET hConnect,
  1131. IN LPCWSTR lpszDirectory
  1132. );
  1133. #ifdef UNICODE
  1134. #define FtpCreateDirectory FtpCreateDirectoryW
  1135. #else
  1136. #define FtpCreateDirectory FtpCreateDirectoryA
  1137. #endif // !UNICODE
  1138. BOOLAPI
  1139. FtpRemoveDirectoryA(
  1140. IN HINTERNET hConnect,
  1141. IN LPCSTR lpszDirectory
  1142. );
  1143. BOOLAPI
  1144. FtpRemoveDirectoryW(
  1145. IN HINTERNET hConnect,
  1146. IN LPCWSTR lpszDirectory
  1147. );
  1148. #ifdef UNICODE
  1149. #define FtpRemoveDirectory FtpRemoveDirectoryW
  1150. #else
  1151. #define FtpRemoveDirectory FtpRemoveDirectoryA
  1152. #endif // !UNICODE
  1153. BOOLAPI
  1154. FtpSetCurrentDirectoryA(
  1155. IN HINTERNET hConnect,
  1156. IN LPCSTR lpszDirectory
  1157. );
  1158. BOOLAPI
  1159. FtpSetCurrentDirectoryW(
  1160. IN HINTERNET hConnect,
  1161. IN LPCWSTR lpszDirectory
  1162. );
  1163. #ifdef UNICODE
  1164. #define FtpSetCurrentDirectory FtpSetCurrentDirectoryW
  1165. #else
  1166. #define FtpSetCurrentDirectory FtpSetCurrentDirectoryA
  1167. #endif // !UNICODE
  1168. BOOLAPI
  1169. FtpGetCurrentDirectoryA(
  1170. IN HINTERNET hConnect,
  1171. OUT LPSTR lpszCurrentDirectory,
  1172. IN OUT LPDWORD lpdwCurrentDirectory
  1173. );
  1174. BOOLAPI
  1175. FtpGetCurrentDirectoryW(
  1176. IN HINTERNET hConnect,
  1177. OUT LPWSTR lpszCurrentDirectory,
  1178. IN OUT LPDWORD lpdwCurrentDirectory
  1179. );
  1180. #ifdef UNICODE
  1181. #define FtpGetCurrentDirectory FtpGetCurrentDirectoryW
  1182. #else
  1183. #define FtpGetCurrentDirectory FtpGetCurrentDirectoryA
  1184. #endif // !UNICODE
  1185. //
  1186. // Gopher
  1187. //
  1188. //
  1189. // manifests
  1190. //
  1191. //
  1192. // string field lengths (in characters, not bytes)
  1193. //
  1194. #define MAX_GOPHER_DISPLAY_TEXT 128
  1195. #define MAX_GOPHER_SELECTOR_TEXT 256
  1196. #define MAX_GOPHER_HOST_NAME INTERNET_MAX_HOST_NAME_LENGTH
  1197. #define MAX_GOPHER_LOCATOR_LENGTH (1 \
  1198. + MAX_GOPHER_DISPLAY_TEXT \
  1199. + 1 \
  1200. + MAX_GOPHER_SELECTOR_TEXT \
  1201. + 1 \
  1202. + MAX_GOPHER_HOST_NAME \
  1203. + 1 \
  1204. + INTERNET_MAX_PORT_NUMBER_LENGTH \
  1205. + 1 \
  1206. + 1 \
  1207. + 2 \
  1208. )
  1209. //
  1210. // structures/types
  1211. //
  1212. //
  1213. // GOPHER_FIND_DATA - returns the results of a GopherFindFirstFile()/
  1214. // InternetFindNextFile() request
  1215. //
  1216. typedef struct {
  1217. CHAR DisplayString[MAX_GOPHER_DISPLAY_TEXT + 1];
  1218. DWORD GopherType; // GOPHER_TYPE_, if known
  1219. DWORD SizeLow;
  1220. DWORD SizeHigh;
  1221. FILETIME LastModificationTime;
  1222. CHAR Locator[MAX_GOPHER_LOCATOR_LENGTH + 1];
  1223. } GOPHER_FIND_DATAA, * LPGOPHER_FIND_DATAA;
  1224. typedef struct {
  1225. WCHAR DisplayString[MAX_GOPHER_DISPLAY_TEXT + 1];
  1226. DWORD GopherType; // GOPHER_TYPE_, if known
  1227. DWORD SizeLow;
  1228. DWORD SizeHigh;
  1229. FILETIME LastModificationTime;
  1230. WCHAR Locator[MAX_GOPHER_LOCATOR_LENGTH + 1];
  1231. } GOPHER_FIND_DATAW, * LPGOPHER_FIND_DATAW;
  1232. #ifdef UNICODE
  1233. typedef GOPHER_FIND_DATAW GOPHER_FIND_DATA;
  1234. typedef LPGOPHER_FIND_DATAW LPGOPHER_FIND_DATA;
  1235. #else
  1236. typedef GOPHER_FIND_DATAA GOPHER_FIND_DATA;
  1237. typedef LPGOPHER_FIND_DATAA LPGOPHER_FIND_DATA;
  1238. #endif // UNICODE
  1239. //
  1240. // manifests for GopherType
  1241. //
  1242. #define GOPHER_TYPE_TEXT_FILE 0x00000001
  1243. #define GOPHER_TYPE_DIRECTORY 0x00000002
  1244. #define GOPHER_TYPE_CSO 0x00000004
  1245. #define GOPHER_TYPE_ERROR 0x00000008
  1246. #define GOPHER_TYPE_MAC_BINHEX 0x00000010
  1247. #define GOPHER_TYPE_DOS_ARCHIVE 0x00000020
  1248. #define GOPHER_TYPE_UNIX_UUENCODED 0x00000040
  1249. #define GOPHER_TYPE_INDEX_SERVER 0x00000080
  1250. #define GOPHER_TYPE_TELNET 0x00000100
  1251. #define GOPHER_TYPE_BINARY 0x00000200
  1252. #define GOPHER_TYPE_REDUNDANT 0x00000400
  1253. #define GOPHER_TYPE_TN3270 0x00000800
  1254. #define GOPHER_TYPE_GIF 0x00001000
  1255. #define GOPHER_TYPE_IMAGE 0x00002000
  1256. #define GOPHER_TYPE_BITMAP 0x00004000
  1257. #define GOPHER_TYPE_MOVIE 0x00008000
  1258. #define GOPHER_TYPE_SOUND 0x00010000
  1259. #define GOPHER_TYPE_HTML 0x00020000
  1260. #define GOPHER_TYPE_PDF 0x00040000
  1261. #define GOPHER_TYPE_CALENDAR 0x00080000
  1262. #define GOPHER_TYPE_INLINE 0x00100000
  1263. #define GOPHER_TYPE_UNKNOWN 0x20000000
  1264. #define GOPHER_TYPE_ASK 0x40000000
  1265. #define GOPHER_TYPE_GOPHER_PLUS 0x80000000
  1266. //
  1267. // gopher type macros
  1268. //
  1269. #define IS_GOPHER_FILE(type) (BOOL)(((type) & GOPHER_TYPE_FILE_MASK) ? TRUE : FALSE)
  1270. #define IS_GOPHER_DIRECTORY(type) (BOOL)(((type) & GOPHER_TYPE_DIRECTORY) ? TRUE : FALSE)
  1271. #define IS_GOPHER_PHONE_SERVER(type) (BOOL)(((type) & GOPHER_TYPE_CSO) ? TRUE : FALSE)
  1272. #define IS_GOPHER_ERROR(type) (BOOL)(((type) & GOPHER_TYPE_ERROR) ? TRUE : FALSE)
  1273. #define IS_GOPHER_INDEX_SERVER(type) (BOOL)(((type) & GOPHER_TYPE_INDEX_SERVER) ? TRUE : FALSE)
  1274. #define IS_GOPHER_TELNET_SESSION(type) (BOOL)(((type) & GOPHER_TYPE_TELNET) ? TRUE : FALSE)
  1275. #define IS_GOPHER_BACKUP_SERVER(type) (BOOL)(((type) & GOPHER_TYPE_REDUNDANT) ? TRUE : FALSE)
  1276. #define IS_GOPHER_TN3270_SESSION(type) (BOOL)(((type) & GOPHER_TYPE_TN3270) ? TRUE : FALSE)
  1277. #define IS_GOPHER_ASK(type) (BOOL)(((type) & GOPHER_TYPE_ASK) ? TRUE : FALSE)
  1278. #define IS_GOPHER_PLUS(type) (BOOL)(((type) & GOPHER_TYPE_GOPHER_PLUS) ? TRUE : FALSE)
  1279. #define IS_GOPHER_TYPE_KNOWN(type) (BOOL)(((type) & GOPHER_TYPE_UNKNOWN) ? FALSE : TRUE)
  1280. //
  1281. // GOPHER_TYPE_FILE_MASK - use this to determine if a locator identifies a
  1282. // (known) file type
  1283. //
  1284. #define GOPHER_TYPE_FILE_MASK (GOPHER_TYPE_TEXT_FILE \
  1285. | GOPHER_TYPE_MAC_BINHEX \
  1286. | GOPHER_TYPE_DOS_ARCHIVE \
  1287. | GOPHER_TYPE_UNIX_UUENCODED \
  1288. | GOPHER_TYPE_BINARY \
  1289. | GOPHER_TYPE_GIF \
  1290. | GOPHER_TYPE_IMAGE \
  1291. | GOPHER_TYPE_BITMAP \
  1292. | GOPHER_TYPE_MOVIE \
  1293. | GOPHER_TYPE_SOUND \
  1294. | GOPHER_TYPE_HTML \
  1295. | GOPHER_TYPE_PDF \
  1296. | GOPHER_TYPE_CALENDAR \
  1297. | GOPHER_TYPE_INLINE \
  1298. )
  1299. //
  1300. // structured gopher attributes (as defined in gopher+ protocol document)
  1301. //
  1302. typedef struct {
  1303. LPCTSTR Comment;
  1304. LPCTSTR EmailAddress;
  1305. } GOPHER_ADMIN_ATTRIBUTE_TYPE, * LPGOPHER_ADMIN_ATTRIBUTE_TYPE;
  1306. typedef struct {
  1307. FILETIME DateAndTime;
  1308. } GOPHER_MOD_DATE_ATTRIBUTE_TYPE, * LPGOPHER_MOD_DATE_ATTRIBUTE_TYPE;
  1309. typedef struct {
  1310. DWORD Ttl;
  1311. } GOPHER_TTL_ATTRIBUTE_TYPE, * LPGOPHER_TTL_ATTRIBUTE_TYPE;
  1312. typedef struct {
  1313. INT Score;
  1314. } GOPHER_SCORE_ATTRIBUTE_TYPE, * LPGOPHER_SCORE_ATTRIBUTE_TYPE;
  1315. typedef struct {
  1316. INT LowerBound;
  1317. INT UpperBound;
  1318. } GOPHER_SCORE_RANGE_ATTRIBUTE_TYPE, * LPGOPHER_SCORE_RANGE_ATTRIBUTE_TYPE;
  1319. typedef struct {
  1320. LPCTSTR Site;
  1321. } GOPHER_SITE_ATTRIBUTE_TYPE, * LPGOPHER_SITE_ATTRIBUTE_TYPE;
  1322. typedef struct {
  1323. LPCTSTR Organization;
  1324. } GOPHER_ORGANIZATION_ATTRIBUTE_TYPE, * LPGOPHER_ORGANIZATION_ATTRIBUTE_TYPE;
  1325. typedef struct {
  1326. LPCTSTR Location;
  1327. } GOPHER_LOCATION_ATTRIBUTE_TYPE, * LPGOPHER_LOCATION_ATTRIBUTE_TYPE;
  1328. typedef struct {
  1329. INT DegreesNorth;
  1330. INT MinutesNorth;
  1331. INT SecondsNorth;
  1332. INT DegreesEast;
  1333. INT MinutesEast;
  1334. INT SecondsEast;
  1335. } GOPHER_GEOGRAPHICAL_LOCATION_ATTRIBUTE_TYPE, * LPGOPHER_GEOGRAPHICAL_LOCATION_ATTRIBUTE_TYPE;
  1336. typedef struct {
  1337. INT Zone;
  1338. } GOPHER_TIMEZONE_ATTRIBUTE_TYPE, * LPGOPHER_TIMEZONE_ATTRIBUTE_TYPE;
  1339. typedef struct {
  1340. LPCTSTR Provider;
  1341. } GOPHER_PROVIDER_ATTRIBUTE_TYPE, * LPGOPHER_PROVIDER_ATTRIBUTE_TYPE;
  1342. typedef struct {
  1343. LPCTSTR Version;
  1344. } GOPHER_VERSION_ATTRIBUTE_TYPE, * LPGOPHER_VERSION_ATTRIBUTE_TYPE;
  1345. typedef struct {
  1346. LPCTSTR ShortAbstract;
  1347. LPCTSTR AbstractFile;
  1348. } GOPHER_ABSTRACT_ATTRIBUTE_TYPE, * LPGOPHER_ABSTRACT_ATTRIBUTE_TYPE;
  1349. typedef struct {
  1350. LPCTSTR ContentType;
  1351. LPCTSTR Language;
  1352. DWORD Size;
  1353. } GOPHER_VIEW_ATTRIBUTE_TYPE, * LPGOPHER_VIEW_ATTRIBUTE_TYPE;
  1354. typedef struct {
  1355. BOOL TreeWalk;
  1356. } GOPHER_VERONICA_ATTRIBUTE_TYPE, * LPGOPHER_VERONICA_ATTRIBUTE_TYPE;
  1357. typedef struct {
  1358. LPCTSTR QuestionType;
  1359. LPCTSTR QuestionText;
  1360. } GOPHER_ASK_ATTRIBUTE_TYPE, * LPGOPHER_ASK_ATTRIBUTE_TYPE;
  1361. //
  1362. // GOPHER_UNKNOWN_ATTRIBUTE_TYPE - this is returned if we retrieve an attribute
  1363. // that is not specified in the current gopher/gopher+ documentation. It is up
  1364. // to the application to parse the information
  1365. //
  1366. typedef struct {
  1367. LPCTSTR Text;
  1368. } GOPHER_UNKNOWN_ATTRIBUTE_TYPE, * LPGOPHER_UNKNOWN_ATTRIBUTE_TYPE;
  1369. //
  1370. // GOPHER_ATTRIBUTE_TYPE - returned in the user's buffer when an enumerated
  1371. // GopherGetAttribute call is made
  1372. //
  1373. typedef struct {
  1374. DWORD CategoryId; // e.g. GOPHER_CATEGORY_ID_ADMIN
  1375. DWORD AttributeId; // e.g. GOPHER_ATTRIBUTE_ID_ADMIN
  1376. union {
  1377. GOPHER_ADMIN_ATTRIBUTE_TYPE Admin;
  1378. GOPHER_MOD_DATE_ATTRIBUTE_TYPE ModDate;
  1379. GOPHER_TTL_ATTRIBUTE_TYPE Ttl;
  1380. GOPHER_SCORE_ATTRIBUTE_TYPE Score;
  1381. GOPHER_SCORE_RANGE_ATTRIBUTE_TYPE ScoreRange;
  1382. GOPHER_SITE_ATTRIBUTE_TYPE Site;
  1383. GOPHER_ORGANIZATION_ATTRIBUTE_TYPE Organization;
  1384. GOPHER_LOCATION_ATTRIBUTE_TYPE Location;
  1385. GOPHER_GEOGRAPHICAL_LOCATION_ATTRIBUTE_TYPE GeographicalLocation;
  1386. GOPHER_TIMEZONE_ATTRIBUTE_TYPE TimeZone;
  1387. GOPHER_PROVIDER_ATTRIBUTE_TYPE Provider;
  1388. GOPHER_VERSION_ATTRIBUTE_TYPE Version;
  1389. GOPHER_ABSTRACT_ATTRIBUTE_TYPE Abstract;
  1390. GOPHER_VIEW_ATTRIBUTE_TYPE View;
  1391. GOPHER_VERONICA_ATTRIBUTE_TYPE Veronica;
  1392. GOPHER_ASK_ATTRIBUTE_TYPE Ask;
  1393. GOPHER_UNKNOWN_ATTRIBUTE_TYPE Unknown;
  1394. } AttributeType;
  1395. } GOPHER_ATTRIBUTE_TYPE, * LPGOPHER_ATTRIBUTE_TYPE;
  1396. #define MAX_GOPHER_CATEGORY_NAME 128 // arbitrary
  1397. #define MAX_GOPHER_ATTRIBUTE_NAME 128 // "
  1398. #define MIN_GOPHER_ATTRIBUTE_LENGTH 256 // "
  1399. //
  1400. // known gopher attribute categories. See below for ordinals
  1401. //
  1402. #define GOPHER_INFO_CATEGORY TEXT("+INFO")
  1403. #define GOPHER_ADMIN_CATEGORY TEXT("+ADMIN")
  1404. #define GOPHER_VIEWS_CATEGORY TEXT("+VIEWS")
  1405. #define GOPHER_ABSTRACT_CATEGORY TEXT("+ABSTRACT")
  1406. #define GOPHER_VERONICA_CATEGORY TEXT("+VERONICA")
  1407. //
  1408. // known gopher attributes. These are the attribute names as defined in the
  1409. // gopher+ protocol document
  1410. //
  1411. #define GOPHER_ADMIN_ATTRIBUTE TEXT("Admin")
  1412. #define GOPHER_MOD_DATE_ATTRIBUTE TEXT("Mod-Date")
  1413. #define GOPHER_TTL_ATTRIBUTE TEXT("TTL")
  1414. #define GOPHER_SCORE_ATTRIBUTE TEXT("Score")
  1415. #define GOPHER_RANGE_ATTRIBUTE TEXT("Score-range")
  1416. #define GOPHER_SITE_ATTRIBUTE TEXT("Site")
  1417. #define GOPHER_ORG_ATTRIBUTE TEXT("Org")
  1418. #define GOPHER_LOCATION_ATTRIBUTE TEXT("Loc")
  1419. #define GOPHER_GEOG_ATTRIBUTE TEXT("Geog")
  1420. #define GOPHER_TIMEZONE_ATTRIBUTE TEXT("TZ")
  1421. #define GOPHER_PROVIDER_ATTRIBUTE TEXT("Provider")
  1422. #define GOPHER_VERSION_ATTRIBUTE TEXT("Version")
  1423. #define GOPHER_ABSTRACT_ATTRIBUTE TEXT("Abstract")
  1424. #define GOPHER_VIEW_ATTRIBUTE TEXT("View")
  1425. #define GOPHER_TREEWALK_ATTRIBUTE TEXT("treewalk")
  1426. //
  1427. // identifiers for attribute strings
  1428. //
  1429. #define GOPHER_ATTRIBUTE_ID_BASE 0xabcccc00
  1430. #define GOPHER_CATEGORY_ID_ALL (GOPHER_ATTRIBUTE_ID_BASE + 1)
  1431. #define GOPHER_CATEGORY_ID_INFO (GOPHER_ATTRIBUTE_ID_BASE + 2)
  1432. #define GOPHER_CATEGORY_ID_ADMIN (GOPHER_ATTRIBUTE_ID_BASE + 3)
  1433. #define GOPHER_CATEGORY_ID_VIEWS (GOPHER_ATTRIBUTE_ID_BASE + 4)
  1434. #define GOPHER_CATEGORY_ID_ABSTRACT (GOPHER_ATTRIBUTE_ID_BASE + 5)
  1435. #define GOPHER_CATEGORY_ID_VERONICA (GOPHER_ATTRIBUTE_ID_BASE + 6)
  1436. #define GOPHER_CATEGORY_ID_ASK (GOPHER_ATTRIBUTE_ID_BASE + 7)
  1437. #define GOPHER_CATEGORY_ID_UNKNOWN (GOPHER_ATTRIBUTE_ID_BASE + 8)
  1438. #define GOPHER_ATTRIBUTE_ID_ALL (GOPHER_ATTRIBUTE_ID_BASE + 9)
  1439. #define GOPHER_ATTRIBUTE_ID_ADMIN (GOPHER_ATTRIBUTE_ID_BASE + 10)
  1440. #define GOPHER_ATTRIBUTE_ID_MOD_DATE (GOPHER_ATTRIBUTE_ID_BASE + 11)
  1441. #define GOPHER_ATTRIBUTE_ID_TTL (GOPHER_ATTRIBUTE_ID_BASE + 12)
  1442. #define GOPHER_ATTRIBUTE_ID_SCORE (GOPHER_ATTRIBUTE_ID_BASE + 13)
  1443. #define GOPHER_ATTRIBUTE_ID_RANGE (GOPHER_ATTRIBUTE_ID_BASE + 14)
  1444. #define GOPHER_ATTRIBUTE_ID_SITE (GOPHER_ATTRIBUTE_ID_BASE + 15)
  1445. #define GOPHER_ATTRIBUTE_ID_ORG (GOPHER_ATTRIBUTE_ID_BASE + 16)
  1446. #define GOPHER_ATTRIBUTE_ID_LOCATION (GOPHER_ATTRIBUTE_ID_BASE + 17)
  1447. #define GOPHER_ATTRIBUTE_ID_GEOG (GOPHER_ATTRIBUTE_ID_BASE + 18)
  1448. #define GOPHER_ATTRIBUTE_ID_TIMEZONE (GOPHER_ATTRIBUTE_ID_BASE + 19)
  1449. #define GOPHER_ATTRIBUTE_ID_PROVIDER (GOPHER_ATTRIBUTE_ID_BASE + 20)
  1450. #define GOPHER_ATTRIBUTE_ID_VERSION (GOPHER_ATTRIBUTE_ID_BASE + 21)
  1451. #define GOPHER_ATTRIBUTE_ID_ABSTRACT (GOPHER_ATTRIBUTE_ID_BASE + 22)
  1452. #define GOPHER_ATTRIBUTE_ID_VIEW (GOPHER_ATTRIBUTE_ID_BASE + 23)
  1453. #define GOPHER_ATTRIBUTE_ID_TREEWALK (GOPHER_ATTRIBUTE_ID_BASE + 24)
  1454. #define GOPHER_ATTRIBUTE_ID_UNKNOWN (GOPHER_ATTRIBUTE_ID_BASE + 25)
  1455. //
  1456. // prototypes
  1457. //
  1458. BOOLAPI
  1459. GopherCreateLocatorA(
  1460. IN LPCSTR lpszHost,
  1461. IN INTERNET_PORT nServerPort,
  1462. IN LPCSTR lpszDisplayString OPTIONAL,
  1463. IN LPCSTR lpszSelectorString OPTIONAL,
  1464. IN DWORD dwGopherType,
  1465. OUT LPSTR lpszLocator OPTIONAL,
  1466. IN OUT LPDWORD lpdwBufferLength
  1467. );
  1468. BOOLAPI
  1469. GopherCreateLocatorW(
  1470. IN LPCWSTR lpszHost,
  1471. IN INTERNET_PORT nServerPort,
  1472. IN LPCWSTR lpszDisplayString OPTIONAL,
  1473. IN LPCWSTR lpszSelectorString OPTIONAL,
  1474. IN DWORD dwGopherType,
  1475. OUT LPWSTR lpszLocator OPTIONAL,
  1476. IN OUT LPDWORD lpdwBufferLength
  1477. );
  1478. #ifdef UNICODE
  1479. #define GopherCreateLocator GopherCreateLocatorW
  1480. #else
  1481. #define GopherCreateLocator GopherCreateLocatorA
  1482. #endif // !UNICODE
  1483. BOOLAPI
  1484. GopherGetLocatorTypeA(
  1485. IN LPCSTR lpszLocator,
  1486. OUT LPDWORD lpdwGopherType
  1487. );
  1488. BOOLAPI
  1489. GopherGetLocatorTypeW(
  1490. IN LPCWSTR lpszLocator,
  1491. OUT LPDWORD lpdwGopherType
  1492. );
  1493. #ifdef UNICODE
  1494. #define GopherGetLocatorType GopherGetLocatorTypeW
  1495. #else
  1496. #define GopherGetLocatorType GopherGetLocatorTypeA
  1497. #endif // !UNICODE
  1498. INTERNETAPI
  1499. HINTERNET
  1500. WINAPI
  1501. GopherFindFirstFileA(
  1502. IN HINTERNET hConnect,
  1503. IN LPCSTR lpszLocator OPTIONAL,
  1504. IN LPCSTR lpszSearchString OPTIONAL,
  1505. OUT LPGOPHER_FIND_DATAA lpFindData OPTIONAL,
  1506. IN DWORD dwFlags,
  1507. IN DWORD dwContext
  1508. );
  1509. INTERNETAPI
  1510. HINTERNET
  1511. WINAPI
  1512. GopherFindFirstFileW(
  1513. IN HINTERNET hConnect,
  1514. IN LPCWSTR lpszLocator OPTIONAL,
  1515. IN LPCWSTR lpszSearchString OPTIONAL,
  1516. OUT LPGOPHER_FIND_DATAW lpFindData OPTIONAL,
  1517. IN DWORD dwFlags,
  1518. IN DWORD dwContext
  1519. );
  1520. #ifdef UNICODE
  1521. #define GopherFindFirstFile GopherFindFirstFileW
  1522. #else
  1523. #define GopherFindFirstFile GopherFindFirstFileA
  1524. #endif // !UNICODE
  1525. INTERNETAPI
  1526. HINTERNET
  1527. WINAPI
  1528. GopherOpenFileA(
  1529. IN HINTERNET hConnect,
  1530. IN LPCSTR lpszLocator,
  1531. IN LPCSTR lpszView OPTIONAL,
  1532. IN DWORD dwFlags,
  1533. IN DWORD dwContext
  1534. );
  1535. INTERNETAPI
  1536. HINTERNET
  1537. WINAPI
  1538. GopherOpenFileW(
  1539. IN HINTERNET hConnect,
  1540. IN LPCWSTR lpszLocator,
  1541. IN LPCWSTR lpszView OPTIONAL,
  1542. IN DWORD dwFlags,
  1543. IN DWORD dwContext
  1544. );
  1545. #ifdef UNICODE
  1546. #define GopherOpenFile GopherOpenFileW
  1547. #else
  1548. #define GopherOpenFile GopherOpenFileA
  1549. #endif // !UNICODE
  1550. typedef
  1551. BOOL
  1552. (CALLBACK * GOPHER_ATTRIBUTE_ENUMERATOR)(
  1553. LPGOPHER_ATTRIBUTE_TYPE lpAttributeInfo,
  1554. DWORD dwError
  1555. );
  1556. BOOLAPI
  1557. GopherGetAttributeA(
  1558. IN HINTERNET hConnect,
  1559. IN LPCSTR lpszLocator,
  1560. IN LPCSTR lpszAttributeName OPTIONAL,
  1561. OUT LPBYTE lpBuffer,
  1562. IN DWORD dwBufferLength,
  1563. OUT LPDWORD lpdwCharactersReturned,
  1564. IN GOPHER_ATTRIBUTE_ENUMERATOR lpfnEnumerator OPTIONAL,
  1565. IN DWORD dwContext
  1566. );
  1567. BOOLAPI
  1568. GopherGetAttributeW(
  1569. IN HINTERNET hConnect,
  1570. IN LPCWSTR lpszLocator,
  1571. IN LPCWSTR lpszAttributeName OPTIONAL,
  1572. OUT LPBYTE lpBuffer,
  1573. IN DWORD dwBufferLength,
  1574. OUT LPDWORD lpdwCharactersReturned,
  1575. IN GOPHER_ATTRIBUTE_ENUMERATOR lpfnEnumerator OPTIONAL,
  1576. IN DWORD dwContext
  1577. );
  1578. #ifdef UNICODE
  1579. #define GopherGetAttribute GopherGetAttributeW
  1580. #else
  1581. #define GopherGetAttribute GopherGetAttributeA
  1582. #endif // !UNICODE
  1583. //
  1584. // HTTP
  1585. //
  1586. //
  1587. // manifests
  1588. //
  1589. //
  1590. // the default major/minor HTTP version numbers
  1591. //
  1592. #define HTTP_MAJOR_VERSION 1
  1593. #define HTTP_MINOR_VERSION 0
  1594. #define HTTP_VERSION TEXT("HTTP/1.0")
  1595. //
  1596. // HttpQueryInfo info levels. Generally, there is one info level
  1597. // for each potential RFC822/HTTP/MIME header that an HTTP server
  1598. // may send as part of a request response.
  1599. //
  1600. // The HTTP_QUERY_RAW_HEADERS info level is provided for clients
  1601. // that choose to perform their own header parsing.
  1602. //
  1603. #define HTTP_QUERY_MIME_VERSION 0
  1604. #define HTTP_QUERY_CONTENT_TYPE 1
  1605. #define HTTP_QUERY_CONTENT_TRANSFER_ENCODING 2
  1606. #define HTTP_QUERY_CONTENT_ID 3
  1607. #define HTTP_QUERY_CONTENT_DESCRIPTION 4
  1608. #define HTTP_QUERY_CONTENT_LENGTH 5
  1609. #define HTTP_QUERY_CONTENT_LANGUAGE 6
  1610. #define HTTP_QUERY_ALLOW 7
  1611. #define HTTP_QUERY_PUBLIC 8
  1612. #define HTTP_QUERY_DATE 9
  1613. #define HTTP_QUERY_EXPIRES 10
  1614. #define HTTP_QUERY_LAST_MODIFIED 11
  1615. #define HTTP_QUERY_MESSAGE_ID 12
  1616. #define HTTP_QUERY_URI 13
  1617. #define HTTP_QUERY_DERIVED_FROM 14
  1618. #define HTTP_QUERY_COST 15
  1619. #define HTTP_QUERY_LINK 16
  1620. #define HTTP_QUERY_PRAGMA 17
  1621. #define HTTP_QUERY_VERSION 18 // special: part of status line
  1622. #define HTTP_QUERY_STATUS_CODE 19 // special: part of status line
  1623. #define HTTP_QUERY_STATUS_TEXT 20 // special: part of status line
  1624. #define HTTP_QUERY_RAW_HEADERS 21 // special: all headers as ASCIIZ
  1625. #define HTTP_QUERY_RAW_HEADERS_CRLF 22 // special: all headers
  1626. #define HTTP_QUERY_CONNECTION 23
  1627. #define HTTP_QUERY_ACCEPT 24
  1628. #define HTTP_QUERY_ACCEPT_CHARSET 25
  1629. #define HTTP_QUERY_ACCEPT_ENCODING 26
  1630. #define HTTP_QUERY_ACCEPT_LANGUAGE 27
  1631. #define HTTP_QUERY_AUTHORIZATION 28
  1632. #define HTTP_QUERY_CONTENT_ENCODING 29
  1633. #define HTTP_QUERY_FORWARDED 30
  1634. #define HTTP_QUERY_FROM 31
  1635. #define HTTP_QUERY_IF_MODIFIED_SINCE 32
  1636. #define HTTP_QUERY_LOCATION 33
  1637. #define HTTP_QUERY_ORIG_URI 34
  1638. #define HTTP_QUERY_REFERER 35
  1639. #define HTTP_QUERY_RETRY_AFTER 36
  1640. #define HTTP_QUERY_SERVER 37
  1641. #define HTTP_QUERY_TITLE 38
  1642. #define HTTP_QUERY_USER_AGENT 39
  1643. #define HTTP_QUERY_WWW_AUTHENTICATE 40
  1644. #define HTTP_QUERY_PROXY_AUTHENTICATE 41
  1645. #define HTTP_QUERY_ACCEPT_RANGES 42
  1646. #define HTTP_QUERY_SET_COOKIE 43
  1647. #define HTTP_QUERY_COOKIE 44
  1648. #define HTTP_QUERY_REQUEST_METHOD 45 // special: GET/POST etc.
  1649. #define HTTP_QUERY_REFRESH 46
  1650. #define HTTP_QUERY_CONTENT_DISPOSITION 47
  1651. //
  1652. // HTTP 1.1 defined headers
  1653. //
  1654. #define HTTP_QUERY_AGE 48
  1655. #define HTTP_QUERY_CACHE_CONTROL 49
  1656. #define HTTP_QUERY_CONTENT_BASE 50
  1657. #define HTTP_QUERY_CONTENT_LOCATION 51
  1658. #define HTTP_QUERY_CONTENT_MD5 52
  1659. #define HTTP_QUERY_CONTENT_RANGE 53
  1660. #define HTTP_QUERY_ETAG 54
  1661. #define HTTP_QUERY_HOST 55
  1662. #define HTTP_QUERY_IF_MATCH 56
  1663. #define HTTP_QUERY_IF_NONE_MATCH 57
  1664. #define HTTP_QUERY_IF_RANGE 58
  1665. #define HTTP_QUERY_IF_UNMODIFIED_SINCE 59
  1666. #define HTTP_QUERY_MAX_FORWARDS 60
  1667. #define HTTP_QUERY_PROXY_AUTHORIZATION 61
  1668. #define HTTP_QUERY_RANGE 62
  1669. #define HTTP_QUERY_TRANSFER_ENCODING 63
  1670. #define HTTP_QUERY_UPGRADE 64
  1671. #define HTTP_QUERY_VARY 65
  1672. #define HTTP_QUERY_VIA 66
  1673. #define HTTP_QUERY_WARNING 67
  1674. #define HTTP_QUERY_MAX 67
  1675. //
  1676. // HTTP_QUERY_CUSTOM - if this special value is supplied as the dwInfoLevel
  1677. // parameter of HttpQueryInfo() then the lpBuffer parameter contains the name
  1678. // of the header we are to query
  1679. //
  1680. #define HTTP_QUERY_CUSTOM 65535
  1681. //
  1682. // HTTP_QUERY_FLAG_REQUEST_HEADERS - if this bit is set in the dwInfoLevel
  1683. // parameter of HttpQueryInfo() then the request headers will be queried for the
  1684. // request information
  1685. //
  1686. #define HTTP_QUERY_FLAG_REQUEST_HEADERS 0x80000000
  1687. //
  1688. // HTTP_QUERY_FLAG_SYSTEMTIME - if this bit is set in the dwInfoLevel parameter
  1689. // of HttpQueryInfo() AND the header being queried contains date information,
  1690. // e.g. the "Expires:" header then lpBuffer will contain a SYSTEMTIME structure
  1691. // containing the date and time information converted from the header string
  1692. //
  1693. #define HTTP_QUERY_FLAG_SYSTEMTIME 0x40000000
  1694. //
  1695. // HTTP_QUERY_FLAG_NUMBER - if this bit is set in the dwInfoLevel parameter of
  1696. // HttpQueryInfo(), then the value of the header will be converted to a number
  1697. // before being returned to the caller, if applicable
  1698. //
  1699. #define HTTP_QUERY_FLAG_NUMBER 0x20000000
  1700. //
  1701. // HTTP_QUERY_FLAG_COALESCE - combine the values from several headers of the
  1702. // same name into the output buffer
  1703. //
  1704. #define HTTP_QUERY_FLAG_COALESCE 0x10000000
  1705. #define HTTP_QUERY_MODIFIER_FLAGS_MASK (HTTP_QUERY_FLAG_REQUEST_HEADERS \
  1706. | HTTP_QUERY_FLAG_SYSTEMTIME \
  1707. | HTTP_QUERY_FLAG_NUMBER \
  1708. | HTTP_QUERY_FLAG_COALESCE \
  1709. )
  1710. #define HTTP_QUERY_HEADER_MASK (~HTTP_QUERY_MODIFIER_FLAGS_MASK)
  1711. //
  1712. // HTTP Response Status Codes:
  1713. //
  1714. #define HTTP_STATUS_CONTINUE 100 // OK to continue with request
  1715. #define HTTP_STATUS_SWITCH_PROTOCOLS 101 // server has switched protocols in upgrade header
  1716. #define HTTP_STATUS_OK 200 // request completed
  1717. #define HTTP_STATUS_CREATED 201 // object created, reason = new URI
  1718. #define HTTP_STATUS_ACCEPTED 202 // async completion (TBS)
  1719. #define HTTP_STATUS_PARTIAL 203 // partial completion
  1720. #define HTTP_STATUS_NO_CONTENT 204 // no info to return
  1721. #define HTTP_STATUS_RESET_CONTENT 205 // request completed, but clear form
  1722. #define HTTP_STATUS_PARTIAL_CONTENT 206 // partial GET furfilled
  1723. #define HTTP_STATUS_AMBIGUOUS 300 // server couldn't decide what to return
  1724. #define HTTP_STATUS_MOVED 301 // object permanently moved
  1725. #define HTTP_STATUS_REDIRECT 302 // object temporarily moved
  1726. #define HTTP_STATUS_REDIRECT_METHOD 303 // redirection w/ new access method
  1727. #define HTTP_STATUS_NOT_MODIFIED 304 // if-modified-since was not modified
  1728. #define HTTP_STATUS_USE_PROXY 305 // redirection to proxy, location header specifies proxy to use
  1729. #define HTTP_STATUS_REDIRECT_KEEP_VERB 307 // HTTP/1.1: keep same verb
  1730. #define HTTP_STATUS_BAD_REQUEST 400 // invalid syntax
  1731. #define HTTP_STATUS_DENIED 401 // access denied
  1732. #define HTTP_STATUS_PAYMENT_REQ 402 // payment required
  1733. #define HTTP_STATUS_FORBIDDEN 403 // request forbidden
  1734. #define HTTP_STATUS_NOT_FOUND 404 // object not found
  1735. #define HTTP_STATUS_BAD_METHOD 405 // method is not allowed
  1736. #define HTTP_STATUS_NONE_ACCEPTABLE 406 // no response acceptable to client found
  1737. #define HTTP_STATUS_PROXY_AUTH_REQ 407 // proxy authentication required
  1738. #define HTTP_STATUS_REQUEST_TIMEOUT 408 // server timed out waiting for request
  1739. #define HTTP_STATUS_CONFLICT 409 // user should resubmit with more info
  1740. #define HTTP_STATUS_GONE 410 // the resource is no longer available
  1741. #define HTTP_STATUS_LENGTH_REQUIRED 411 // the server refused to accept request w/o a length
  1742. #define HTTP_STATUS_PRECOND_FAILED 412 // precondition given in request failed
  1743. #define HTTP_STATUS_REQUEST_TOO_LARGE 413 // request entity was too large
  1744. #define HTTP_STATUS_URI_TOO_LONG 414 // request URI too long
  1745. #define HTTP_STATUS_UNSUPPORTED_MEDIA 415 // unsupported media type
  1746. #define HTTP_STATUS_SERVER_ERROR 500 // internal server error
  1747. #define HTTP_STATUS_NOT_SUPPORTED 501 // required not supported
  1748. #define HTTP_STATUS_BAD_GATEWAY 502 // error response received from gateway
  1749. #define HTTP_STATUS_SERVICE_UNAVAIL 503 // temporarily overloaded
  1750. #define HTTP_STATUS_GATEWAY_TIMEOUT 504 // timed out waiting for gateway
  1751. #define HTTP_STATUS_VERSION_NOT_SUP 505 // HTTP version not supported
  1752. #define HTTP_STATUS_FIRST HTTP_STATUS_CONTINUE
  1753. #define HTTP_STATUS_LAST HTTP_STATUS_VERSION_NOT_SUP
  1754. //
  1755. // prototypes
  1756. //
  1757. INTERNETAPI
  1758. HINTERNET
  1759. WINAPI
  1760. HttpOpenRequestA(
  1761. IN HINTERNET hConnect,
  1762. IN LPCSTR lpszVerb,
  1763. IN LPCSTR lpszObjectName,
  1764. IN LPCSTR lpszVersion,
  1765. IN LPCSTR lpszReferrer OPTIONAL,
  1766. IN LPCSTR FAR * lplpszAcceptTypes OPTIONAL,
  1767. IN DWORD dwFlags,
  1768. IN DWORD dwContext
  1769. );
  1770. INTERNETAPI
  1771. HINTERNET
  1772. WINAPI
  1773. HttpOpenRequestW(
  1774. IN HINTERNET hConnect,
  1775. IN LPCWSTR lpszVerb,
  1776. IN LPCWSTR lpszObjectName,
  1777. IN LPCWSTR lpszVersion,
  1778. IN LPCWSTR lpszReferrer OPTIONAL,
  1779. IN LPCWSTR FAR * lplpszAcceptTypes OPTIONAL,
  1780. IN DWORD dwFlags,
  1781. IN DWORD dwContext
  1782. );
  1783. #ifdef UNICODE
  1784. #define HttpOpenRequest HttpOpenRequestW
  1785. #else
  1786. #define HttpOpenRequest HttpOpenRequestA
  1787. #endif // !UNICODE
  1788. BOOLAPI
  1789. HttpAddRequestHeadersA(
  1790. IN HINTERNET hRequest,
  1791. IN LPCSTR lpszHeaders,
  1792. IN DWORD dwHeadersLength,
  1793. IN DWORD dwModifiers
  1794. );
  1795. BOOLAPI
  1796. HttpAddRequestHeadersW(
  1797. IN HINTERNET hRequest,
  1798. IN LPCWSTR lpszHeaders,
  1799. IN DWORD dwHeadersLength,
  1800. IN DWORD dwModifiers
  1801. );
  1802. #ifdef UNICODE
  1803. #define HttpAddRequestHeaders HttpAddRequestHeadersW
  1804. #else
  1805. #define HttpAddRequestHeaders HttpAddRequestHeadersA
  1806. #endif // !UNICODE
  1807. //
  1808. // values for dwModifiers parameter of HttpAddRequestHeaders()
  1809. //
  1810. #define HTTP_ADDREQ_INDEX_MASK 0x0000FFFF
  1811. #define HTTP_ADDREQ_FLAGS_MASK 0xFFFF0000
  1812. //
  1813. // HTTP_ADDREQ_FLAG_ADD_IF_NEW - the header will only be added if it doesn't
  1814. // already exist
  1815. //
  1816. #define HTTP_ADDREQ_FLAG_ADD_IF_NEW 0x10000000
  1817. //
  1818. // HTTP_ADDREQ_FLAG_ADD - if HTTP_ADDREQ_FLAG_REPLACE is set but the header is
  1819. // not found then if this flag is set, the header is added anyway, so long as
  1820. // there is a valid header-value
  1821. //
  1822. #define HTTP_ADDREQ_FLAG_ADD 0x20000000
  1823. //
  1824. // HTTP_ADDREQ_FLAG_COALESCE - coalesce headers with same name. e.g.
  1825. // "Accept: text/*" and "Accept: audio/*" with this flag results in a single
  1826. // header: "Accept: text/*, audio/*"
  1827. //
  1828. #define HTTP_ADDREQ_FLAG_COALESCE_WITH_COMMA 0x40000000
  1829. #define HTTP_ADDREQ_FLAG_COALESCE_WITH_SEMICOLON 0x01000000
  1830. #define HTTP_ADDREQ_FLAG_COALESCE HTTP_ADDREQ_FLAG_COALESCE_WITH_COMMA
  1831. //
  1832. // HTTP_ADDREQ_FLAG_REPLACE - replaces the specified header. Only one header can
  1833. // be supplied in the buffer. If the header to be replaced is not the first
  1834. // in a list of headers with the same name, then the relative index should be
  1835. // supplied in the low 8 bits of the dwModifiers parameter. If the header-value
  1836. // part is missing, then the header is removed
  1837. //
  1838. #define HTTP_ADDREQ_FLAG_REPLACE 0x80000000
  1839. BOOLAPI
  1840. HttpSendRequestA(
  1841. IN HINTERNET hRequest,
  1842. IN LPCSTR lpszHeaders OPTIONAL,
  1843. IN DWORD dwHeadersLength,
  1844. IN LPVOID lpOptional OPTIONAL,
  1845. IN DWORD dwOptionalLength
  1846. );
  1847. BOOLAPI
  1848. HttpSendRequestW(
  1849. IN HINTERNET hRequest,
  1850. IN LPCWSTR lpszHeaders OPTIONAL,
  1851. IN DWORD dwHeadersLength,
  1852. IN LPVOID lpOptional OPTIONAL,
  1853. IN DWORD dwOptionalLength
  1854. );
  1855. #ifdef UNICODE
  1856. #define HttpSendRequest HttpSendRequestW
  1857. #else
  1858. #define HttpSendRequest HttpSendRequestA
  1859. #endif // !UNICODE
  1860. INTERNETAPI
  1861. BOOL
  1862. WINAPI
  1863. HttpSendRequestExA(
  1864. IN HINTERNET hRequest,
  1865. IN LPINTERNET_BUFFERSA lpBuffersIn OPTIONAL,
  1866. OUT LPINTERNET_BUFFERSA lpBuffersOut OPTIONAL,
  1867. IN DWORD dwFlags,
  1868. IN DWORD dwContext
  1869. );
  1870. INTERNETAPI
  1871. BOOL
  1872. WINAPI
  1873. HttpSendRequestExW(
  1874. IN HINTERNET hRequest,
  1875. IN LPINTERNET_BUFFERSW lpBuffersIn OPTIONAL,
  1876. OUT LPINTERNET_BUFFERSW lpBuffersOut OPTIONAL,
  1877. IN DWORD dwFlags,
  1878. IN DWORD dwContext
  1879. );
  1880. #ifdef UNICODE
  1881. #define HttpSendRequestEx HttpSendRequestExW
  1882. #else
  1883. #define HttpSendRequestEx HttpSendRequestExA
  1884. #endif // !UNICODE
  1885. //
  1886. // flags for HttpSendRequestEx(), HttpEndRequest()
  1887. //
  1888. #define HSR_ASYNC WININET_API_FLAG_ASYNC // force async
  1889. #define HSR_SYNC WININET_API_FLAG_SYNC // force sync
  1890. #define HSR_USE_CONTEXT WININET_API_FLAG_USE_CONTEXT // use dwContext value
  1891. #define HSR_INITIATE 0x00000008 // iterative operation (completed by HttpEndRequest)
  1892. #define HSR_DOWNLOAD 0x00000010 // download to file
  1893. #define HSR_CHUNKED 0x00000020 // operation is send of chunked data
  1894. INTERNETAPI
  1895. BOOL
  1896. WINAPI
  1897. HttpEndRequestA(
  1898. IN HINTERNET hRequest,
  1899. OUT LPINTERNET_BUFFERSA lpBuffersOut OPTIONAL,
  1900. IN DWORD dwFlags,
  1901. IN DWORD dwContext
  1902. );
  1903. INTERNETAPI
  1904. BOOL
  1905. WINAPI
  1906. HttpEndRequestW(
  1907. IN HINTERNET hRequest,
  1908. OUT LPINTERNET_BUFFERSW lpBuffersOut OPTIONAL,
  1909. IN DWORD dwFlags,
  1910. IN DWORD dwContext
  1911. );
  1912. #ifdef UNICODE
  1913. #define HttpEndRequest HttpEndRequestW
  1914. #else
  1915. #define HttpEndRequest HttpEndRequestA
  1916. #endif // !UNICODE
  1917. BOOLAPI
  1918. HttpQueryInfoA(
  1919. IN HINTERNET hRequest,
  1920. IN DWORD dwInfoLevel,
  1921. IN OUT LPVOID lpBuffer OPTIONAL,
  1922. IN OUT LPDWORD lpdwBufferLength,
  1923. IN OUT LPDWORD lpdwIndex OPTIONAL
  1924. );
  1925. BOOLAPI
  1926. HttpQueryInfoW(
  1927. IN HINTERNET hRequest,
  1928. IN DWORD dwInfoLevel,
  1929. IN OUT LPVOID lpBuffer OPTIONAL,
  1930. IN OUT LPDWORD lpdwBufferLength,
  1931. IN OUT LPDWORD lpdwIndex OPTIONAL
  1932. );
  1933. #ifdef UNICODE
  1934. #define HttpQueryInfo HttpQueryInfoW
  1935. #else
  1936. #define HttpQueryInfo HttpQueryInfoA
  1937. #endif // !UNICODE
  1938. //
  1939. // Cookie APIs
  1940. //
  1941. BOOLAPI
  1942. InternetSetCookieA(
  1943. IN LPCSTR lpszUrl,
  1944. IN LPCSTR lpszCookieName,
  1945. IN LPCSTR lpszCookieData
  1946. );
  1947. BOOLAPI
  1948. InternetSetCookieW(
  1949. IN LPCSTR lpszUrl,
  1950. IN LPCWSTR lpszCookieName,
  1951. IN LPCWSTR lpszCookieData
  1952. );
  1953. #ifdef UNICODE
  1954. #define InternetSetCookie InternetSetCookieW
  1955. #else
  1956. #define InternetSetCookie InternetSetCookieA
  1957. #endif // !UNICODE
  1958. BOOLAPI
  1959. InternetGetCookieA(
  1960. IN LPCSTR lpszUrl,
  1961. IN LPCSTR lpszCookieName,
  1962. OUT LPSTR lpCookieData,
  1963. IN OUT LPDWORD lpdwSize
  1964. );
  1965. BOOLAPI
  1966. InternetGetCookieW(
  1967. IN LPCSTR lpszUrl,
  1968. IN LPCWSTR lpszCookieName,
  1969. OUT LPWSTR lpCookieData,
  1970. IN OUT LPDWORD lpdwSize
  1971. );
  1972. #ifdef UNICODE
  1973. #define InternetGetCookie InternetGetCookieW
  1974. #else
  1975. #define InternetGetCookie InternetGetCookieA
  1976. #endif // !UNICODE
  1977. //
  1978. // offline browsing
  1979. //
  1980. INTERNETAPI
  1981. DWORD
  1982. WINAPI
  1983. InternetAttemptConnect(
  1984. IN DWORD dwReserved
  1985. );
  1986. BOOLAPI
  1987. InternetCheckConnectionA(
  1988. IN LPCSTR lpszUrl,
  1989. IN DWORD dwFlags,
  1990. IN DWORD dwReserved
  1991. );
  1992. BOOLAPI
  1993. InternetCheckConnectionW(
  1994. IN LPCWSTR lpszUrl,
  1995. IN DWORD dwFlags,
  1996. IN DWORD dwReserved
  1997. );
  1998. #ifdef UNICODE
  1999. #define InternetCheckConnection InternetCheckConnectionW
  2000. #else
  2001. #define InternetCheckConnection InternetCheckConnectionA
  2002. #endif // !UNICODE
  2003. #define FLAG_ICC_FORCE_CONNECTION 0x00000001
  2004. //
  2005. // Internet UI
  2006. //
  2007. //
  2008. // InternetErrorDlg - Provides UI for certain Errors.
  2009. //
  2010. #define FLAGS_ERROR_UI_FILTER_FOR_ERRORS 0x01
  2011. #define FLAGS_ERROR_UI_FLAGS_CHANGE_OPTIONS 0x02
  2012. #define FLAGS_ERROR_UI_FLAGS_GENERATE_DATA 0x04
  2013. #define FLAGS_ERROR_UI_FLAGS_NO_UI 0x08
  2014. #define FLAGS_ERROR_UI_SERIALIZE_DIALOGS 0x10
  2015. //
  2016. // If SERIALIZE_DIALOGS flag set, client should implement thread-safe non-blocking callback...
  2017. //
  2018. DWORD InternetAuthNotifyCallback
  2019. (
  2020. DWORD dwContext, // as passed to InternetErrorDlg
  2021. DWORD dwReturn, // error code: success, resend, or cancel
  2022. LPVOID lpReserved // reserved: will be set to null
  2023. );
  2024. typedef DWORD (CALLBACK * PFN_AUTH_NOTIFY) (DWORD, DWORD, LPVOID);
  2025. //
  2026. // ... and last parameter of InternetErrorDlg should point to...
  2027. //
  2028. typedef struct
  2029. {
  2030. DWORD cbStruct; // size of this structure
  2031. DWORD dwOptions; // reserved: must set to 0
  2032. PFN_AUTH_NOTIFY pfnNotify; // notification callback to retry InternetErrorDlg
  2033. DWORD dwContext; // context to pass to to notification function
  2034. }
  2035. INTERNET_AUTH_NOTIFY_DATA;
  2036. INTERNETAPI
  2037. DWORD
  2038. WINAPI
  2039. InternetErrorDlg(
  2040. IN HWND hWnd,
  2041. IN OUT HINTERNET hRequest,
  2042. IN DWORD dwError,
  2043. IN DWORD dwFlags,
  2044. IN OUT LPVOID * lppvData
  2045. );
  2046. INTERNETAPI
  2047. DWORD
  2048. WINAPI
  2049. InternetConfirmZoneCrossing(
  2050. IN HWND hWnd,
  2051. IN LPSTR szUrlPrev,
  2052. IN LPSTR szUrlNew,
  2053. IN BOOL bPost
  2054. );
  2055. //#if !defined(_WINERROR_)
  2056. //
  2057. // Internet API error returns
  2058. //
  2059. #define INTERNET_ERROR_BASE 12000
  2060. #define ERROR_INTERNET_OUT_OF_HANDLES (INTERNET_ERROR_BASE + 1)
  2061. #define ERROR_INTERNET_TIMEOUT (INTERNET_ERROR_BASE + 2)
  2062. #define ERROR_INTERNET_EXTENDED_ERROR (INTERNET_ERROR_BASE + 3)
  2063. #define ERROR_INTERNET_INTERNAL_ERROR (INTERNET_ERROR_BASE + 4)
  2064. #define ERROR_INTERNET_INVALID_URL (INTERNET_ERROR_BASE + 5)
  2065. #define ERROR_INTERNET_UNRECOGNIZED_SCHEME (INTERNET_ERROR_BASE + 6)
  2066. #define ERROR_INTERNET_NAME_NOT_RESOLVED (INTERNET_ERROR_BASE + 7)
  2067. #define ERROR_INTERNET_PROTOCOL_NOT_FOUND (INTERNET_ERROR_BASE + 8)
  2068. #define ERROR_INTERNET_INVALID_OPTION (INTERNET_ERROR_BASE + 9)
  2069. #define ERROR_INTERNET_BAD_OPTION_LENGTH (INTERNET_ERROR_BASE + 10)
  2070. #define ERROR_INTERNET_OPTION_NOT_SETTABLE (INTERNET_ERROR_BASE + 11)
  2071. #define ERROR_INTERNET_SHUTDOWN (INTERNET_ERROR_BASE + 12)
  2072. #define ERROR_INTERNET_INCORRECT_USER_NAME (INTERNET_ERROR_BASE + 13)
  2073. #define ERROR_INTERNET_INCORRECT_PASSWORD (INTERNET_ERROR_BASE + 14)
  2074. #define ERROR_INTERNET_LOGIN_FAILURE (INTERNET_ERROR_BASE + 15)
  2075. #define ERROR_INTERNET_INVALID_OPERATION (INTERNET_ERROR_BASE + 16)
  2076. #define ERROR_INTERNET_OPERATION_CANCELLED (INTERNET_ERROR_BASE + 17)
  2077. #define ERROR_INTERNET_INCORRECT_HANDLE_TYPE (INTERNET_ERROR_BASE + 18)
  2078. #define ERROR_INTERNET_INCORRECT_HANDLE_STATE (INTERNET_ERROR_BASE + 19)
  2079. #define ERROR_INTERNET_NOT_PROXY_REQUEST (INTERNET_ERROR_BASE + 20)
  2080. #define ERROR_INTERNET_REGISTRY_VALUE_NOT_FOUND (INTERNET_ERROR_BASE + 21)
  2081. #define ERROR_INTERNET_BAD_REGISTRY_PARAMETER (INTERNET_ERROR_BASE + 22)
  2082. #define ERROR_INTERNET_NO_DIRECT_ACCESS (INTERNET_ERROR_BASE + 23)
  2083. #define ERROR_INTERNET_NO_CONTEXT (INTERNET_ERROR_BASE + 24)
  2084. #define ERROR_INTERNET_NO_CALLBACK (INTERNET_ERROR_BASE + 25)
  2085. #define ERROR_INTERNET_REQUEST_PENDING (INTERNET_ERROR_BASE + 26)
  2086. #define ERROR_INTERNET_INCORRECT_FORMAT (INTERNET_ERROR_BASE + 27)
  2087. #define ERROR_INTERNET_ITEM_NOT_FOUND (INTERNET_ERROR_BASE + 28)
  2088. #define ERROR_INTERNET_CANNOT_CONNECT (INTERNET_ERROR_BASE + 29)
  2089. #define ERROR_INTERNET_CONNECTION_ABORTED (INTERNET_ERROR_BASE + 30)
  2090. #define ERROR_INTERNET_CONNECTION_RESET (INTERNET_ERROR_BASE + 31)
  2091. #define ERROR_INTERNET_FORCE_RETRY (INTERNET_ERROR_BASE + 32)
  2092. #define ERROR_INTERNET_INVALID_PROXY_REQUEST (INTERNET_ERROR_BASE + 33)
  2093. #define ERROR_INTERNET_NEED_UI (INTERNET_ERROR_BASE + 34)
  2094. #define ERROR_INTERNET_HANDLE_EXISTS (INTERNET_ERROR_BASE + 36)
  2095. #define ERROR_INTERNET_SEC_CERT_DATE_INVALID (INTERNET_ERROR_BASE + 37)
  2096. #define ERROR_INTERNET_SEC_CERT_CN_INVALID (INTERNET_ERROR_BASE + 38)
  2097. #define ERROR_INTERNET_HTTP_TO_HTTPS_ON_REDIR (INTERNET_ERROR_BASE + 39)
  2098. #define ERROR_INTERNET_HTTPS_TO_HTTP_ON_REDIR (INTERNET_ERROR_BASE + 40)
  2099. #define ERROR_INTERNET_MIXED_SECURITY (INTERNET_ERROR_BASE + 41)
  2100. #define ERROR_INTERNET_CHG_POST_IS_NON_SECURE (INTERNET_ERROR_BASE + 42)
  2101. #define ERROR_INTERNET_POST_IS_NON_SECURE (INTERNET_ERROR_BASE + 43)
  2102. #define ERROR_INTERNET_CLIENT_AUTH_CERT_NEEDED (INTERNET_ERROR_BASE + 44)
  2103. #define ERROR_INTERNET_INVALID_CA (INTERNET_ERROR_BASE + 45)
  2104. #define ERROR_INTERNET_CLIENT_AUTH_NOT_SETUP (INTERNET_ERROR_BASE + 46)
  2105. #define ERROR_INTERNET_ASYNC_THREAD_FAILED (INTERNET_ERROR_BASE + 47)
  2106. #define ERROR_INTERNET_REDIRECT_SCHEME_CHANGE (INTERNET_ERROR_BASE + 48)
  2107. #define ERROR_INTERNET_DIALOG_PENDING (INTERNET_ERROR_BASE + 49)
  2108. #define ERROR_INTERNET_RETRY_DIALOG (INTERNET_ERROR_BASE + 50)
  2109. #define ERROR_INTERNET_HTTPS_HTTP_SUBMIT_REDIR (INTERNET_ERROR_BASE + 52)
  2110. #define ERROR_INTERNET_INSERT_CDROM (INTERNET_ERROR_BASE + 53)
  2111. //
  2112. // FTP API errors
  2113. //
  2114. #define ERROR_FTP_TRANSFER_IN_PROGRESS (INTERNET_ERROR_BASE + 110)
  2115. #define ERROR_FTP_DROPPED (INTERNET_ERROR_BASE + 111)
  2116. #define ERROR_FTP_NO_PASSIVE_MODE (INTERNET_ERROR_BASE + 112)
  2117. //
  2118. // gopher API errors
  2119. //
  2120. #define ERROR_GOPHER_PROTOCOL_ERROR (INTERNET_ERROR_BASE + 130)
  2121. #define ERROR_GOPHER_NOT_FILE (INTERNET_ERROR_BASE + 131)
  2122. #define ERROR_GOPHER_DATA_ERROR (INTERNET_ERROR_BASE + 132)
  2123. #define ERROR_GOPHER_END_OF_DATA (INTERNET_ERROR_BASE + 133)
  2124. #define ERROR_GOPHER_INVALID_LOCATOR (INTERNET_ERROR_BASE + 134)
  2125. #define ERROR_GOPHER_INCORRECT_LOCATOR_TYPE (INTERNET_ERROR_BASE + 135)
  2126. #define ERROR_GOPHER_NOT_GOPHER_PLUS (INTERNET_ERROR_BASE + 136)
  2127. #define ERROR_GOPHER_ATTRIBUTE_NOT_FOUND (INTERNET_ERROR_BASE + 137)
  2128. #define ERROR_GOPHER_UNKNOWN_LOCATOR (INTERNET_ERROR_BASE + 138)
  2129. //
  2130. // HTTP API errors
  2131. //
  2132. #define ERROR_HTTP_HEADER_NOT_FOUND (INTERNET_ERROR_BASE + 150)
  2133. #define ERROR_HTTP_DOWNLEVEL_SERVER (INTERNET_ERROR_BASE + 151)
  2134. #define ERROR_HTTP_INVALID_SERVER_RESPONSE (INTERNET_ERROR_BASE + 152)
  2135. #define ERROR_HTTP_INVALID_HEADER (INTERNET_ERROR_BASE + 153)
  2136. #define ERROR_HTTP_INVALID_QUERY_REQUEST (INTERNET_ERROR_BASE + 154)
  2137. #define ERROR_HTTP_HEADER_ALREADY_EXISTS (INTERNET_ERROR_BASE + 155)
  2138. #define ERROR_HTTP_REDIRECT_FAILED (INTERNET_ERROR_BASE + 156)
  2139. #define ERROR_HTTP_NOT_REDIRECTED (INTERNET_ERROR_BASE + 160)
  2140. #define ERROR_HTTP_COOKIE_NEEDS_CONFIRMATION (INTERNET_ERROR_BASE + 161)
  2141. #define ERROR_HTTP_COOKIE_DECLINED (INTERNET_ERROR_BASE + 162)
  2142. #define ERROR_HTTP_REDIRECT_NEEDS_CONFIRMATION (INTERNET_ERROR_BASE + 168)
  2143. //
  2144. // additional Internet API error codes
  2145. //
  2146. #define ERROR_INTERNET_SECURITY_CHANNEL_ERROR (INTERNET_ERROR_BASE + 157)
  2147. #define ERROR_INTERNET_UNABLE_TO_CACHE_FILE (INTERNET_ERROR_BASE + 158)
  2148. #define ERROR_INTERNET_TCPIP_NOT_INSTALLED (INTERNET_ERROR_BASE + 159)
  2149. #define ERROR_INTERNET_DISCONNECTED (INTERNET_ERROR_BASE + 163)
  2150. #define ERROR_INTERNET_SERVER_UNREACHABLE (INTERNET_ERROR_BASE + 164)
  2151. #define ERROR_INTERNET_PROXY_SERVER_UNREACHABLE (INTERNET_ERROR_BASE + 165)
  2152. #define ERROR_INTERNET_BAD_AUTO_PROXY_SCRIPT (INTERNET_ERROR_BASE + 166)
  2153. #define ERROR_INTERNET_UNABLE_TO_DOWNLOAD_SCRIPT (INTERNET_ERROR_BASE + 167)
  2154. #define ERROR_INTERNET_SEC_INVALID_CERT (INTERNET_ERROR_BASE + 169)
  2155. #define ERROR_INTERNET_SEC_CERT_REVOKED (INTERNET_ERROR_BASE + 170)
  2156. // InternetAutodial specific errors
  2157. #define ERROR_INTERNET_FAILED_DUETOSECURITYCHECK (INTERNET_ERROR_BASE + 171)
  2158. #define INTERNET_ERROR_LAST ERROR_INTERNET_FAILED_DUETOSECURITYCHECK
  2159. //#endif // !defined(_WINERROR_)
  2160. //
  2161. // URLCACHE APIs
  2162. //
  2163. //
  2164. // datatype definitions.
  2165. //
  2166. //
  2167. // cache entry type flags.
  2168. //
  2169. #define NORMAL_CACHE_ENTRY 0x00000001
  2170. #define COOKIE_CACHE_ENTRY 0x00100000
  2171. #define URLHISTORY_CACHE_ENTRY 0x00200000
  2172. #define TRACK_OFFLINE_CACHE_ENTRY 0x00000010
  2173. #define TRACK_ONLINE_CACHE_ENTRY 0x00000020
  2174. #define STICKY_CACHE_ENTRY 0x00000004
  2175. #define SPARSE_CACHE_ENTRY 0x00010000
  2176. #define URLCACHE_FIND_DEFAULT_FILTER NORMAL_CACHE_ENTRY \
  2177. | COOKIE_CACHE_ENTRY \
  2178. | URLHISTORY_CACHE_ENTRY \
  2179. | TRACK_OFFLINE_CACHE_ENTRY \
  2180. | TRACK_ONLINE_CACHE_ENTRY \
  2181. | STICKY_CACHE_ENTRY
  2182. //
  2183. // INTERNET_CACHE_ENTRY_INFO -
  2184. //
  2185. typedef struct _INTERNET_CACHE_ENTRY_INFOA {
  2186. DWORD dwStructSize; // version of cache system.
  2187. LPSTR lpszSourceUrlName; // embedded pointer to the URL name string.
  2188. LPSTR lpszLocalFileName; // embedded pointer to the local file name.
  2189. DWORD CacheEntryType; // cache type bit mask.
  2190. DWORD dwUseCount; // current users count of the cache entry.
  2191. DWORD dwHitRate; // num of times the cache entry was retrieved.
  2192. DWORD dwSizeLow; // low DWORD of the file size.
  2193. DWORD dwSizeHigh; // high DWORD of the file size.
  2194. FILETIME LastModifiedTime; // last modified time of the file in GMT format.
  2195. FILETIME ExpireTime; // expire time of the file in GMT format
  2196. FILETIME LastAccessTime; // last accessed time in GMT format
  2197. FILETIME LastSyncTime; // last time the URL was synchronized
  2198. // with the source
  2199. LPBYTE lpHeaderInfo; // embedded pointer to the header info.
  2200. DWORD dwHeaderInfoSize; // size of the above header.
  2201. LPSTR lpszFileExtension; // File extension used to retrive the urldata as a file.
  2202. union { // Exemption delta from last access time.
  2203. DWORD dwReserved;
  2204. DWORD dwExemptDelta;
  2205. }; // Exemption delta from last access
  2206. } INTERNET_CACHE_ENTRY_INFOA, * LPINTERNET_CACHE_ENTRY_INFOA;
  2207. typedef struct _INTERNET_CACHE_ENTRY_INFOW {
  2208. DWORD dwStructSize; // version of cache system.
  2209. LPSTR lpszSourceUrlName; // embedded pointer to the URL name string.
  2210. LPWSTR lpszLocalFileName; // embedded pointer to the local file name.
  2211. DWORD CacheEntryType; // cache type bit mask.
  2212. DWORD dwUseCount; // current users count of the cache entry.
  2213. DWORD dwHitRate; // num of times the cache entry was retrieved.
  2214. DWORD dwSizeLow; // low DWORD of the file size.
  2215. DWORD dwSizeHigh; // high DWORD of the file size.
  2216. FILETIME LastModifiedTime; // last modified time of the file in GMT format.
  2217. FILETIME ExpireTime; // expire time of the file in GMT format
  2218. FILETIME LastAccessTime; // last accessed time in GMT format
  2219. FILETIME LastSyncTime; // last time the URL was synchronized
  2220. // with the source
  2221. LPBYTE lpHeaderInfo; // embedded pointer to the header info.
  2222. DWORD dwHeaderInfoSize; // size of the above header.
  2223. LPWSTR lpszFileExtension; // File extension used to retrive the urldata as a file.
  2224. union { // Exemption delta from last access time.
  2225. DWORD dwReserved;
  2226. DWORD dwExemptDelta;
  2227. }; // Exemption delta from last access
  2228. } INTERNET_CACHE_ENTRY_INFOW, * LPINTERNET_CACHE_ENTRY_INFOW;
  2229. #ifdef UNICODE
  2230. typedef INTERNET_CACHE_ENTRY_INFOW INTERNET_CACHE_ENTRY_INFO;
  2231. typedef LPINTERNET_CACHE_ENTRY_INFOW LPINTERNET_CACHE_ENTRY_INFO;
  2232. #else
  2233. typedef INTERNET_CACHE_ENTRY_INFOA INTERNET_CACHE_ENTRY_INFO;
  2234. typedef LPINTERNET_CACHE_ENTRY_INFOA LPINTERNET_CACHE_ENTRY_INFO;
  2235. #endif // UNICODE
  2236. //
  2237. // Cache APIs
  2238. //
  2239. BOOLAPI
  2240. CreateUrlCacheEntryA(
  2241. IN LPCSTR lpszUrlName,
  2242. IN DWORD dwExpectedFileSize,
  2243. IN LPCSTR lpszFileExtension,
  2244. OUT LPSTR lpszFileName,
  2245. IN DWORD dwReserved
  2246. );
  2247. BOOLAPI
  2248. CreateUrlCacheEntryW(
  2249. IN LPCSTR lpszUrlName,
  2250. IN DWORD dwExpectedFileSize,
  2251. IN LPCSTR lpszFileExtension,
  2252. OUT LPWSTR lpszFileName,
  2253. IN DWORD dwReserved
  2254. );
  2255. #ifdef UNICODE
  2256. #define CreateUrlCacheEntry CreateUrlCacheEntryW
  2257. #else
  2258. #define CreateUrlCacheEntry CreateUrlCacheEntryA
  2259. #endif // !UNICODE
  2260. BOOLAPI
  2261. CommitUrlCacheEntryA(
  2262. IN LPCSTR lpszUrlName,
  2263. IN LPCSTR lpszLocalFileName,
  2264. IN FILETIME ExpireTime,
  2265. IN FILETIME LastModifiedTime,
  2266. IN DWORD CacheEntryType,
  2267. IN LPBYTE lpHeaderInfo,
  2268. IN DWORD dwHeaderSize,
  2269. IN LPCSTR lpszFileExtension,
  2270. IN DWORD dwReserved
  2271. );
  2272. BOOLAPI
  2273. CommitUrlCacheEntryW(
  2274. IN LPCSTR lpszUrlName,
  2275. IN LPCWSTR lpszLocalFileName,
  2276. IN FILETIME ExpireTime,
  2277. IN FILETIME LastModifiedTime,
  2278. IN DWORD CacheEntryType,
  2279. IN LPBYTE lpHeaderInfo,
  2280. IN DWORD dwHeaderSize,
  2281. IN LPCWSTR lpszFileExtension,
  2282. IN DWORD dwReserved
  2283. );
  2284. #ifdef UNICODE
  2285. #define CommitUrlCacheEntry CommitUrlCacheEntryW
  2286. #else
  2287. #define CommitUrlCacheEntry CommitUrlCacheEntryA
  2288. #endif // !UNICODE
  2289. BOOLAPI
  2290. RetrieveUrlCacheEntryFileA(
  2291. IN LPCSTR lpszUrlName,
  2292. OUT LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
  2293. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize,
  2294. IN DWORD dwReserved
  2295. );
  2296. BOOLAPI
  2297. RetrieveUrlCacheEntryFileW(
  2298. IN LPCSTR lpszUrlName,
  2299. OUT LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  2300. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize,
  2301. IN DWORD dwReserved
  2302. );
  2303. #ifdef UNICODE
  2304. #define RetrieveUrlCacheEntryFile RetrieveUrlCacheEntryFileW
  2305. #else
  2306. #define RetrieveUrlCacheEntryFile RetrieveUrlCacheEntryFileA
  2307. #endif // !UNICODE
  2308. BOOLAPI
  2309. UnlockUrlCacheEntryFile(
  2310. IN LPCSTR lpszUrlName,
  2311. IN DWORD dwReserved
  2312. );
  2313. INTERNETAPI
  2314. HANDLE
  2315. WINAPI
  2316. RetrieveUrlCacheEntryStreamA(
  2317. IN LPCSTR lpszUrlName,
  2318. OUT LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
  2319. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize,
  2320. IN BOOL fRandomRead,
  2321. IN DWORD dwReserved
  2322. );
  2323. INTERNETAPI
  2324. HANDLE
  2325. WINAPI
  2326. RetrieveUrlCacheEntryStreamW(
  2327. IN LPCSTR lpszUrlName,
  2328. OUT LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  2329. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize,
  2330. IN BOOL fRandomRead,
  2331. IN DWORD dwReserved
  2332. );
  2333. #ifdef UNICODE
  2334. #define RetrieveUrlCacheEntryStream RetrieveUrlCacheEntryStreamW
  2335. #else
  2336. #define RetrieveUrlCacheEntryStream RetrieveUrlCacheEntryStreamA
  2337. #endif // !UNICODE
  2338. BOOLAPI
  2339. ReadUrlCacheEntryStream(
  2340. IN HANDLE hUrlCacheStream,
  2341. IN DWORD dwLocation,
  2342. IN OUT LPVOID lpBuffer,
  2343. IN OUT LPDWORD lpdwLen,
  2344. IN DWORD Reserved
  2345. );
  2346. BOOLAPI
  2347. UnlockUrlCacheEntryStream(
  2348. IN HANDLE hUrlCacheStream,
  2349. IN DWORD Reserved
  2350. );
  2351. BOOLAPI
  2352. GetUrlCacheEntryInfoA(
  2353. IN LPCSTR lpszUrlName,
  2354. OUT LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
  2355. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize
  2356. );
  2357. BOOLAPI
  2358. GetUrlCacheEntryInfoW(
  2359. IN LPCSTR lpszUrlName,
  2360. OUT LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  2361. IN OUT LPDWORD lpdwCacheEntryInfoBufferSize
  2362. );
  2363. #ifdef UNICODE
  2364. #define GetUrlCacheEntryInfo GetUrlCacheEntryInfoW
  2365. #else
  2366. #define GetUrlCacheEntryInfo GetUrlCacheEntryInfoA
  2367. #endif // !UNICODE
  2368. BOOLAPI
  2369. GetUrlCacheEntryInfoExA(
  2370. IN LPCSTR lpszUrl,
  2371. OUT LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
  2372. IN OUT LPDWORD lpdwCacheEntryInfoBufSize,
  2373. OUT LPSTR lpszReserved, // must pass null
  2374. IN OUT LPDWORD lpdwReserved, // must pass null
  2375. LPVOID lpReserved, // must pass null
  2376. DWORD dwFlags // reserved
  2377. );
  2378. BOOLAPI
  2379. GetUrlCacheEntryInfoExW(
  2380. IN LPCSTR lpszUrl,
  2381. OUT LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  2382. IN OUT LPDWORD lpdwCacheEntryInfoBufSize,
  2383. OUT LPSTR lpszReserved, // must pass null
  2384. IN OUT LPDWORD lpdwReserved, // must pass null
  2385. LPVOID lpReserved, // must pass null
  2386. DWORD dwFlags // reserved
  2387. );
  2388. #ifdef UNICODE
  2389. #define GetUrlCacheEntryInfoEx GetUrlCacheEntryInfoExW
  2390. #else
  2391. #define GetUrlCacheEntryInfoEx GetUrlCacheEntryInfoExA
  2392. #endif // !UNICODE
  2393. #define CACHE_ENTRY_ATTRIBUTE_FC 0x00000004
  2394. #define CACHE_ENTRY_HITRATE_FC 0x00000010
  2395. #define CACHE_ENTRY_MODTIME_FC 0x00000040
  2396. #define CACHE_ENTRY_EXPTIME_FC 0x00000080
  2397. #define CACHE_ENTRY_ACCTIME_FC 0x00000100
  2398. #define CACHE_ENTRY_SYNCTIME_FC 0x00000200
  2399. #define CACHE_ENTRY_HEADERINFO_FC 0x00000400
  2400. #define CACHE_ENTRY_EXEMPT_DELTA_FC 0x00000800
  2401. BOOLAPI
  2402. SetUrlCacheEntryInfoA(
  2403. IN LPCSTR lpszUrlName,
  2404. IN LPINTERNET_CACHE_ENTRY_INFOA lpCacheEntryInfo,
  2405. IN DWORD dwFieldControl
  2406. );
  2407. BOOLAPI
  2408. SetUrlCacheEntryInfoW(
  2409. IN LPCSTR lpszUrlName,
  2410. IN LPINTERNET_CACHE_ENTRY_INFOW lpCacheEntryInfo,
  2411. IN DWORD dwFieldControl
  2412. );
  2413. #ifdef UNICODE
  2414. #define SetUrlCacheEntryInfo SetUrlCacheEntryInfoW
  2415. #else
  2416. #define SetUrlCacheEntryInfo SetUrlCacheEntryInfoA
  2417. #endif // !UNICODE
  2418. //
  2419. // Cache Group Functions
  2420. //
  2421. typedef LONGLONG GROUPID;
  2422. INTERNETAPI
  2423. GROUPID
  2424. WINAPI
  2425. CreateUrlCacheGroup(
  2426. IN DWORD dwFlags,
  2427. IN LPVOID lpReserved // must pass NULL
  2428. );
  2429. BOOLAPI
  2430. DeleteUrlCacheGroup(
  2431. IN GROUPID GroupId,
  2432. IN DWORD dwFlags, // must pass 0
  2433. IN LPVOID lpReserved // must pass NULL
  2434. );
  2435. // Flags for SetUrlCacheEntryGroup
  2436. #define INTERNET_CACHE_GROUP_ADD 0
  2437. #define INTERNET_CACHE_GROUP_REMOVE 1
  2438. BOOLAPI
  2439. SetUrlCacheEntryGroup(
  2440. IN LPCSTR lpszUrlName,
  2441. IN DWORD dwFlags,
  2442. IN GROUPID GroupId,
  2443. IN LPBYTE pbGroupAttributes, // must pass NULL
  2444. IN DWORD cbGroupAttributes, // must pass 0
  2445. IN LPVOID lpReserved // must pass NULL
  2446. );
  2447. INTERNETAPI
  2448. HANDLE
  2449. WINAPI
  2450. FindFirstUrlCacheEntryExA(
  2451. IN LPCSTR lpszUrlSearchPattern,
  2452. IN DWORD dwFlags,
  2453. IN DWORD dwFilter,
  2454. IN GROUPID GroupId,
  2455. OUT LPINTERNET_CACHE_ENTRY_INFOA lpFirstCacheEntryInfo,
  2456. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize,
  2457. OUT LPVOID lpGroupAttributes, // must pass NULL
  2458. IN OUT LPDWORD pcbGroupAttributes, // must pass NULL
  2459. IN LPVOID lpReserved // must pass NULL
  2460. );
  2461. INTERNETAPI
  2462. HANDLE
  2463. WINAPI
  2464. FindFirstUrlCacheEntryExW(
  2465. IN LPCSTR lpszUrlSearchPattern,
  2466. IN DWORD dwFlags,
  2467. IN DWORD dwFilter,
  2468. IN GROUPID GroupId,
  2469. OUT LPINTERNET_CACHE_ENTRY_INFOW lpFirstCacheEntryInfo,
  2470. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize,
  2471. OUT LPVOID lpGroupAttributes, // must pass NULL
  2472. IN OUT LPDWORD pcbGroupAttributes, // must pass NULL
  2473. IN LPVOID lpReserved // must pass NULL
  2474. );
  2475. #ifdef UNICODE
  2476. #define FindFirstUrlCacheEntryEx FindFirstUrlCacheEntryExW
  2477. #else
  2478. #define FindFirstUrlCacheEntryEx FindFirstUrlCacheEntryExA
  2479. #endif // !UNICODE
  2480. BOOLAPI
  2481. FindNextUrlCacheEntryExA(
  2482. IN HANDLE hEnumHandle,
  2483. OUT LPINTERNET_CACHE_ENTRY_INFOA lpFirstCacheEntryInfo,
  2484. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize,
  2485. OUT LPVOID lpGroupAttributes, // must pass NULL
  2486. IN OUT LPDWORD pcbGroupAttributes, // must pass NULL
  2487. IN LPVOID lpReserved // must pass NULL
  2488. );
  2489. BOOLAPI
  2490. FindNextUrlCacheEntryExW(
  2491. IN HANDLE hEnumHandle,
  2492. OUT LPINTERNET_CACHE_ENTRY_INFOW lpFirstCacheEntryInfo,
  2493. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize,
  2494. OUT LPVOID lpGroupAttributes, // must pass NULL
  2495. IN OUT LPDWORD pcbGroupAttributes, // must pass NULL
  2496. IN LPVOID lpReserved // must pass NULL
  2497. );
  2498. #ifdef UNICODE
  2499. #define FindNextUrlCacheEntryEx FindNextUrlCacheEntryExW
  2500. #else
  2501. #define FindNextUrlCacheEntryEx FindNextUrlCacheEntryExA
  2502. #endif // !UNICODE
  2503. INTERNETAPI
  2504. HANDLE
  2505. WINAPI
  2506. FindFirstUrlCacheEntryA(
  2507. IN LPCSTR lpszUrlSearchPattern,
  2508. OUT LPINTERNET_CACHE_ENTRY_INFOA lpFirstCacheEntryInfo,
  2509. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize
  2510. );
  2511. INTERNETAPI
  2512. HANDLE
  2513. WINAPI
  2514. FindFirstUrlCacheEntryW(
  2515. IN LPCSTR lpszUrlSearchPattern,
  2516. OUT LPINTERNET_CACHE_ENTRY_INFOW lpFirstCacheEntryInfo,
  2517. IN OUT LPDWORD lpdwFirstCacheEntryInfoBufferSize
  2518. );
  2519. #ifdef UNICODE
  2520. #define FindFirstUrlCacheEntry FindFirstUrlCacheEntryW
  2521. #else
  2522. #define FindFirstUrlCacheEntry FindFirstUrlCacheEntryA
  2523. #endif // !UNICODE
  2524. BOOLAPI
  2525. FindNextUrlCacheEntryA(
  2526. IN HANDLE hEnumHandle,
  2527. OUT LPINTERNET_CACHE_ENTRY_INFOA lpNextCacheEntryInfo,
  2528. IN OUT LPDWORD lpdwNextCacheEntryInfoBufferSize
  2529. );
  2530. BOOLAPI
  2531. FindNextUrlCacheEntryW(
  2532. IN HANDLE hEnumHandle,
  2533. OUT LPINTERNET_CACHE_ENTRY_INFOW lpNextCacheEntryInfo,
  2534. IN OUT LPDWORD lpdwNextCacheEntryInfoBufferSize
  2535. );
  2536. #ifdef UNICODE
  2537. #define FindNextUrlCacheEntry FindNextUrlCacheEntryW
  2538. #else
  2539. #define FindNextUrlCacheEntry FindNextUrlCacheEntryA
  2540. #endif // !UNICODE
  2541. BOOLAPI
  2542. FindCloseUrlCache(
  2543. IN HANDLE hEnumHandle
  2544. );
  2545. BOOLAPI
  2546. DeleteUrlCacheEntry(
  2547. IN LPCSTR lpszUrlName
  2548. );
  2549. //
  2550. // Autodial APIs
  2551. //
  2552. INTERNETAPI
  2553. DWORD
  2554. WINAPI
  2555. InternetDial(
  2556. IN HWND hwndParent,
  2557. IN LPTSTR lpszConnectoid,
  2558. IN DWORD dwFlags,
  2559. OUT LPDWORD lpdwConnection,
  2560. IN DWORD dwReserved);
  2561. // Flags for InternetDial - must not conflict with InternetAutodial flags
  2562. // as they are valid here also.
  2563. #define INTERNET_DIAL_UNATTENDED 0x8000
  2564. INTERNETAPI
  2565. DWORD
  2566. WINAPI
  2567. InternetHangUp(
  2568. IN DWORD dwConnection,
  2569. IN DWORD dwReserved);
  2570. #define INTERENT_GOONLINE_REFRESH 0x00000001
  2571. #define INTERENT_GOONLINE_MASK 0x00000001
  2572. INTERNETAPI
  2573. BOOL
  2574. WINAPI
  2575. InternetGoOnline(
  2576. IN LPTSTR lpszURL,
  2577. IN HWND hwndParent,
  2578. IN DWORD dwFlags);
  2579. INTERNETAPI
  2580. BOOL
  2581. WINAPI
  2582. InternetAutodial(
  2583. IN DWORD dwFlags,
  2584. IN DWORD dwReserved);
  2585. // Flags for InternetAutodial
  2586. #define INTERNET_AUTODIAL_FORCE_ONLINE 1
  2587. #define INTERNET_AUTODIAL_FORCE_UNATTENDED 2
  2588. #define INTERNET_AUTODIAL_FAILIFSECURITYCHECK 4
  2589. #define INTERNET_AUTODIAL_FLAGS_MASK (INTERNET_AUTODIAL_FORCE_ONLINE | INTERNET_AUTODIAL_FORCE_UNATTENDED | INTERNET_AUTODIAL_FAILIFSECURITYCHECK)
  2590. INTERNETAPI
  2591. BOOL
  2592. WINAPI
  2593. InternetAutodialHangup(
  2594. IN DWORD dwReserved);
  2595. INTERNETAPI
  2596. BOOL
  2597. WINAPI
  2598. InternetGetConnectedState(
  2599. OUT LPDWORD lpdwFlags,
  2600. IN DWORD dwReserved);
  2601. // Flags for InternetGetConnectedState
  2602. #define INTERNET_CONNECTION_MODEM 1
  2603. #define INTERNET_CONNECTION_LAN 2
  2604. #define INTERNET_CONNECTION_PROXY 4
  2605. #define INTERNET_CONNECTION_MODEM_BUSY 8
  2606. //
  2607. // Custom dial handler functions
  2608. //
  2609. // Custom dial handler prototype
  2610. typedef DWORD (CALLBACK * PFN_DIAL_HANDLER) (HWND, LPCSTR, DWORD, LPDWORD);
  2611. // Flags for custom dial handler
  2612. #define INTERNET_CUSTOMDIAL_CONNECT 0
  2613. #define INTERNET_CUSTOMDIAL_UNATTENDED 1
  2614. #define INTERNET_CUSTOMDIAL_DISCONNECT 2
  2615. // Custom dial handler supported functionality flags
  2616. #define INTERNET_CUSTOMDIAL_SAFE_FOR_UNATTENDED 1
  2617. #define INTERNET_CUSTOMDIAL_WILL_SUPPLY_STATE 2
  2618. #define INTERNET_CUSTOMDIAL_CAN_HANGUP 4
  2619. INTERNETAPI
  2620. BOOL
  2621. WINAPI
  2622. InternetSetDialState(
  2623. IN LPCTSTR lpszConnectoid,
  2624. IN DWORD dwState,
  2625. IN DWORD dwReserved);
  2626. // States for InternetSetDialState
  2627. #define INTERNET_DIALSTATE_DISCONNECTED 1
  2628. #if defined(__cplusplus)
  2629. }
  2630. #endif
  2631. /*
  2632. * Return packing to whatever it was before we
  2633. * entered this file
  2634. */
  2635. #pragma pack(pop, wininet)
  2636. #endif // !defined(_WININET_)