|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.openspaces.core.space.AbstractSpaceFactoryBean
public abstract class AbstractSpaceFactoryBean
Base class for most space factory beans responsible for creating/finding IJSpace
implementation.
Provides support for raising Spring application events: BeforeSpaceModeChangeEvent
and
AfterSpaceModeChangeEvent
alerting other beans of the current space mode
(primary/backup). Beans that wish to be notified of it should implement Spring
ApplicationListener
. Note that this space mode events might
be raised more than once for the same space mode, and beans that listen to it should take it into
account.
The space mode event will be raised regardless of the space "type" that is used. For embedded
spaces, an actual space mode event listener will be registered with the actual cluster member (if
not in cluster mode, the actual space). For remote space lookups (jini/rmi), no listener will be
registered and Space mode events will still be raised during context refresh with a
PRIMARY
mode in order to allow beans to be written regardless of how the space is
looked up.
Derived classes should implement the doCreateSpace()
to obtain the IJSpace
.
Field Summary | |
---|---|
protected Log |
logger
|
Constructor Summary | |
---|---|
AbstractSpaceFactoryBean()
|
Method Summary | |
---|---|
void |
afterPropertiesSet()
Initializes the space by calling the doCreateSpace() . |
void |
destroy()
Destroys the space and unregisters the internal space mode listener (if registered). |
protected abstract IJSpace |
doCreateSpace()
Responsible for creating/finding the actual IJSpace implementation. |
protected void |
fireSpaceAfterBackupEvent()
Sends AfterSpaceModeChangeEvent events with space mode SpaceMode.BACKUP to all beans in the application context
that implement the SpaceAfterBackupListener interface. |
protected void |
fireSpaceAfterPrimaryEvent()
Sends AfterSpaceModeChangeEvent events with space mode SpaceMode.PRIMARY to all beans in the application context
that implement the SpaceAfterPrimaryListener interface. |
protected void |
fireSpaceBeforeBackupEvent()
Sends BeforeSpaceModeChangeEvent events with space mode SpaceMode.BACKUP to all beans in the application context
that implement the SpaceBeforeBackupListener interface. |
protected void |
fireSpaceBeforePrimaryEvent()
Sends BeforeSpaceModeChangeEvent events with space mode SpaceMode.PRIMARY to all beans in the application context
that implement the SpaceBeforePrimaryListener interface. |
protected ApplicationContext |
getApplicationContext()
|
String |
getName()
|
Object |
getObject()
Spring factory bean returning the IJSpace created during the bean initialization
(afterPropertiesSet() ). |
Class<? extends IJSpace> |
getObjectType()
Returns the object type of the factory bean. |
protected SecurityConfig |
getSecurityConfig()
|
ServiceDetails[] |
getServicesDetails()
Retruns one or more service details that the service exposes. |
boolean |
isAlive()
Returns if this space is alive or not by pinging the Space and if it is considered healthy. |
boolean |
isMemberAliveEnabled()
Returns the setEnableMemberAliveIndicator(Boolean) flag. |
protected boolean |
isRegisterForSpaceModeNotifications()
Returns if the space should register for primary backup notifications. |
boolean |
isSingleton()
Returns true since this factory is a singleton. |
void |
onApplicationEvent(ApplicationEvent applicationEvent)
If ContextRefreshedEvent is raised will send two extra events:
BeforeSpaceModeChangeEvent and AfterSpaceModeChangeEvent with the current
space mode. |
void |
process(com.gigaspaces.internal.dump.InternalDump dump)
|
void |
setApplicationContext(ApplicationContext applicationContext)
Injected by Spring thanks to ApplicationContextAware . |
void |
setBeanName(String name)
|
void |
setEnableMemberAliveIndicator(Boolean enableMemberAliveIndicator)
Should this Space bean control if the cluster member is alive or not. |
void |
setPrimaryBackupListener(com.gigaspaces.cluster.activeelection.ISpaceModeListener primaryBackupListener)
Sets a custom primary backup listener |
void |
setRegisterForSpaceModeNotifications(boolean registerForSpaceMode)
Sets if the space should register for primary backup (mode) notifications. |
void |
setSecurityConfig(SecurityConfig securityConfig)
Sets security configuration for the Space. |
void |
setUserDetails(UserDetails userDetails)
Sets the security configuration with the provided custom user details. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected Log logger
Constructor Detail |
---|
public AbstractSpaceFactoryBean()
Method Detail |
---|
public void setRegisterForSpaceModeNotifications(boolean registerForSpaceMode)
rmi
or jini
protocols.
public void setUserDetails(UserDetails userDetails)
userDetails
- a custom user details.public void setSecurityConfig(SecurityConfig securityConfig)
protected SecurityConfig getSecurityConfig()
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException
ApplicationContextAware
.
setApplicationContext
in interface ApplicationContextAware
BeansException
protected ApplicationContext getApplicationContext()
public void setBeanName(String name)
setBeanName
in interface BeanNameAware
public void setPrimaryBackupListener(com.gigaspaces.cluster.activeelection.ISpaceModeListener primaryBackupListener)
public void setEnableMemberAliveIndicator(Boolean enableMemberAliveIndicator)
true
if the Space started is an embedded Space, and false
if the it is connected to a remote Space.
public void afterPropertiesSet() throws DataAccessException
doCreateSpace()
.
Registers with the Space an internal space mode listener in order to be able to send Spring
level BeforeSpaceModeChangeEvent
and AfterSpaceModeChangeEvent
for primary
and backup handling of different beans within the context. The registration is based on
isRegisterForSpaceModeNotifications()
.
afterPropertiesSet
in interface InitializingBean
DataAccessException
public void destroy() throws Exception
destroy
in interface DisposableBean
Exception
public void onApplicationEvent(ApplicationEvent applicationEvent)
ContextRefreshedEvent
is raised will send two extra events:
BeforeSpaceModeChangeEvent
and AfterSpaceModeChangeEvent
with the current
space mode. This is done since other beans that use this events might not catch them while
the context is constructed.
Note, this will mean that events with the same Space mode might be raised, one after the other, and Spring beans that listens for them should take it into account.
onApplicationEvent
in interface ApplicationListener
public Object getObject()
IJSpace
created during the bean initialization
(afterPropertiesSet()
).
getObject
in interface FactoryBean
IJSpace
implementationpublic Class<? extends IJSpace> getObjectType()
IJSpace
implementation class.
getObjectType
in interface FactoryBean
public boolean isSingleton()
true
since this factory is a singleton.
isSingleton
in interface FactoryBean
public boolean isMemberAliveEnabled()
setEnableMemberAliveIndicator(Boolean)
flag.
isMemberAliveEnabled
in interface MemberAliveIndicator
public boolean isAlive() throws Exception
isAlive
in interface MemberAliveIndicator
Exception
protected abstract IJSpace doCreateSpace() throws DataAccessException
IJSpace
implementation.
DataAccessException
protected boolean isRegisterForSpaceModeNotifications()
setRegisterForSpaceModeNotifications(boolean)
was set, will return this flag. If not, will register to primary backup notification if the space was
found using an embedded protocol, and will not register for notification if the space was found using rmi
or jini
protocols.
protected void fireSpaceBeforeBackupEvent()
BeforeSpaceModeChangeEvent
events with space mode SpaceMode.BACKUP
to all beans in the application context
that implement the SpaceBeforeBackupListener
interface.
protected void fireSpaceAfterBackupEvent()
AfterSpaceModeChangeEvent
events with space mode SpaceMode.BACKUP
to all beans in the application context
that implement the SpaceAfterBackupListener
interface.
protected void fireSpaceBeforePrimaryEvent()
BeforeSpaceModeChangeEvent
events with space mode SpaceMode.PRIMARY
to all beans in the application context
that implement the SpaceBeforePrimaryListener
interface.
protected void fireSpaceAfterPrimaryEvent()
AfterSpaceModeChangeEvent
events with space mode SpaceMode.PRIMARY
to all beans in the application context
that implement the SpaceAfterPrimaryListener
interface.
public ServiceDetails[] getServicesDetails()
ServiceDetailsProvider
getServicesDetails
in interface ServiceDetailsProvider
public String getName()
getName
in interface com.gigaspaces.internal.dump.InternalDumpProcessor
public void process(com.gigaspaces.internal.dump.InternalDump dump) throws com.gigaspaces.internal.dump.InternalDumpProcessorFailedException
process
in interface com.gigaspaces.internal.dump.InternalDumpProcessor
com.gigaspaces.internal.dump.InternalDumpProcessorFailedException
|
GigaSpaces XAP 8.0 API | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |