Package net.i2p.app

Interface ClientApp

All Known Subinterfaces:
RouterApp
All Known Implementing Classes:
Analysis, BOB, ConsoleUpdateManager, I2PControlController, JettyStart, Main, NewsManager, RouterConsoleRunner, SAMBridge, SnarkManager, SocketController, StatSummarizer, TunnelControllerGroup, UrlLauncher

public interface ClientApp
If a class started via clients.config implements this interface, it will be used to manage the client, instead of starting with main() Clients implementing this interface MUST provide the following constructor: public MyClientApp(I2PAppContext context, ClientAppManager listener, String[] args) {...} All parameters are non-null. This constructor is for instantiation only. Do not take a long time. Do not block. Never start threads or processes in it. The ClientAppState of the returned object must be INITIALIZED, or else throw something. The startup() method will be called next. Never ever hold a static reference to the context or anything derived from it.
Since:
0.9.4
  • Method Summary

    Modifier and Type Method Description
    String getDisplayName()
    The display name of the ClientApp, used in user interfaces.
    String getName()
    The generic name of the ClientApp, used for registration, e.g.
    ClientAppState getState()
    The current state of the ClientApp.
    void shutdown​(String[] args)
    Do not take a long time.
    void startup()
    Do not take a long time.
  • Method Details

    • startup

      void startup() throws Throwable
      Do not take a long time. Do not block. Start threads here if necessary. Client must call ClientAppManager.notify() at least once within this method to change the state from INITIALIZED to something else. Will not be called multiple times on the same object.
      Throws:
      Throwable
    • shutdown

      void shutdown​(String[] args) throws Throwable
      Do not take a long time. Do not block. Use a thread if necessary. If previously running, client must call ClientAppManager.notify() at least once within this method to change the state to STOPPING or STOPPED. May be called multiple times on the same object, in any state.
      Parameters:
      args - generally null but could be stopArgs from clients.config
      Throws:
      Throwable
    • getState

      ClientAppState getState()
      The current state of the ClientApp.
      Returns:
      non-null
    • getName

      String getName()
      The generic name of the ClientApp, used for registration, e.g. "console". Do not translate.
      Returns:
      non-null
    • getDisplayName

      String getDisplayName()
      The display name of the ClientApp, used in user interfaces. The app must translate.
      Returns:
      non-null