Friday, July 31, 2009
Grails: use a session scoped bean in a singleton bean
static scope = 'session'
Now there's a problem if you use this service in a singleton scoped bean like a filter or a taglib for example. The problem is that spring will try to instantiate the singleton bean on startup, then it will try to create the service to inject it in the singleton, but as this does not occur in a session, spring cannot create the service and fails with a BeanCreationException. Anyway, even if the singleton was created within a session, the same service would be used for all sessions as the singleton wouldn't be re-injected for each session.
Fortunately, spring comes with the handy ScopedProxyFactoryBean. As its name implies, it is a proxy factory bean for scoped object. To use it, you first have to declare the service in grails-app/conf/spring/resources.groovy for an application or in the doWithSpring method of the plugin descriptor for a plugin:
sessionScopedService(SessionScopedService) { bean ->
bean.scope = 'session'
}
At the same place, declare the proxy factory bean:
sessionScopeProxy(org.springframework.aop.scope.ScopedProxyFactoryBean) {
targetBean = 'sessionScopedService'
proxyTargetClass = true
}
You can now use the sessionScopeProxy instead of the sessionScopedService in you singleton bean. It will transparently proxy to a session scoped SessionScopeService bean.
Wednesday, July 29, 2009
Grails: externalize configuration with jndi
Grails provides a very handy way to set configuration with Config.groovy file.
When developing internal applications, this solution is perfect especially with per-environment configuration.
For packaged third-party applications or complex multi-environment sites, it's harder to get a maintainable solution. Grails provides the grails.config.locations setting to load configuration from files possibly out of the application war file. The problem with this solution is to get a flexible cross-appserver cross-platform way to provide the custom config file to the application.
The solution presented here is to use jndi.
Let's say you want to provide a web service URL to an application, it will be made available to the application by the application server.
We will store the web service URL at the jndi name java:comp/env/wsUrl.
To access the value in the grails application, we will use a bit of spring magic by declaring a bean in grails-app/conf/spring/resources.groovy:
beans = {
wsUrl(org.springframework.jndi.JndiObjectFactoryBean){
jndiName = 'java:comp/env/wsUrl'
}
}
This will make the bean available with the value read from jndi, to use it, simply declare a variable named wsUrl in an injected object (controller, service...):
def wsUrl
For the development environment, if you use jetty, the value can be set by creating the web-app/WEB-INF/jetty-env.xml file with the following content:
<?xml version="1.0" encoding="UTF-8"?>
<configure class="org.mortbay.jetty.webapp.WebAppContext">
<new id="wsUrl" class="org.mortbay.jetty.plus.naming.EnvEntry">
<arg>wsUrl</arg>
<arg>http://www.example.com/dev-ws/</arg>
<arg type="boolean">true</arg>
</new>
</configure>
If you deploy to a tomcat environment, you can set the value by creating a file conf/Catalina/localhost/<context-name>.xml in your tomcat installation containing:
<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Environment name="wsUrl" value="http://www.example.com/prod-ws/"
type="java.lang.String" override="true"/>
</Context>
If the parameter has to be set in multiple applications in the same tomcat instance, it can be declared in conf/server.xml file and referenced in each application .xml file with the ResourceLink tag.
Saturday, July 25, 2009
BAF: soon something to show
Wednesday, June 17, 2009
Deploying on Websphere Application Server 6.1 for i5/OS
Monday, June 15, 2009
Deploying on IBM Integrated Web Application Server for i
Sunday, June 14, 2009
Practical example: jtopen and webservice
Tuesday, June 9, 2009
Grails jtopen plugin 0.3 is out: user profile authentication
Monday, June 8, 2009
grails jtopen plugin 0.2 is out: groovy record level access
Wednesday, June 3, 2009
Program call: a practical example
import org.codehaus.groovy.grails.plugins.jtopen.types.*class CommandService {boolean transactional = falsedef ibmIdef executeCommand(String command) {def cr = ibmI.call('QCMDEXC',[new IChar(command),new IPacked(command.length(),15,5)] as Type[])cr.success?:cr.messageList}}
- The command to execute as a CHAR variable
- The command length as a (15,5) packed decimal
class DataAreaController {def commandServicedef create = {def result = commandService.executeCommand("CRTDTAARA ${params.name} TYPE(*CHAR) LEN(10)")render result==true?"Data area ${params.name} created":result.inspect()}}
jtopen grails plugin 0.1.2 available
- A bug with IbmI bean injection was fixed
- The IBin2 and IBin8 parameter types were added to handle 2-byte and 8-byte integers
- The IByteArray parameter type was added. This type is useful when a parameter does not have a fixed layout that can be handled by IDataStructure
jtopen grails plugin 0.1.1 available
Tuesday, June 2, 2009
The grails jtopen plugin is coming
- jtopen 6.5.1
- injection of an AS400ConnectionPool bean
- the IbmI class
- easy program call
- easy data area access
- Easy program call with handling of input and output parameters
- Easy access to character and decimal data areas
- Possibility to use traditionnal object names (OBJECT or LIBRARY/OBJECT)