 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.  Upgrade Instructions from 5.1 to 5.2
This upgrade is recommended to anyone running Liferay Portal 5.1SE and wants to benefit from the New Features in Liferay Portal v5.2
Always use the latest version of 5.2 available as it will have fixed all the potential upgrade issues that may have been found. You should at least use v5.2.2 (there is no need to update to 5.2.0 or 5.2.1 first!)
Prerequisite #
It's recommended to upgrade first at least to 5.1.1SE if you are running any previous version.
Basic Installation Outline #
This instructions should be enough if you haven't made any customizations to the out-of-the-box release. Otherwise you will also have to follow the steps in the next sections.
- Make sure you've got your last complete backup at hand - not just the database backup: e.g. you most likely would like to have your portal-ext.properties available to restore the applicable settings later (The settings most likely will have to be changed, but still: you want to know your customizations to redo them later)
- Undeploy the old version of Liferay, and then shut down your application server. For Tomcat, you'd delete the ROOT folder from <Tomcat Home>/webapps.
- Copy the new versions of the dependency .jars to a location on your server's classpath, overwriting the ones you already have for the old version of Liferay. For Tomcat, these are stored in <Tomcat Home>/common/lib/ext.
- Deploy the new Liferay .war file. This is different by application server. For Tomcat, you'd create a ROOT folder in <Tomcat Home>/webapps and unzip the .war file there.
- Delete your tomcat class cache ie <Tomcat Home>/work/Catalina/localhost/ as sometimes tomcat will load class' from the previous version of Liferay instead of the new version
- Start (or restart) your application server. Liferay should come up.
Changes in configuration properties #
How to keep the old values #
The default values of some properties has been changed. In order to keep the previous values you have to run Liferay passing the following system property:
java ... -Dexternal-properties=portal-legacy-5.1.properties
Each application server has different methods to add this system property. In Tomcat modify setenv.sh/setenv.bat and append that option to the environment variable JAVA_OPTS (other documentations suggest catalina.sh/catalina.bat or catalina.conf, depending on the exact version you are using. setenv.sh or setenv.bat is not delivered with tomcat but - if existing - it will be embedded in the startup process, so it's a nice way to separate your own settings from tomcats default shell scripts).
Here are the complete contents of that file (portal-legacy-5.1.properties) for reference:
resource.repositories.root=${user.home}/liferay
theme.portlet.sharing.default=true
organizations.country.required[regular]=true
organizations.assignment.auto=true
organizations.assignment.strict=false
organizations.membership.strict=true
lucene.dir=${resource.repositories.root}/lucene/
jcr.jackrabbit.repository.root=${resource.repositories.root}/jackrabbit
dl.hook.impl=com.liferay.documentlibrary.util.JCRHook
dl.hook.file.system.root.dir=${resource.repositories.root}/document_libraryImportant changes in the configuration of Database access and mail integration #
One very important aspect of the upgrade is that now the configuration of the database parameters and those for mail integration are handled through the portal.properties to unify the configuration through all application servers.
It's still possible to use application server specific datasources and pools if desired by using certain configuration properties.
Check Database Configuration for further details on how to adapt your existing configuration.
Theme Upgrade #
Instructions for maintaining customized themes built in 5.1 without redeploying with the new SDK :
- Change the header of "/WEB-INF/liferay-plugin-package.xml" to (Note: Remove the square brackets surrounding the dtd link as this code outline is formatted wrong):
<!DOCTYPE plugin-package PUBLIC "-//Liferay//DTD Plugin Package 5.2.0//EN" "http://www.liferay.com/dtd/liferay-plugin-package_5_2_0.dtd">
- Change the header of "/WEB-INF/liferay-look-and-feel.xml" to (Note: Remove the square brackets surrounding the dtd link as this code outline is formatted wrong):
<!DOCTYPE look-and-feel PUBLIC "-//Liferay//DTD Look and Feel 5.2.0//EN" "http://www.liferay.com/dtd/liferay-look-and-feel_5_2_0.dtd">
- Upgrade compatibility version in "liferay-look-and-feel.xml" :
<compatibility>
        <version>5.2.2+</version>
</compatibility>- In "portal_normal.vm", delete the following lines :
$theme.include($session_timeout_include) $theme.include($sound_alerts_include)
(If you let them you will see a blank page and an exception)
- In order to display the control panel in the dock, add the following lines in "dock.vm":
#if ($show_control_panel) <li class="control-panel"> <a href="$control_panel_url">$control_panel_text</a> </li> #end
- In "navigation.css":
.lfr-dock li.control-panel a {
	background-image: url(../images/dock/control_panel.png);
 }- Then copy the /images/dock/control_panel.png from the classic theme (ROOT/html/themes/classic) into your theme.
- In WEB-INF/web.xml, change the deprecated declaration "com.liferay.portal.servlet.filters.compression.CompressionFilter" into "com.liferay.portal.servlet.filters.gzip.GZipFilter "
API Changes #
Usage of ServiceContext in Liferay's Services Layer #
The most significant API change in 5.2 is that most APIs of the service layer have been adapted to use the ServiceContext Pattern. The Service Context is an object that contains context information about a given API call. All of the fields of this object are optional, although the services that store any type of content will require you to specify at least the scopeGroupId. Here is a simple example of how to create a ServiceContext instance and pass it to a service API:
ServiceContext serviceContext = new ServiceContext(); serviceContext.setScopeGroupId(myGroupId); BlogsEntryServiceUtil.addEntry(...., serviceContext);
If you are invoking the service from a servlet, an struts action or any other frontend class which has access to the portletRequest, you can use a utility method that will create the ServiceContext object and fill it with all the necessary values automatically. In that case the above example could be rewritten as follows:
ServiceContext serviceContext = ServiceContextFactory.getInstance(BlogsEntry.class.getName(), portletRequest); BlogsEntryServiceUtil.addEntry(...., serviceContext);
Please see this forum thread for more discussion on the topic.
