Interface Command
-
- All Known Subinterfaces:
Context
- All Known Implementing Classes:
AbstractCommand,GroupCommand,PageCommand,RedirectCommand,WikiCommand,WikiContext
public interface Command
Represents a logical "unit of work" that includes a request context, JSP, URLPattern, content template and (optionally) a target and required security permission. Examples of Commands include "view a page," "create a group," and "edit user preferences."
Commands come in two flavors: "static" and "targeted."
- Static commands are exactly what they sound like: static. They are
final, threadsafe, and immutable. They have no intrinsic idea of the context they are acting in. For example, the static commandorg.apache.wiki.ui.PageCommand#VIEWembodies the idea of viewing a page — but exactly which page is left undefined. Static commands exist so that they can be freely shared and passed around without incurring the penalties of object creation. Static commands are a lot like naked request contexts ("edit", "view", etc.) except that they include additional, essential properties such as the associated URL pattern and content JSP. - Targeted commands "decorate" static commands by scoping a static Command at a specific target such as a WikiPage or
GroupPrincipal. Targeted commands are created by calling an existing Command's
targetedCommand(Object)and supplying the target object. Implementing classes generally require a specific target type. For example, theorg.apache.wiki.ui.PageCommandclass requires that the target object be of typePage.
Concrete implementations of Command include:
- PageCommand: commands for editing, renaming, and viewing pages
- GroupCommand: commands for viewing, editing and deleting wiki groups
- WikiCommand: commands for wiki-wide operations such as creating groups, editing preferences and profiles, and logging in/out
- RedirectCommand: commands for redirections to off-site special pages
For a given targeted Command, its
getTarget()method will return a non-nullvalue. In addition, itsrequiredPermission()method will generally also return a non-nullvalue. It is each implementation's responsibility to construct and store the correct Permission for a given Command and Target. For example, when PageCommand.VIEW is targeted at the WikiPageMain, the Command's associated permission isPagePermission "theWiki:Main", "view".Static Commands, and targeted Commands that do not require specific permissions to execute, return a
nullresult forrequiredPermission().- Since:
- 2.4.22
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description java.lang.StringgetContentTemplate()Returns the content template associated with a Command, such asPreferencesContent.jsp.java.lang.StringgetJSP()Returns the JSP associated with the Command.java.lang.StringgetName()Returns the human-friendly name for this command.java.lang.StringgetRequestContext()Returns the name of the request context (e.g.java.lang.ObjectgetTarget()Returns the target associated with a Command, if it was created with one.java.lang.StringgetURLPattern()Returns the URL pattern associated with this Command.java.security.PermissionrequiredPermission()Returns the Permission required to successfully execute this Command.CommandtargetedCommand(java.lang.Object target)Creates and returns a targeted Command by combining a target, such as a WikiPage or GroupPrincipal into the existing Command.
-
-
-
Method Detail
-
targetedCommand
Command targetedCommand(java.lang.Object target)
Creates and returns a targeted Command by combining a target, such as a WikiPage or GroupPrincipal into the existing Command. Subclasses should check to make sure the suppliedtargetobject is of the correct type. This method is guaranteed to return a non-nullCommand (unless the target is an incorrect type).- Parameters:
target- the object to combine, such as a GroupPrincipal or WikiPage- Returns:
- the new, targeted Command
- Throws:
java.lang.IllegalArgumentException- if the target is not of the correct type
-
getContentTemplate
java.lang.String getContentTemplate()
Returns the content template associated with a Command, such asPreferencesContent.jsp. For Commands that are not page-related, this method will always returnnull. Calling methods should always check to see if the result of this method isnull.- Returns:
- the content template
-
getJSP
java.lang.String getJSP()
Returns the JSP associated with the Command. The JSP is a "local" JSP within the JSPWiki webapp; it is not a general HTTP URL. If it exists, the JSP will be expressed relative to the webapp root, without a leading slash. This method is guaranteed to return a non-nullresult, although in some cases the result may be an empty string.- Returns:
- the JSP or url associated with the wiki command
-
getName
java.lang.String getName()
Returns the human-friendly name for this command.- Returns:
- the name
-
getRequestContext
java.lang.String getRequestContext()
Returns the name of the request context (e.g. VIEW) associated with this Command. This method is guaranteed to return a non-nullString.- Returns:
- the request context
-
requiredPermission
java.security.Permission requiredPermission()
Returns the Permission required to successfully execute this Command. If no Permission is requred, this method returnsnull. For example, the static commandorg.apache.wiki.ui.PageCommand#VIEWdoesn't require a permission because it isn't referring to a particular WikiPage. However, if this command targets a WikiPage calledMain(viaorg.apache.wiki.ui.PageCommand#targetedCommand(Object), the resulting Command would require the permissionPagePermission "yourWiki:Main", "view".- Returns:
- the required permission, or
nullif not required
-
getTarget
java.lang.Object getTarget()
Returns the target associated with a Command, if it was created with one. Commands created withtargetedCommand(Object)will always return a non-nullobject. Calling methods should always check to see if the result of this method isnull.- Returns:
- the wiki page
-
getURLPattern
java.lang.String getURLPattern()
Returns the URL pattern associated with this Command. This method is guaranteed to return a non-nullString.- Returns:
- the URL pattern
-
-