Package net.i2p.router.naming
Class BlockfileNamingService
- java.lang.Object
-
- net.i2p.client.naming.NamingService
-
- net.i2p.client.naming.DummyNamingService
-
- net.i2p.router.naming.BlockfileNamingService
-
public class BlockfileNamingService extends DummyNamingService
A naming service using the net.metanotion BlockFile database. This database contains the following skiplists:"%%__INFO__%%" is the master database skiplist, containing one entry: "info": a Properties, serialized with DataHelper functions: "version": "4" "created": Java long time (ms) "upgraded": Java long time (ms) (as of database version 2) "lists": Comma-separated list of host databases, to be searched in-order for lookups "%%__REVERSE__%%" is the reverse lookup skiplist (as of database version 2): The skiplist keys are Integers, the first 4 bytes of the hash of the dest. The skiplist values are Properties. There may be multiple entries in the properties, each one is a reverse mapping, as there may be more than one hostname for a given destination, or there could be collisions with the same first 4 bytes of the hash. Each property key is a hostname. Each property value is the empty string. For each host database, there is a skiplist containing the hosts for that database. The keys/values in these skiplists are as follows: key: a UTF-8 String value: a DestEntry, which is: a one-byte count of the Properties/Destination pairs to follow (as of database version 4, otherwise one) that many pairs of: Properties (serialized with DataHelper) Destination (serialized as usual). The DestEntry Properties typically contains: "a": The time added (Java long time in ms) "s": The original source of the entry (typically a file name or subscription URL) others TBD
All hostnames are converted to lower case.- Since:
- 0.8.7, moved from core to addressbook in 0.9.31
-
-
Field Summary
-
Fields inherited from class net.i2p.client.naming.DummyNamingService
BASE32_HASH_LENGTH, CACHE_MAX_SIZE, DEST_SIZE, PROP_B32
-
Fields inherited from class net.i2p.client.naming.NamingService
_context, _listeners, _log, _updaters, PROP_IMPL
-
-
Constructor Summary
Constructors Constructor Description BlockfileNamingService(I2PAppContext context)
Opens the database at hostsdb.blockfile or creates a new one and imports entries from hosts.txt, userhosts.txt, and privatehosts.txt.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
addDestination(String hostname, Destination d, Properties options)
Add a Destination to an existing hostname's entry in the addressbook.void
export(Writer out, Properties options)
Export in a hosts.txt format.Map<String,String>
getBase64Entries(Properties options)
This may be more or less efficient than getEntries(), depending on the implementation.Map<String,Destination>
getEntries(Properties options)
Warning - This will bring the whole database into memory if options is null, empty, or unsupported, use with caution.Set<String>
getNames(Properties options)
Destination
lookup(String hostname, Properties lookupOptions, Properties storedOptions)
Same as lookup(hostname) but with in and out options Note that whether this (and lookup(hostname)) resolve Base 32 addresses in the form {52 chars}.b32.i2p is NamingService-specific.List<Destination>
lookupAll(String hostname, Properties lookupOptions, List<Properties> storedOptions)
Return all of the entries found in the first list found, or in the list specified in lookupOptions.static void
main(String[] args)
BlockfileNamingService [force] force = force writableboolean
put(String hostname, Destination d, Properties options)
Add a hostname and Destination to the addressbook.boolean
putIfAbsent(String hostname, Destination d, Properties options)
Add a hostname and Destination to the addressbook.static Properties
readProperties(ByteArrayInputStream in)
Same as DataHelper.readProperties, UTF-8, unsorted, except that values may up to 4K bytes.boolean
remove(String hostname, Properties options)
Delete the entry.boolean
remove(String hostname, Destination d, Properties options)
Remove a hostname's entry only if it contains the Destination d.String
reverseLookup(Destination d, Properties options)
Same as reverseLookup(dest) but with options This implementation returns null.String
reverseLookup(Hash h)
Reverse lookup a hash.List<String>
reverseLookupAll(Destination d, Properties options)
Same as reverseLookupAll(dest) but with options This implementation returns the result from reverseLookup, or null.List<String>
reverseLookupAll(Hash h)
Reverse lookup a hash.void
shutdown()
Parent will call when removed.int
size(Properties options)
This implementation returns -1.-
Methods inherited from class net.i2p.client.naming.DummyNamingService
clearCache, getCache, putCache, removeCache
-
Methods inherited from class net.i2p.client.naming.NamingService
addDestination, addNamingService, addNamingService, createInstance, export, getConfiguration, getEntries, getName, getNames, getNamingServices, getParent, lookup, lookup, lookupAll, lookupBase32, lookupBase64, put, putAll, putIfAbsent, registerListener, registerUpdater, remove, remove, removeNamingService, requestUpdate, reverseLookup, reverseLookupAll, setConfiguration, size, start, toString, unregisterListener, unregisterUpdater, update
-
-
-
-
Constructor Detail
-
BlockfileNamingService
public BlockfileNamingService(I2PAppContext context)
Opens the database at hostsdb.blockfile or creates a new one and imports entries from hosts.txt, userhosts.txt, and privatehosts.txt. If not in router context, the database will be opened read-only unless the property i2p.naming.blockfile.writeInAppContext is true. Not designed for multiple instantiations or simultaneous use by multple JVMs.- Throws:
RuntimeException
- on fatal error
-
-
Method Detail
-
lookup
public Destination lookup(String hostname, Properties lookupOptions, Properties storedOptions)
Description copied from class:NamingService
Same as lookup(hostname) but with in and out options Note that whether this (and lookup(hostname)) resolve Base 32 addresses in the form {52 chars}.b32.i2p is NamingService-specific.- Overrides:
lookup
in classDummyNamingService
- Parameters:
hostname
- mixed case as it could be a keylookupOptions
- input parameter, NamingService-specific, can be nullstoredOptions
- output parameter, NamingService-specific, any stored properties will be added if non-null- Returns:
- dest or null
-
put
public boolean put(String hostname, Destination d, Properties options)
Description copied from class:NamingService
Add a hostname and Destination to the addressbook. Overwrites old entry if it exists. See also putIfAbsent() and update().- Overrides:
put
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", add to that list (default "hosts.txt") Use the key "s" for the source- Returns:
- success
-
putIfAbsent
public boolean putIfAbsent(String hostname, Destination d, Properties options)
Description copied from class:NamingService
Add a hostname and Destination to the addressbook. Fails if entry previously exists. See also put() and update().- Overrides:
putIfAbsent
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", add to that list (default "hosts.txt") Use the key "s" for the source. Key "a" will be added with the current time, unless "a" is present in options.- Returns:
- success
-
remove
public boolean remove(String hostname, Properties options)
Description copied from class:NamingService
Delete the entry.- Overrides:
remove
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", remove from that list (default "hosts.txt", NOT all lists)- Returns:
- true if removed successfully, false on error or if it did not exist
-
getEntries
public Map<String,Destination> getEntries(Properties options)
Description copied from class:NamingService
Warning - This will bring the whole database into memory if options is null, empty, or unsupported, use with caution.- Overrides:
getEntries
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", get from that list (default "hosts.txt", NOT all lists) Key "skip": skip that many entries Key "limit": max number to return Key "search": return only those matching substring Key "startsWith": return only those starting with ("[0-9]" allowed) Key "beginWith": start here in the iteration Don't use both startsWith and beginWith. Search, startsWith, and beginWith values must be lower case.- Returns:
- all mappings (matching the options if non-null) or empty Map if none; Returned Map is not necessarily sorted, implementation dependent
-
getBase64Entries
public Map<String,String> getBase64Entries(Properties options)
Description copied from class:NamingService
This may be more or less efficient than getEntries(), depending on the implementation. Warning - This will bring the whole database into memory if options is null, empty, or unsupported, use with caution. This implementation calls getEntries(options) and returns a SortedMap. Subclasses should override if they store base64 natively.- Overrides:
getBase64Entries
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", get from that list (default "hosts.txt", NOT all lists) Key "skip": skip that many entries Key "limit": max number to return Key "search": return only those matching substring Key "startsWith": return only those starting with ("[0-9]" allowed) Key "beginWith": start here in the iteration Don't use both startsWith and beginWith. Search, startsWith, and beginWith values must be lower case.- Returns:
- all mappings (matching the options if non-null) or empty Map if none; Returned Map is not necessarily sorted, implementation dependent
- Since:
- 0.9.20
-
export
public void export(Writer out, Properties options) throws IOException
Export in a hosts.txt format. Output is sorted. Caller must close writer.- Overrides:
export
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", get from that list (default "hosts.txt", NOT all lists) Key "search": return only those matching substring Key "startsWith": return only those starting with ("[0-9]" allowed) Key "beginWith": start here in the iteration- Throws:
IOException
- Since:
- 0.9.30 override NamingService to add stored authentication strings
-
getNames
public Set<String> getNames(Properties options)
- Overrides:
getNames
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", get from that list (default "hosts.txt", NOT all lists) Key "skip": skip that many entries Key "limit": max number to return Key "search": return only those matching substring Key "startsWith": return only those starting with ("[0-9]" allowed) Key "beginWith": start here in the iteration Don't use both startsWith and beginWith. Search, startsWith, and beginWith values must be lower case.- Returns:
- all known hostnames (matching the options if non-null) or empty Set if none; Returned Set is not necessarily sorted, implementation dependent
- Since:
- 0.9.20
-
reverseLookup
public String reverseLookup(Destination d, Properties options)
Description copied from class:NamingService
Same as reverseLookup(dest) but with options This implementation returns null. Subclasses implementing reverse lookups should override.- Overrides:
reverseLookup
in classNamingService
- Parameters:
options
- ignoredd
- non-null- Returns:
- hostname or null
- Since:
- 0.8.9
-
reverseLookup
public String reverseLookup(Hash h)
Description copied from class:NamingService
Reverse lookup a hash. This implementation returns null. Subclasses implementing reverse lookups should override.- Overrides:
reverseLookup
in classNamingService
- Parameters:
h
- non-null- Returns:
- a hostname for this hash, or
null
if none is known. It is safe for subclasses to always returnnull
if no reverse lookup is possible. - Since:
- 0.8.9
-
reverseLookupAll
public List<String> reverseLookupAll(Destination d, Properties options)
Description copied from class:NamingService
Same as reverseLookupAll(dest) but with options This implementation returns the result from reverseLookup, or null. Subclasses implementing reverse lookups should override.- Overrides:
reverseLookupAll
in classNamingService
- Parameters:
options
- ignoredd
- non-null- Returns:
- a non-empty list of hostnames for this Destination, or
null
- Since:
- 0.9.26
-
reverseLookupAll
public List<String> reverseLookupAll(Hash h)
Description copied from class:NamingService
Reverse lookup a hash. This implementation returns the result from reverseLookup, or null. Subclasses implementing reverse lookups should override.- Overrides:
reverseLookupAll
in classNamingService
- Parameters:
h
- non-null- Returns:
- a non-empty list of hostnames for this hash, or
null
if none is known. It is safe for subclasses to always returnnull
if no reverse lookup is possible. - Since:
- 0.9.26
-
size
public int size(Properties options)
Description copied from class:NamingService
This implementation returns -1. Most subclasses should override.- Overrides:
size
in classNamingService
- Parameters:
options
- If non-null and contains the key "list", return the size of that list (default "hosts.txt", NOT all lists)- Returns:
- number of entries (matching the options if non-null) or -1 if unknown
-
shutdown
public void shutdown()
Description copied from class:NamingService
Parent will call when removed. If this is the root naming service, the core will stop it. Should not be called by others.- Overrides:
shutdown
in classNamingService
-
lookupAll
public List<Destination> lookupAll(String hostname, Properties lookupOptions, List<Properties> storedOptions)
Return all of the entries found in the first list found, or in the list specified in lookupOptions. Does not aggregate all destinations found in all lists. If storedOptions is non-null, it must be a List that supports null entries. If the returned value (the List of Destinations) is non-null, the same number of Properties objects will be added to storedOptions. If no properties were found for a given Destination, the corresponding entry in the storedOptions list will be null.- Overrides:
lookupAll
in classNamingService
- Parameters:
lookupOptions
- input parameter, NamingService-specific, may be nullstoredOptions
- output parameter, NamingService-specific, any stored properties will be added if non-null- Returns:
- non-empty List of Destinations, or null if nothing found
- Since:
- 0.9.26
-
addDestination
public boolean addDestination(String hostname, Destination d, Properties options)
Add a Destination to an existing hostname's entry in the addressbook. This does not prevent adding b32. Caller must check.- Overrides:
addDestination
in classNamingService
- Parameters:
options
- NamingService-specific, may be null- Returns:
- success
- Since:
- 0.9.26
-
remove
public boolean remove(String hostname, Destination d, Properties options)
Remove a hostname's entry only if it contains the Destination d. If the NamingService supports multiple Destinations per hostname, and this is the only Destination, removes the entire entry. If aditional Destinations remain, it only removes the specified Destination from the entry.- Overrides:
remove
in classNamingService
- Parameters:
options
- NamingService-specific, may be null- Returns:
- true if entry containing d was successfully removed.
- Since:
- 0.9.26
-
readProperties
public static Properties readProperties(ByteArrayInputStream in) throws DataFormatException, IOException
Same as DataHelper.readProperties, UTF-8, unsorted, except that values may up to 4K bytes. Throws DataFormatException on duplicate key- Parameters:
in
- stream to read the mapping from- Returns:
- a Properties
- Throws:
DataFormatException
- if the format is invalidIOException
- if there is a problem reading the data- Since:
- 0.9.26
-
main
public static void main(String[] args)
BlockfileNamingService [force] force = force writable
-
-