Class ExternalComponentManager
java.lang.Object
org.jivesoftware.openfire.component.ExternalComponentManager
Manages the connection permissions for external components. When an external component is
allowed to connect to this server then a special configuration for the component will be kept.
The configuration holds information such as the shared secret that the component should use
when authenticating with the server.
- Author:
- Gaston Dombiak
-
Nested Class Summary
Nested Classes -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionstatic voidaddListener(ExternalComponentManagerListener listener) Registers a listener to receive events when a configuration change happens.static voidallowAccess(ExternalComponentConfiguration configuration) Allows an external component to connect to the local server with the specified configuration.static voidblockAccess(String subdomain) Blocks an external component from connecting to the local server.static booleanReturns true if the external component with the specified subdomain can connect to the local server.static voiddeleteConfiguration(String subdomain) Removes any existing defined permission and configuration for the specified external component.Returns the list of registered external components that are allowed to connect to this server when using a whitelist policy.Returns the list of external components that are NOT allowed to connect to this server.static StringReturns the default secret key to use for those external components that don't have an individual configuration.Returns the permission policy being used for new XMPP entities that are trying to connect to the server.static StringgetSecretForComponent(String subdomain) Returns the shared secret with the specified external component.static booleanhasConfiguration(String subdomain) Returns true if there is a configuration for the specified subdomain.static voidUnregisters a listener to receive events.static voidsetDefaultSecret(String defaultSecret) Sets the default secret key to use for those external components that don't have an individual configuration.static voidsetPermissionPolicy(String policy) Sets the permission policy being used for new XMPP entities that are trying to connect to the server.static voidSets the permission policy being used for new XMPP entities that are trying to connect to the server.static voidupdateComponentSecret(String subdomain, String secret)
-
Constructor Details
-
ExternalComponentManager
public ExternalComponentManager()
-
-
Method Details
-
allowAccess
public static void allowAccess(ExternalComponentConfiguration configuration) throws ModificationNotAllowedException Allows an external component to connect to the local server with the specified configuration.- Parameters:
configuration- the configuration for the external component.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
blockAccess
Blocks an external component from connecting to the local server. If the component was connected when the permission was revoked then the connection of the entity will be closed.- Parameters:
subdomain- the subdomain of the external component that is not allowed to connect.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
canAccess
Returns true if the external component with the specified subdomain can connect to the local server.- Parameters:
subdomain- the subdomain of the external component.- Returns:
- true if the external component with the specified subdomain can connect to the local server.
-
hasConfiguration
Returns true if there is a configuration for the specified subdomain. This checking can be used as an indirect way of checking that the specified subdomain belongs to an external component.- Parameters:
subdomain- the subdomain of the external component.- Returns:
- true if there is a configuration for the specified subdomain.
-
getAllowedComponents
Returns the list of registered external components that are allowed to connect to this server when using a whitelist policy. However, when using a blacklist policy (i.e. anyone may connect to the server) the returned list of configurations will be used for obtaining the shared secret specific for each component.- Returns:
- the configuration of the registered external components.
-
getBlockedComponents
Returns the list of external components that are NOT allowed to connect to this server.- Returns:
- the configuration of the blocked external components.
-
updateComponentSecret
public static void updateComponentSecret(String subdomain, String secret) throws ModificationNotAllowedException - Throws:
ModificationNotAllowedException
-
deleteConfiguration
Removes any existing defined permission and configuration for the specified external component.- Parameters:
subdomain- the subdomain of the external component.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
getDefaultSecret
Returns the default secret key to use for those external components that don't have an individual configuration.- Returns:
- the default secret key to use for those external components that don't have an individual configuration.
-
setDefaultSecret
Sets the default secret key to use for those external components that don't have an individual configuration.- Parameters:
defaultSecret- the default secret key to use for those external components that don't have an individual configuration.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
getSecretForComponent
Returns the shared secret with the specified external component. If no shared secret was defined then use the default shared secret.- Parameters:
subdomain- the subdomain of the external component to get his shared secret. (e.g. conference)- Returns:
- the shared secret with the specified external component or the default shared secret.
-
getPermissionPolicy
Returns the permission policy being used for new XMPP entities that are trying to connect to the server. There are two types of policies: 1) blacklist: where any entity is allowed to connect to the server except for those listed in the black list and 2) whitelist: where only the entities listed in the white list are allowed to connect to the server.- Returns:
- the permission policy being used for new XMPP entities that are trying to connect to the server.
-
setPermissionPolicy
public static void setPermissionPolicy(ExternalComponentManager.PermissionPolicy policy) throws ModificationNotAllowedException Sets the permission policy being used for new XMPP entities that are trying to connect to the server. There are two types of policies: 1) blacklist: where any entity is allowed to connect to the server except for those listed in the black list and 2) whitelist: where only the entities listed in the white list are allowed to connect to the server.- Parameters:
policy- the new PermissionPolicy to use.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
setPermissionPolicy
Sets the permission policy being used for new XMPP entities that are trying to connect to the server. There are two types of policies: 1) blacklist: where any entity is allowed to connect to the server except for those listed in the black list and 2) whitelist: where only the entities listed in the white list are allowed to connect to the server.- Parameters:
policy- the new policy to use.- Throws:
ModificationNotAllowedException- if the operation was denied.
-
addListener
Registers a listener to receive events when a configuration change happens. Listeners have the chance to deny the operation from happening.- Parameters:
listener- the listener.
-
removeListener
Unregisters a listener to receive events.- Parameters:
listener- the listener.
-