net.i2p.app
Interface ClientApp

All Known Subinterfaces:
RouterApp
All Known Implementing Classes:
BOB, ConsoleUpdateManager, JettyStart, NewsManager, RouterConsoleRunner, SAMBridge, 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
 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 Detail

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