|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectphp.java.bridge.SessionFactory
php.java.bridge.http.ContextFactory
public final class ContextFactory
Create session, jsr223 contexts.
The ContextFactory may keep a promise (a "proxy") which one may evaluate to a session reference (for PHP/JSP session sharing), and/or it may reference a "half-executed" bridge for local channel re-directs (for "high speed" communication links).
A unique context instance should be created for each request and destroyed when the request is done.
Clients of the PHP clients may attach additional data and run with
a customized ContextFactory by using the visitor pattern,
see accept(IContextFactoryVisitor).
The string ID of the instance should be passed to the client, which may pass it back together with the getSession request or the "local channel re-direct". If the former happens, we invoke the promise and return the session object to the client. Different promises can evaluate to the same session object. For local channel re-directs the ContextFactory is given to a ContextRunner which handles the local channel communication.
When a php client is not interested in a context for 5 seconds (checked every 10 minutes), the context is destroyed: a) switching from the HTTP tunnel to the local channel of the ContextRunner or b) switching from the fresh context created by the client of the PHP client to the recycled, persistent context, costs only one round-trip. The time for such a context switch is usually much less than 10ms unless either the php client or the client that waits for the php client is traced. If 5 seconds is not enough during debugging, change the ORPHANED_TIMEOUT.
In a shared environment with k web contexts there can be up to n*k active JavaBridge/ContextFactory instances
(where n is the number of active php clients). All ContextFactories are kept in a shared, per-loader
map. But the map can only be accessed via get(String, ICredentials), which checks if the ContextFactory
belongs to the same ContextServer.
ServletContextFactory,
ContextServer,
SessionFactory.TIMER_DURATION| Nested Class Summary | |
|---|---|
static interface |
ContextFactory.ICredentials
The credentials provided by the web context, usually this ContextFactory. |
| Field Summary | |
|---|---|
static java.lang.String |
EMPTY_CONTEXT_NAME
This context name can be used when a ContextFactory is used outside of a servlet environment |
| Fields inherited from class php.java.bridge.SessionFactory |
|---|
TIMER_DURATION, TIMER_FREQ |
| Constructor Summary | |
|---|---|
ContextFactory(java.lang.String webContext)
|
|
| Method Summary | |
|---|---|
void |
accept(IContextFactoryVisitor visitor)
Use this method to attach a visitor to the ContextFactory. |
static IContextFactory |
addNew()
Create a new simple ContextFactory (a factory which creates an emulated JSR223 context) and add it to the list of context factories kept by this classloader. |
static IContextFactory |
addNew(java.lang.String webContext)
Create a new ContextFactory and add it to the list of context factories kept by this classloader. |
void |
destroy()
Destroy the factory |
static void |
destroyAll()
Remove all context factories from the classloader. |
static IContextFactory |
get(java.lang.String id,
ContextFactory.ICredentials server)
Only for internal use. |
JavaBridge |
getBridge()
Return the JavaBridge. |
java.lang.Object |
getContext()
Returns the context. |
java.lang.String |
getId()
Return the serializable ID of the context factory |
ISession |
getSession(java.lang.String name,
boolean clientIsNew,
int timeout)
Return a standard session, shared with JSP |
ISession |
getSimpleSession(java.lang.String name,
boolean clientIsNew,
int timeout)
Return a simple session which cannot be shared with JSP |
void |
recycle()
Recycle the factory for new reqests. |
void |
recycle(ContextFactory target)
Typically the visitor implements this method, it should attach itself to the target by calling target.accept(this). |
void |
recycle(java.lang.String id)
Synchronize the current state with id. |
static void |
removeAll()
Deprecated. |
void |
removeOrphaned()
Removes the unused context factory from the classloader's list of context factories. |
void |
setBridge(JavaBridge bridge)
|
void |
setContext(java.lang.Object context)
Set the Context into this factory. |
java.lang.String |
toString()
|
void |
waitFor()
Wait until this context is finished. |
| Methods inherited from class java.lang.Object |
|---|
equals, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| Field Detail |
|---|
public static final java.lang.String EMPTY_CONTEXT_NAME
| Constructor Detail |
|---|
public ContextFactory(java.lang.String webContext)
| Method Detail |
|---|
public static IContextFactory addNew(java.lang.String webContext)
webContext - The current web context, use ContextFactory.EMPTY_CONTEXT
if servlet web contexts are not available, config.getServletContext().getRealPath("") otherwise.
get(String, ICredentials)public static IContextFactory addNew()
get(String, ICredentials)
public static IContextFactory get(java.lang.String id,
ContextFactory.ICredentials server)
id
id - The IDserver - Your context server.
java.lang.SecurityException - if id belongs to a different ContextServer.addNew(String)public void recycle(ContextFactory target)
IContextFactorytarget.accept(this).
recycle in interface IContextFactorytarget - The persistent ContextFactory.IContextFactory.recycle(String),
accept(IContextFactoryVisitor),
IContextFactoryVisitor.visit(ContextFactory),
SimpleContextFactory
public void recycle(java.lang.String id)
throws java.lang.SecurityException
IContextFactoryWhen persistent connections are used, the bridge instances recycle their context factories (persistent php clients store their context id, so that they don't have to aquire a new one). However, a client of a php client may have passed a fresh context id. If this happened, the bridge calls this method, which may update the current context with the fresh values from id.
Typically the ContextFactory implements this method. It should find the ContextFactory for id, check that the Factory is not in use (and throw a SecurityException, if isInitialized() returns true), remove it by calling removeOrphaned() and call its recycle() method passing it the current ContextFactory.
recycle in interface IContextFactoryid - The fresh id
java.lang.SecurityException - if the found ContextFactory is initialized.IContextFactory.recycle(ContextFactory),
JavaBridge.recycle()public void recycle()
recycle in class SessionFactorypublic void destroy()
SessionFactory
destroy in interface IContextFactorydestroy in class SessionFactorypublic static void removeAll()
destroyAll()public static void destroyAll()
ContextServer
public void waitFor()
throws java.lang.InterruptedException
IContextFactory
waitFor in interface IContextFactoryjava.lang.InterruptedExceptionContextRunnerpublic java.lang.String getId()
IContextFactory
getId in interface IContextFactorypublic java.lang.String toString()
toString in class java.lang.Objectpublic java.lang.Object getContext()
getContext in interface IContextFactorygetContext in class SessionFactorygetContext()public void setContext(java.lang.Object context)
setContext in interface IContextFactorycontext - The context.addNew(String)public void setBridge(JavaBridge bridge)
public JavaBridge getBridge()
IContextFactory
getBridge in interface IContextFactorypublic void accept(IContextFactoryVisitor visitor)
visitor - The custom ContextFactory
public ISession getSimpleSession(java.lang.String name,
boolean clientIsNew,
int timeout)
name - The session nameclientIsNew - true, if the client wants a new sessiontimeout - expires in n seconds
public ISession getSession(java.lang.String name,
boolean clientIsNew,
int timeout)
getSession in interface IContextFactorygetSession in class SessionFactoryname - The session nameclientIsNew - true, if the client wants a new sessiontimeout - expires in n seconds
ISessionpublic void removeOrphaned()
IContextFactory
removeOrphaned in interface IContextFactory
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||