Vroom Request Dispatcher
A simple way to build jython (python), jruby, groovy and javascript enabled Java EE applications. Please visit http://code.google.com/p/vroom-request-dispatcher to download the API.
Friday, February 6, 2009
Friday, January 9, 2009
Configuring VRD for Scripting Languages
In traditional java web applications, you can only use java language to write server side code. Using VRD-SLE (Scripting Language Extension), you can easily configure your java web applications to write server side code using Jython, JRuby, Groovy and JavaScript. Not only this, you can also get benefit of the powerful libraries of Jython and JRuby.
The first thing you need to do is to configure your web application to work with Vroom Request Dispatcher. For that please read the Blog Entry What is Vroom Request Dispatcher?
Once the above step is complete, you need to add following entries in /WEB-INF/vrd-config.xml file: (You may only include the entries that are needed)
For Jython, you need to add JVM parameter as follows:
Jython:
JRuby:
Groovy:
JavaScript:
The first thing you need to do is to configure your web application to work with Vroom Request Dispatcher. For that please read the Blog Entry What is Vroom Request Dispatcher?
Once the above step is complete, you need to add following entries in /WEB-INF/vrd-config.xml file: (You may only include the entries that are needed)
<vrd-config>
<request pattern="/path/to/scripts/.*.py">
<invocation method-name="net.openkoncept.vroom.vrd.jython.JythonRequestDispatcher.dispatch"/>
</request>
<request pattern="/path/to/scripts/.*.rb">
<invocation method-name="net.openkoncept.vroom.vrd.jruby.JRubyRequestDispatcher.dispatch"/>
</request>
<request pattern="/path/to/scripts/.*.groovy">
<invocation method-name="net.openkoncept.vroom.vrd.groovy.GroovyRequestDispatcher.dispatch"/>
</request>
<request pattern="/path/to/scripts/.*.js">
<invocation method-name="net.openkoncept.vroom.vrd.javascript.JavaScriptRequestDispatcher.dispatch"/>
</request>
</vrd-config>
For Jython, you need to add JVM parameter as follows:
Like servlet, there is an entry point for these scripts and that is a no argument public method named vrd_main , to request and response objects are accessible in the script using variables vrd_hreq (javax.servlet.http.HttpServletRequest) and vrd_hres (javax.servlet.http.HttpServletResponse). Below are the samples in each scripting language:
-Dpython.path=/path/to/jython-home/Lib:/path/to/jython-home/Lib/site-packages
Jython:
def vrd_main():
res = vrd_hres
res.contentType = 'text/html'
w = res.writer
w.print('Hello World')
w.flush()
JRuby:
def vrd_main()
res = $bsf.lookupBean('vrd_hres')
res.contentType = 'text/html'
w = res.writer
w.print('Hello World')
w.flush()
end
Groovy:
def vrd_main() {
res = vrd_hres
res.contentType = 'text/html'
w = res.writer
w.print('Hello World')
w.flush()
}
JavaScript:
function vrd_main() {
res = vrd_hres
res.contentType = 'text/html'
w = res.writer
w.print('Hello World')
w.flush()
}
Thursday, January 8, 2009
How to write vrd-config.xml file?
It's very important to understand how we should write vrd-config.xml. There is a file named vrd-config-1.0.xsd which is available with the API and can be used to validate vrd-config.xml however it is not required. Below is a quick guide:
The root element of the configuration file is vrd-config. It may have 0 or many request elements. E.g.
Each request element can have either response or invocation as child element. The response element takes two attributes, url (mandatory) and redirect (optional with default value false), e.g.
1. Using method-name and bean-class attributes:
The above mentioned methods are only applicable to public static methods of a public class. If the method is public but not static, there are two additional (optional) attributes, var and scope. The var attribute is used to specify a variable name to refer instance of bean-class. The scope is the scope of the instance. The possible values of scope are application, session, and request. If not specified, the scope is local. E.g.
Note: The method that can be invoked must satisfy one of the following method signatures:
The root element of the configuration file is vrd-config. It may have 0 or many request elements. E.g.
The request elements take two attributes, pattern (mandatory) and exclude. Both accepts java regular expressions, e.g.
<vrd-config>
<request ...>
...
</request>
</vrd-config>
The above definition is to intercept all URIs except those followed by /script/ .
<request pattern=".*" exclude="/scripts/.*">
...
</request>
Each request element can have either response or invocation as child element. The response element takes two attributes, url (mandatory) and redirect (optional with default value false), e.g.
Normal if the response is a forward, the redirect attribute is not specified. To do a response redirect on the same web application, you need to specify #{contextPath} as prefix in the path attribute, e.g.
<request pattern=".*">
<response url="http://www.google.com" redirect="true"/>
</request>
The invocation element of the response object is used to invoke java method. There are two attributes, method-name (mandatory) and bean-class. There are two ways to specify the method to invoke:
<request pattern="/|/index.jsp">
<response path="#{contextPath}/welcome.jsp" redirect="true"/>
</request>
1. Using method-name and bean-class attributes:
<request pattern=".*">2. Using only the method-name attribute:
<invocation bean-class="Foo" method-name="bar"/>
</request>
<request pattern=".*">
<invocation method-name="Foo.bar"/>
</request>
The above mentioned methods are only applicable to public static methods of a public class. If the method is public but not static, there are two additional (optional) attributes, var and scope. The var attribute is used to specify a variable name to refer instance of bean-class. The scope is the scope of the instance. The possible values of scope are application, session, and request. If not specified, the scope is local. E.g.
<request pattern=".*">
<invocation bean-class="Foo" method-name="bar" var="foo" scope="request"/>
</request>
Note: The method that can be invoked must satisfy one of the following method signatures:
The Object can be an instance of any java class, but if it is a String, it can be used to define navigation. For navigation, you must use result element of invocation element. The result element takes two attributes, pattern and exclude and allows either response or invocation element just like request element.
public (static) void|Object methodName();
public (static) void|Object methodName(javax.servlet.http.HttpServletRequest);
public (static) void|Object methodName(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse);
Or
<invocation method-name="java.util.Date.toString" var="dt" scope="application">
<result pattern="(Sat|Sun).*">
<response url="#{contextPath}/access-denied.html" redirect="true"/>
</result>
</invocation>
<invocation method-name="A.m1">This is all about writing vrd-config.xml file.
<result pattern="value1">
<invocation method-name="B.m2">
<result pattern="value2">
<response url="http://www.someurl.com" redirect="true"/>
</result>
</invocation>
</result>
</invocation>
Wednesday, January 7, 2009
What is Vroom Request Dispatcher?
Vroom Request Dispatcher or simply VRD is a small API for Java Web Applications. It consists of a small set of Java classes and a Java web filter (VRDFilter) which is configured in web.xml. The filter looks for a file named vrd-config.xml under /WEB-INF folder of the web application to work.
The API written after the inspiration of the powerful url pattern mapping in Python based web applications. Now in Java you can easily map url patterns to redirect/forward to other urls and/or invoke any public java method. Furthermore the API also helps to define application navigation. All these mappings and navigations are defined in /WEB-INF/vrd-config.xml file.
For download the library please visit the project website (http://code.google.com/p/vroom-request-dispatcher).
Once you download the library, configure it with the IDE you are using to build Java Web Applications. If you're not using any IDE, then either you can place the library files under classpath or you can copy them in /WEB-INF/lib folder. Once the Library is available, you need to add following entry in web.xml:
After setting up the library and updating the web.xml file, you need to create an xml file name vrd-config.xml file. To learn about please the read the blog entry How to write vrd-config.xml file?
For download the library please visit the project website (http://code.google.com/p/vroom-request-dispatcher).
Once you download the library, configure it with the IDE you are using to build Java Web Applications. If you're not using any IDE, then either you can place the library files under classpath or you can copy them in /WEB-INF/lib folder. Once the Library is available, you need to add following entry in web.xml:
<filter>
<filter-name>VRDFilter</filter-name>
<filter-class>net.openkoncept.vroom.vrd.VRDFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>VRDFilter</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
</filter-mapping>
Subscribe to:
Posts (Atom)