Package net.i2p.router
Class CommSystemFacade
java.lang.Object
net.i2p.router.CommSystemFacade
- All Implemented Interfaces:
- Service
- Direct Known Subclasses:
- CommSystemFacadeImpl,- VMCommSystem
Manages the communication subsystem between peers, including connections, 
 listeners, transports, connection keys, etc.
- 
Nested Class SummaryNested Classes
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected static final Stringstatic final shortWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple peoplestatic final shortWe have no network interface at all enabled transportsstatic final shortOur detection system is broken (SSU bind port failed)static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple people We can receive unsolicited connections on IPv6.static final shortWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple people We might be able to receive unsolicited connections on IPv6.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortWe have an IPv6 transport enabled and a public IPv6 address.static final shortThese must be increasing in "badness" (see TransportManager.java), but UNKNOWN must be last.static final shortWe are able to talk to peers that we initiate communication with, but cannot receive unsolicited connections, i.e.static final shortOur reachability is unknown on all
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionabstract intHow many peers are we currently connected to, that we have sent a message to or received a message from in the last five minutes.abstract intHow many peers are we currently connected to, that we have sent a message to in the last minute.Create the list of RouterAddress structures based on the router's configvoidforceDisconnect(Hash peer) Tell the comm system to disconnect from this peer.Get the country code mapgetCountry(Hash peer) getCountryName(String code) Hook for pluggable transport creation.Get all the peers we are connected to.longgetFramedAveragePeerClockSkew(int percentToInclude) Return framed average clock skew of connected peers in seconds, or null if we cannot answer.byte[]getStatus().toStatusString(), translated if available.Median clock skew of connected peers in seconds, or null if we cannot answer.shortDeprecated.use getStatus()Determine under what conditions we are remotely reachable.Factory for making X25519 key pairs.booleanbooleanhaveInboundCapacity(int pct) booleanhaveOutboundCapacity(int pct) voidRouter must call after netdb is initializedbooleanisBacklogged(Hash peer) booleanisDummy()abstract booleanisEstablished(Hash peer) booleanbooleanisInStrictCountry(Hash peer) booleanbooleanvoidmayDisconnect(Hash peer) Tell the comm system that we may disconnect from this peer.voidnotifyRemoveAddress(boolean ipv6) Tell other transports our address changedvoidnotifyRemoveAddress(RouterAddress address) Tell other transports our address changedvoidnotifyReplaceAddress(RouterAddress address) Tell other transports our address changedabstract voidvoidqueueLookup(byte[] ip) voidDeprecated.unusedvoidPluggable transportrenderPeerHTML(Hash peer) voidrenderStatusHTML(Writer out) voidrenderStatusHTML(Writer out, String urlBase, int sortFlags) voidPluggable transportbooleanwasUnreachable(Hash peer) 
- 
Field Details- 
ROUTER_BUNDLE_NAME- Since:
- 0.9.45
- See Also:
 
- 
STATUS_OKpublic static final short STATUS_OKThese must be increasing in "badness" (see TransportManager.java), but UNKNOWN must be last. We are able to receive unsolicited connections on all enabled transports- See Also:
 
- 
STATUS_IPV4_OK_IPV6_UNKNOWNpublic static final short STATUS_IPV4_OK_IPV6_UNKNOWNWe have an IPv6 transport enabled and a public IPv6 address. We can receive unsolicited connections on IPv4. We might be able to receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_OK_IPV6_FIREWALLEDpublic static final short STATUS_IPV4_OK_IPV6_FIREWALLEDWe have an IPv6 transport enabled and a public IPv6 address. We can receive unsolicited connections on IPv4. We cannot receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_UNKNOWN_IPV6_OKpublic static final short STATUS_IPV4_UNKNOWN_IPV6_OKWe have an IPv6 transport enabled and a public IPv6 address. We may be able to receive unsolicited connections on IPv4. We can receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_FIREWALLED_IPV6_OKpublic static final short STATUS_IPV4_FIREWALLED_IPV6_OKWe have an IPv6 transport enabled and a public IPv6 address. We cannot receive unsolicited connections on IPv4. We can receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_DISABLED_IPV6_OKpublic static final short STATUS_IPV4_DISABLED_IPV6_OKWe have an IPv6 transport enabled and a public IPv6 address. IPv4 is disabled. We can receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_SNAT_IPV6_OKpublic static final short STATUS_IPV4_SNAT_IPV6_OKWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple people We can receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_DIFFERENTpublic static final short STATUS_DIFFERENTWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple people- See Also:
 
- 
STATUS_IPV4_SNAT_IPV6_UNKNOWNpublic static final short STATUS_IPV4_SNAT_IPV6_UNKNOWNWe are behind a symmetric NAT which will make our 'from' address look differently when we talk to multiple people We might be able to receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_FIREWALLED_IPV6_UNKNOWNpublic static final short STATUS_IPV4_FIREWALLED_IPV6_UNKNOWNWe have an IPv6 transport enabled and a public IPv6 address. We cannot receive unsolicited connections on IPv4. We might be able to receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_REJECT_UNSOLICITEDpublic static final short STATUS_REJECT_UNSOLICITEDWe are able to talk to peers that we initiate communication with, but cannot receive unsolicited connections, i.e. Firewalled, on all enabled transports.- See Also:
 
- 
STATUS_IPV4_UNKNOWN_IPV6_FIREWALLEDpublic static final short STATUS_IPV4_UNKNOWN_IPV6_FIREWALLEDWe have an IPv6 transport enabled and a public IPv6 address. We may be able to receive unsolicited connections on IPv4. We cannot receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_DISABLED_IPV6_UNKNOWNpublic static final short STATUS_IPV4_DISABLED_IPV6_UNKNOWNWe have an IPv6 transport enabled and a public IPv6 address. IPv4 is disabled. We might be able to receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_IPV4_DISABLED_IPV6_FIREWALLEDpublic static final short STATUS_IPV4_DISABLED_IPV6_FIREWALLEDWe have an IPv6 transport enabled and a public IPv6 address. IPv4 is disabled. We can receive unsolicited connections on IPv6.- Since:
- 0.9.20
- See Also:
 
- 
STATUS_DISCONNECTEDpublic static final short STATUS_DISCONNECTEDWe have no network interface at all enabled transports- Since:
- 0.9.4
- See Also:
 
- 
STATUS_HOSEDpublic static final short STATUS_HOSEDOur detection system is broken (SSU bind port failed)- See Also:
 
- 
STATUS_UNKNOWNpublic static final short STATUS_UNKNOWNOur reachability is unknown on all- See Also:
 
 
- 
- 
Constructor Details- 
CommSystemFacadepublic CommSystemFacade()
 
- 
- 
Method Details- 
processMessage
- 
renderStatusHTML- Throws:
- IOException
 
- 
renderStatusHTML- Specified by:
- renderStatusHTMLin interface- Service
- Throws:
- IOException
 
- 
createAddressesCreate the list of RouterAddress structures based on the router's config
- 
countActivePeerspublic abstract int countActivePeers()How many peers are we currently connected to, that we have sent a message to or received a message from in the last five minutes.
- 
countActiveSendPeerspublic abstract int countActiveSendPeers()How many peers are we currently connected to, that we have sent a message to in the last minute. Unused for anything, to be removed.
- 
haveInboundCapacitypublic boolean haveInboundCapacity(int pct) 
- 
haveOutboundCapacitypublic boolean haveOutboundCapacity(int pct) 
- 
haveHighOutboundCapacitypublic boolean haveHighOutboundCapacity()
- 
getMostRecentErrorMessages
- 
getMedianPeerClockSkewMedian clock skew of connected peers in seconds, or null if we cannot answer. CommSystemFacadeImpl overrides this.
- 
getFramedAveragePeerClockSkewpublic long getFramedAveragePeerClockSkew(int percentToInclude) Return framed average clock skew of connected peers in seconds, or null if we cannot answer. CommSystemFacadeImpl overrides this.
- 
getReachabilityStatusDeprecated.use getStatus()Determine under what conditions we are remotely reachable. For internal use only. Not recommended for plugins or embedded applications, as the integer codes may change. Use getStatus() instead.
- 
getStatusDetermine under what conditions we are remotely reachable.- Since:
- 0.9.20
 
- 
getLocalizedStatusStringgetStatus().toStatusString(), translated if available.- Since:
- 0.9.45
 
- 
recheckReachabilityDeprecated.unused
- 
isBacklogged
- 
wasUnreachable
- 
isEstablished
- 
getIP
- 
queueLookuppublic void queueLookup(byte[] ip) 
- 
mayDisconnectTell the comm system that we may disconnect from this peer. This is advisory only.- Since:
- 0.9.24
 
- 
forceDisconnectTell the comm system to disconnect from this peer.- Since:
- 0.9.38
 
- 
getOurCountry- Since:
- 0.8.11
 
- 
isInStrictCountrypublic boolean isInStrictCountry()- Since:
- 0.8.13
 
- 
isInStrictCountry- Since:
- 0.9.16
 
- 
isInStrictCountry- Since:
- 0.9.16
 
- 
getCountry
- 
getCountryName
- 
getCountriesGet the country code map- Returns:
- Map of two-letter lower case code to untranslated country name, unmodifiable
- Since:
- 0.9.53
 
- 
renderPeerHTML
- 
getTransports- Returns:
- SortedMap of style to Transport (a copy)
- Since:
- 0.9.31
 
- 
getEstablishedGet all the peers we are connected to. This should be more efficient than repeated calls to isEstablished() if you have to check a lot.- Returns:
- the hashes of all the routers we are connected to, non-null
- Since:
- 0.9.34
 
- 
isDummypublic boolean isDummy()- Since:
- 0.8.13
 
- 
isRunningpublic boolean isRunning()- Since:
- 0.9.53
 
- 
notifyReplaceAddressTell other transports our address changed
- 
notifyRemoveAddressTell other transports our address changed- Since:
- 0.9.20
 
- 
notifyRemoveAddresspublic void notifyRemoveAddress(boolean ipv6) Tell other transports our address changed- Since:
- 0.9.20
 
- 
registerTransportPluggable transport- Since:
- 0.9.16
 
- 
unregisterTransportPluggable transport- Since:
- 0.9.16
 
- 
getDHFactoryHook for pluggable transport creation.- Since:
- 0.9.16
 
- 
getXDHFactoryFactory for making X25519 key pairs.- Since:
- 0.9.46
 
- 
initGeoIPpublic void initGeoIP()Router must call after netdb is initialized- Since:
- 0.9.41
 
 
-