 This wiki does not contain official documentation and is currently deprecated and read only. Please try reading the documentation on the Liferay Developer Network, the new site dedicated to Liferay documentation.      DISCOVER Build your web site, collaborate with your colleagues, manage your content, and more.   DEVELOP Build applications that run inside Liferay, extend the features provided out of the box with Liferay's APIs.   DISTRIBUTE Let the world know about your app by publishing it in Liferay's marketplace.   PARTICIPATE Become a part of Liferay's community, meet other Liferay users, and get involved in the open source project.
  This wiki does not contain official documentation and is currently deprecated and read only. Please try reading the documentation on the Liferay Developer Network, the new site dedicated to Liferay documentation.      DISCOVER Build your web site, collaborate with your colleagues, manage your content, and more.   DEVELOP Build applications that run inside Liferay, extend the features provided out of the box with Liferay's APIs.   DISTRIBUTE Let the world know about your app by publishing it in Liferay's marketplace.   PARTICIPATE Become a part of Liferay's community, meet other Liferay users, and get involved in the open source project.  Scripting Language Portlets
Table of Contents [-]
Introduction #
Liferay has support for developing portlets in Ruby, PHP, Groovy, Python, and Javascript in the plugins environment.
Developing using scripting languages is quite easy. You can use the sample portlets as reference, providing the developer the appropriated directory structure, that looks similar to
 
 
Description #
All the impotant files are under docroot/WEB-INF. There it can be found the usual files, including portlet.xml, which looks like this
<portlet-class>com.liferay.util.bridges.groovy.GroovyPortlet</portlet-class>
<init-param>
<name>view-file</name>
    <value>/WEB-INF/groovy/view.groovy</value>
</init-param>
<init-param>
<name>action-file</name>
<value>/WEB-INF/groovy/action.groovy</value>
</init-param>
<init-param>
     <name>global-files</name>
<value>/WEB-INF/groovy/global/LiferayPortlet.groovy,/WEB-INF/groovy/global/Custom.groovy</value>
</init-param>In this file you can set up the portlet class (com.liferay.util.bridges.groovy.GroovyPortlet, com.liferay.util.bridges.ruby.RubyPortlet, com.liferay.util.bridges.php.PHPPortlet, com.liferay.util.bridges.python.PythonPortlet, com.liferay.util.bridges.javascript.JavaScriptPortlet) and which files will handle several options. You can specify which file will be invoked to process the action and which file will be used to render the different portlet modes (in this example only the view mode is defined, but it is quite easy to imagine how to do it for edit and help modes). You can also define a list of files including common stuff under the 'global-files' init param. You can set as much files as you want.
The other files (info.groovy and java.groovy) represent different views your portlet may have, but they have to be linked from somewhere to be accessible. Remember to use the appropriated methods to create correct links inside the portal. For convenience, LiferayPortlet.groovy (or the appropriate one for the scripting language of your choice) includes some methods and examples about how to do that.
The way global files are handled is just by creating a large text structure made by concatenating the global files and the script to execute (view.groovy, java.groovy, ...). Consider this to properly write classes or modules qualified names.
From scripting files you can access the usual portlet objects, namely the request and response objects (actionRequest/actionResponse, renderRequest/renderResponse), portlet config (portletConfig), portlet context (portletContext), portlet preferences (portletPreferences) and user info (userInfo). They are Java objects, so they have all methods and properties you would expect if in a Java class.
The internal implementation is done using BSF, buth some languages require special handling. Ruby uses Jruby, groovy has its own implementation, PHP requires Quercus and Python support is based on Jython. JavaScript execution in handled by Rhino. You need to include the appropriate jar file in the lib directory of your portlet.
TODO: Explain PHP portlets differences. They can be developed including only php files without the full structure and the jar file.
