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 TBDAll host names 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
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 Details
-
BlockfileNamingService
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 Details
-
lookup
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
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
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
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
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
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
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
- 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 host names (matching the options if non-null) or empty Set if none; Returned Set is not necessarily sorted, implementation dependent
- Since:
- 0.9.20
-
reverseLookup
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:
- host name or null
- Since:
- 0.8.9
-
reverseLookup
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 host name 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
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 host names for this Destination, or
null
- Since:
- 0.9.26
-
reverseLookupAll
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 host names 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
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
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
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, IOExceptionSame 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
BlockfileNamingService [force] force = force writable
-