com.sun.jna.platform.win32.Wininet Maven / Gradle / Ivy
/* Copyright (c) 2015 Michael Freeman, All Rights Reserved
*
* The contents of this file is dual-licensed under 2
* alternative Open Source/Free licenses: LGPL 2.1 or later and
* Apache License 2.0. (starting with JNA version 4.0.0).
*
* You can freely decide which license you want to apply to
* the project.
*
* You may obtain a copy of the LGPL License at:
*
* http://www.gnu.org/licenses/licenses.html
*
* A copy is also included in the downloadable source code package
* containing JNA, in file "LGPL2.1".
*
* You may obtain a copy of the Apache License at:
*
* http://www.apache.org/licenses/
*
* A copy is also included in the downloadable source code package
* containing JNA, in file "AL2.0".
*/
package com.sun.jna.platform.win32;
import com.sun.jna.Native;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
import com.sun.jna.Structure.FieldOrder;
import com.sun.jna.Union;
import com.sun.jna.platform.win32.WinNT.HANDLE;
import com.sun.jna.ptr.IntByReference;
import com.sun.jna.win32.StdCallLibrary;
import com.sun.jna.win32.W32APIOptions;
/**
* Functions in WinInet.dll
*/
public interface Wininet extends StdCallLibrary {
/**
* A usable instance of this interface
*/
Wininet INSTANCE = Native.load("wininet", Wininet.class, W32APIOptions.DEFAULT_OPTIONS);
/**
* Normal cache entry; can be deleted to recover space for new entries.
*/
int NORMAL_CACHE_ENTRY = 1;
/**
* Sticky cache entry that is exempt from scavenging for the amount of time
* specified by dwExemptDelta.
* The default value set by CommitUrlCacheEntryA and CommitUrlCacheEntryW is
* one day.
*/
int STICKY_CACHE_ENTRY = 4;
/**
* Cache entry file that has been edited externally. This cache entry type
* is exempt from scavenging.
*/
int EDITED_CACHE_ENTRY = 8;
/**
* Not currently implemented.
*/
int TRACK_OFFLINE_CACHE_ENTRY = 16;
/**
* Not currently implemented.
*/
int TRACK_ONLINE_CACHE_ENTRY = 32;
/**
* Partial response cache entry.
*/
int SPARSE_CACHE_ENTRY = 65536;
/**
* Cookie cache entry.
*/
int COOKIE_CACHE_ENTRY = 1048576;
/**
* Visited link cache entry.
*/
int URLHISTORY_CACHE_ENTRY = 2097152;
/**
* Closes the specified cache enumeration handle.
*
* @param hFind
* Handle returned by a previous call to the
* FindFirstUrlCacheEntry function.
* @return Returns TRUE if successful, or FALSE otherwise. To get extended
* error information, call GetLastError.
*/
boolean FindCloseUrlCache(HANDLE hFind);
/**
* @param lpszUrlName
* String that contains the name of the source that corresponds
* to the cache entry.
* @return Returns TRUE if successful, or FALSE otherwise.
* To get extended error information, call GetLastError.
* Possible error values include the following.
*
* - ERROR_ACCESS_DENIED:The file is locked or in use. The
* entry is marked and deleted when the file is unlocked.
* - ERROR_FILE_NOT_FOUND:The file is not in the cache.
*
*
*/
boolean DeleteUrlCacheEntry(String lpszUrlName);
/**
* Begins the enumeration of the Internet cache.
*
* @param lpszUrlSearchPattern
* A pointer to a string that contains the source name pattern to
* search for.
* This parameter can only be set to "cookie:", "visited:", or
* NULL.
* Set this parameter to "cookie:" to enumerate the cookies or
* "visited:" to enumerate the URL History entries in the cache.
*
* If this parameter is NULL, FindFirstUrlCacheEntry returns all
* content entries in the cache.
* @param lpFirstCacheEntryInfo
* Pointer to an INTERNET_CACHE_ENTRY_INFO structure.
* @param lpcbCacheEntryInfo
* Pointer to a variable that specifies the size of the
* lpFirstCacheEntryInfo buffer, in bytes.
* When the function returns, the variable contains the number of
* bytes copied to the buffer, or the required size needed to
* retrieve the cache entry, in bytes.
* @return Returns a handle that the application can use in the
* FindNextUrlCacheEntry function to retrieve subsequent entries in
* the cache.
* If the function fails, the return value is NULL. To get extended
* error information, call GetLastError.
* ERROR_INSUFFICIENT_BUFFER indicates that the size of
* lpFirstCacheEntryInfo as specified by
* lpdwFirstCacheEntryInfoBufferSize is not sufficient to contain
* all the information.
* The value returned in lpdwFirstCacheEntryInfoBufferSize indicates
* the buffer size necessary to contain all the information.
*/
HANDLE FindFirstUrlCacheEntry(String lpszUrlSearchPattern, INTERNET_CACHE_ENTRY_INFO lpFirstCacheEntryInfo,
IntByReference lpcbCacheEntryInfo);
/**
* @param hEnumHandle
* Handle to the enumeration obtained from a previous call to
* FindFirstUrlCacheEntry.
* @param lpNextCacheEntryInfo
* Pointer to an INTERNET_CACHE_ENTRY_INFO structure that
* receives information about the cache entry.
* @param lpcbCacheEntryInfo
* Pointer to a variable that specifies the size of the
* lpNextCacheEntryInfo buffer, in bytes.
* When the function returns, the variable contains the number of
* bytes copied to the buffer, or the size of the buffer required
* to retrieve the cache entry, in bytes.
* @return Returns TRUE if successful, or FALSE otherwise.
* To get extended error information, call GetLastError.
* Possible error values include the following.
*
* - ERROR_INSUFFICIENT_BUFFER:The size of
* lpNextCacheEntryInfo as specified by
* lpdwNextCacheEntryInfoBufferSize is not sufficient to contain all
* the information.
* The value returned in lpdwNextCacheEntryInfoBufferSize indicates
* the buffer size necessary to contain all the information.
* - ERROR_NO_MORE_ITEMS:The enumeration completed.
*
*/
boolean FindNextUrlCacheEntry(HANDLE hEnumHandle, INTERNET_CACHE_ENTRY_INFO lpNextCacheEntryInfo,
IntByReference lpcbCacheEntryInfo);
/**
* Contains information about an entry in the Internet cache.
*
*
*
* typedef struct _INTERNET_CACHE_ENTRY_INFO {
* DWORD dwStructSize;
* LPTSTR lpszSourceUrlName;
* LPTSTR lpszLocalFileName;
* DWORD CacheEntryType;
* DWORD dwUseCount;
* DWORD dwHitRate;
* DWORD dwSizeLow;
* DWORD dwSizeHigh;
* FILETIME LastModifiedTime;
* FILETIME ExpireTime;
* FILETIME LastAccessTime;
* FILETIME LastSyncTime;
* LPTSTR lpHeaderInfo;
* DWORD dwHeaderInfoSize;
* LPTSTR lpszFileExtension;
* union {
* DWORD dwReserved;
* DWORD dwExemptDelta;
* };
* } INTERNET_CACHE_ENTRY_INFO, *LPINTERNET_CACHE_ENTRY_INFO;
*
*
*
*
* @see MSDN
*/
@FieldOrder({"dwStructSize", "lpszSourceUrlName", "lpszLocalFileName",
"CacheEntryType", "dwUseCount", "dwHitRate", "dwSizeLow", "dwSizeHigh", "LastModifiedTime",
"ExpireTime", "LastAccessTime", "LastSyncTime", "lpHeaderInfo", "dwHeaderInfoSize",
"lpszFileExtension", "u", "additional"})
static class INTERNET_CACHE_ENTRY_INFO extends Structure {
/**
* Size of this structure, in bytes. This value can be used to help
* determine the version of the cache system.
*/
public int dwStructSize;
/**
* Pointer to a null-terminated string that contains the URL name. The
* string occupies the memory area at the end of this structure.
*/
public Pointer lpszSourceUrlName;
/**
* Pointer to a null-terminated string that contains the local file
* name. The string occupies the memory area at the end of this
* structure.
*/
public Pointer lpszLocalFileName;
/**
* A bitmask indicating the type of cache entry and its properties.
* The cache entry types include: history entries
* (URLHISTORY_CACHE_ENTRY), cookie entries (COOKIE_CACHE_ENTRY), and
* normal cached content (NORMAL_CACHE_ENTRY).
*
* This member can be zero or more of the following property flags, and
* cache type flags listed below.
*
* - EDITED_CACHE_ENTRY: Cache entry file that has been edited
* externally. This cache entry type is exempt from scavenging.
* - SPARSE_CACHE_ENTRY: Partial response cache entry.
* - STICKY_CACHE_ENTRY: Sticky cache entry that is exempt from
* scavenging for the amount of time specified by dwExemptDelta.
* The default value set by CommitUrlCacheEntryA and
* CommitUrlCacheEntryW is one day.
* - TRACK_OFFLINE_CACHE_ENTRY: Not currently implemented.
* - TRACK_ONLINE_CACHE_ENTRY: Not currently implemented.
*
*
* The following list contains the cache type flags.
*
* - COOKIE_CACHE_ENTRY: Cookie cache entry.
* - NORMAL_CACHE_ENTRY: Normal cache entry; can be deleted to
* recover space for new entries.
* - URLHISTORY_CACHE_ENTRY: Visited link cache entry.
*
*/
public int CacheEntryType;
/**
* Current number of WinInet callers using the cache entry.
*/
public int dwUseCount;
/**
* Number of times the cache entry was retrieved.
*/
public int dwHitRate;
/**
* Low-order portion of the file size, in bytes.
*/
public int dwSizeLow;
/**
* High-order portion of the file size, in bytes.
*/
public int dwSizeHigh;
/**
* FILETIME structure that contains the last modified time of this URL,
* in Greenwich mean time format.
*/
public Kernel32.FILETIME LastModifiedTime;
/**
* FILETIME structure that contains the expiration time of this file, in
* Greenwich mean time format.
*/
public Kernel32.FILETIME ExpireTime;
/**
* FILETIME structure that contains the last accessed time, in Greenwich
* mean time format.
*/
public Kernel32.FILETIME LastAccessTime;
/**
* FILETIME structure that contains the last time the cache was
* synchronized.
*/
public Kernel32.FILETIME LastSyncTime;
/**
* Pointer to a buffer that contains the header information. The buffer
* occupies the memory at the end of this structure.
*/
public Pointer lpHeaderInfo;
/**
* Size of the lpHeaderInfo buffer, in TCHARs.
*/
public int dwHeaderInfoSize;
/**
* Pointer to a string that contains the file name extension used to
* retrieve the data as a file. The string occupies the memory area at
* the end of this structure.
*/
public Pointer lpszFileExtension;
/**
* A union of the last two distinct fields in INTERNET_CACHE_ENTRY_INFO
*/
public UNION u;
/**
* Additional data (the path and URLs mentioned previously, and more)
*/
public byte[] additional;
public INTERNET_CACHE_ENTRY_INFO(int size) {
additional = new byte[size];
}
/**
* A union of the last two distinct fields in INTERNET_CACHE_ENTRY_INFO
*
*
*
* union {
* DWORD dwReserved;
* DWORD dwExemptDelta;
* };
*
*/
public static class UNION extends Union {
/**
* Reserved. Must be zero.
*/
public int dwReserved;
/**
* Exemption time from the last accessed time, in seconds.
*/
public int dwExemptDelta;
}
@Override
public String toString() {
return (lpszLocalFileName == null ? "" : lpszLocalFileName.getWideString(0) + " => ")
+ (lpszSourceUrlName == null ? "null" : lpszSourceUrlName.getWideString(0));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy