Portal Properties




 ##
 ## Properties Override
 ##

     #
     # Specify where to get the overridden properties. Updates should not be made
     # on this file but on the overridden version of this file.
     #
     # The default read order is: portal.properties and then
     # portal-ext.properties.
     #
     include-and-override=portal-ext.properties
     include-and-override=${liferay.home}/portal-ext.properties

     #
     # Each portal instance can have its own overriden property file following
     # the convention portal-companyId.properties. To enable this feature, set
     # the "company-id-properties" system property to true.
     #
     # To enable:
     #
     #     java ... company-id-properties=true
     #
     # The read order will now be: portal.properties, then portal-ext.properties,
     # and then portal-liferay.com.properties.
     #
     include-and-override=portal-${easyconf:companyId}.properties
     include-and-override=${liferay.home}/portal-${easyconf:companyId}.properties

     #
     # Additional property files can be used by setting the "external-properties"
     # system property.
     #
     # A common use case is to keep legacy property values when upgrading to
     # newer versions of Liferay. To enable:
     #
     #     java ... -Dexternal-properties=portal-legacy-5.1.properties
     #
     # The read order will now be: portal.properties, then portal-ext.properties,
     # and then portal-legacy-5.1.properties.
     #
     include-and-override=${external-properties}
     include-and-override=${liferay.home}/${external-properties}

 ##
 ## Liferay Home
 ##

     #
     # Specify the Liferay home directory.
     #
     liferay.home=${resource.repositories.root}

     #
     # This property is available for backwards compatibility. Please set the
     # property "liferay.home" instead.
     #
     resource.repositories.root=${default.liferay.home}

 ##
 ## Portal Context
 ##

     #
     # Specify the path of the portal servlet context. This is needed because
     # javax.servlet.ServletContext does not have access to the context path
     # until Java EE 5.
     #
     # Set this property if you deploy the portal to another path besides root.
     #
     portal.ctx=/

 ##
 ## TCK
 ##

     #
     # Set this to true to enable programmatic configuration to let the Portlet
     # TCK obtain a URL for each test. This should never be set to true unless
     # you are running the TCK tests.
     #
     tck.url=false

 ##
 ## Schema
 ##

     #
     # Set this to true to automatically create tables and populate with default
     # data if the database is empty.
     #
     schema.run.enabled=true

     #
     # Set this to to true to populate with the minimal amount of data. Set this
     # to false to populate with a larger amount of sample data.
     #
     schema.run.minimal=true

 ##
 ## Upgrade
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.upgrade.UpgradeProcess. These classes will run on
     # startup to upgrade older data to match with the latest version.
     #
     upgrade.processes=         com.liferay.portal.upgrade.UpgradeProcess_4_3_0,         com.liferay.portal.upgrade.UpgradeProcess_4_3_1,         com.liferay.portal.upgrade.UpgradeProcess_4_3_2,         com.liferay.portal.upgrade.UpgradeProcess_4_3_3,         com.liferay.portal.upgrade.UpgradeProcess_4_3_4,         com.liferay.portal.upgrade.UpgradeProcess_4_3_5,         com.liferay.portal.upgrade.UpgradeProcess_4_4_0,         com.liferay.portal.upgrade.UpgradeProcess_5_0_0,         com.liferay.portal.upgrade.UpgradeProcess_5_1_0,         com.liferay.portal.upgrade.UpgradeProcess_5_1_2,         com.liferay.portal.upgrade.UpgradeProcess_5_2_0,         com.liferay.portal.upgrade.UpgradeProcess_5_2_1,         com.liferay.portal.upgrade.UpgradeProcess_5_2_2,         com.liferay.portal.upgrade.UpgradeProcess_5_2_3

 ##
 ## Verify
 ##

     #
     # Input a list of comma delimited class name that implement
     # com.liferay.portal.integrity.VerifyProcess. These classes will run on
     # startup to verify and fix any integrity problems found in the database.
     #
     verify.processes=com.liferay.portal.verify.VerifyProcessSuite

     #
     # Specify the frequency for verifying the integrity of the database.
     #
     # Constants in VerifyProcess:
     #     public static final int ALWAYS = -1;
     #     public static final int NEVER = 0;
     #     public static final int ONCE = 1;
     #
     verify.frequency=1

 ##
 ## Convert
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.convert.ConvertProcess. These classes can be run
     # from within the Admin portlet to convert older data to match a new
     # configuration of the portal.
     #
     convert.processes=         com.liferay.portal.convert.ConvertPermissionAlgorithm,         com.liferay.portal.convert.ConvertWikiCreole

 ##
 ## Auto Deploy
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.kernel.deploy.auto.AutoDeployListener. These classes
     # are used to process the auto deployment of WARs.
     #
     auto.deploy.listeners=         com.liferay.portal.deploy.auto.HookAutoDeployListener,         com.liferay.portal.deploy.auto.LayoutTemplateAutoDeployListener,         com.liferay.portal.deploy.auto.PortletAutoDeployListener,         com.liferay.portal.deploy.auto.ThemeAutoDeployListener,         com.liferay.portal.deploy.auto.WebAutoDeployListener,         com.liferay.portal.deploy.auto.exploded.tomcat.LayoutTemplateExplodedTomcatListener,         com.liferay.portal.deploy.auto.exploded.tomcat.PortletExplodedTomcatListener,         com.liferay.portal.deploy.auto.exploded.tomcat.ThemeExplodedTomcatListener

     #
     # Set this to true to enable auto deploy of layout templates, portlets, and
     # themes.
     #
     auto.deploy.enabled=true

     #
     # Set the directory to scan for layout templates, portlets, and themes to
     # auto deploy.
     #
     auto.deploy.deploy.dir=${liferay.home}/deploy

     #
     # Set the directory where auto deployed WARs are copied to. The application
     # server or servlet container must know to listen on that directory.
     # Different containers have different hot deploy paths. For example, Tomcat
     # listens on "${catalina.base}/webapps" whereas JBoss listens on
     # "${jboss.server.home.dir}/deploy". Set a blank directory to automatically
     # use the application server specific directory.
     #
     auto.deploy.dest.dir=
     auto.deploy.default.dest.dir=../webapps
     auto.deploy.geronimo.dest.dir=${org.apache.geronimo.base.dir}/deploy
     auto.deploy.geronimo-jetty.dest.dir=${org.apache.geronimo.base.dir}/deploy
     auto.deploy.geronimo-tomcat.dest.dir=${org.apache.geronimo.base.dir}/deploy
     auto.deploy.glassfish.dest.dir=${com.sun.aas.instanceRoot}/autodeploy
     auto.deploy.glassfish-tomcat.dest.dir=${com.sun.aas.instanceRoot}/autodeploy
     auto.deploy.jboss-tomcat.dest.dir=${jboss.server.home.dir}/deploy
     auto.deploy.jetty.dest.dir=${jetty.home}/webapps
     auto.deploy.jonas-jetty.dest.dir=${jonas.base}/webapps/autoload
     auto.deploy.jonas-tomcat.dest.dir=${jonas.base}/webapps/autoload
     auto.deploy.resin.dest.dir=${resin.home}/webapps
     auto.deploy.tomcat.dest.dir=${catalina.base}/webapps
     auto.deploy.weblogic.dest.dir=${env.DOMAIN_HOME}/autodeploy

     #
     # Set the interval in milliseconds on how often to scan the directory for
     # changes.
     #
     auto.deploy.interval=10000

     #
     # Set the number of attempts to deploy a file before blacklisting it.
     #
     auto.deploy.blacklist.threshold=10

     #
     # Set this to true if deployed WARs are unpacked. Set this to false your
     # application server has concurrency issues with deploying large WARs.
     #
     auto.deploy.unpack.war=true

     #
     # Set this to true if you want the deployer to rename portlet.xml to
     # portlet-custom.xml. This is only needed when deploying the portal on
     # WebSphere 6.1.x with a version before 6.1.0.7 because WebSphere's portlet
     # container will try to process a portlet at the same time that Liferay is
     # trying to process a portlet.
     #
     auto.deploy.custom.portlet.xml=false

     #
     # Set this to 1 if you are using JBoss' PrefixDeploymentSorter. This will
     # append a 1 in front of your WAR name. For example, if you are deploying a
     # portlet called test-portlet.war, it will deploy it to 1test-portlet.war.
     # JBoss now knows to load this portlet after the other WARs have loaded.
     # However, it will remove the 1 from the context path.
     #
     # Modify /server/default/conf/jboss-service.xml.
     # See org.jboss.deployment.scanner.PrefixDeploymentSorter.
     #
     auto.deploy.jboss.prefix=

     #
     # Set the path to Tomcat's configuration directory. This property is used to
     # auto deploy exploded WARs. Tomcat context XML fiels found in the auto
     # deploy directory will be copied to Tomcat's configuration directory. The
     # context XML file must have a docBase attribute that points to a valid WAR
     # directory.
     #
     auto.deploy.tomcat.conf.dir=../conf/Catalina/localhost

     #
     # Set the path to Tomcat's global class loader. This property is only used
     # by Tomcat in a standalone environment.
     #
     auto.deploy.tomcat.lib.dir=../common/lib/ext

     #
     # Set the URLs of Libraries that might be needed to download during the
     # auto deploy process
     #
     library.download.url.quercus.jar=http://lportal.svn.sourceforge.net/viewvc/*checkout*/lportal/portal/trunk/lib/development/quercus.jar
     library.download.url.resin-util.jar=http://lportal.svn.sourceforge.net/viewvc/*checkout*/lportal/portal/trunk/lib/development/resin-util.jar
     library.download.url.script-10.jar=http://lportal.svn.sourceforge.net/viewvc/*checkout*/lportal/portal/trunk/lib/development/script-10.jar

     #
     # Set the Glassfish settings to enable JSR 88 application deployment.
     #
     auto.deploy.glassfish-tomcat.jee.deployment.enabled=false
     auto.deploy.glassfish-tomcat.jee.dm.id=deployer:Sun:AppServer::localhost:4848
     auto.deploy.glassfish-tomcat.jee.dm.user=admin
     auto.deploy.glassfish-tomcat.jee.dm.passwd=adminadmin
     auto.deploy.glassfish-tomcat.jee.df.classname=com.sun.enterprise.deployapi.SunDeploymentFactory

 ##
 ## Hot Deploy
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.kernel.deploy.hot.HotDeployListener. These classes are
     # used to process the deployment and undeployment of WARs at runtime.
     #
     # Note: PluginPackageHotDeployListener must always be first.
     #
     hot.deploy.listeners=         com.liferay.portal.deploy.hot.PluginPackageHotDeployListener,         com.liferay.portal.deploy.hot.HookHotDeployListener,         com.liferay.portal.deploy.hot.LayoutTemplateHotDeployListener,         com.liferay.portal.deploy.hot.PortletHotDeployListener,         com.liferay.portal.deploy.hot.ThemeHotDeployListener,         com.liferay.portal.deploy.hot.ThemeLoaderHotDeployListener,         com.liferay.portal.deploy.hot.MessagingHotDeployListener

 ##
 ## Hot Undeploy
 ##

     #
     # Set this to true to enable undeploying plugins.
     #
     hot.undeploy.enabled=true

     #
     # Set the undeploy interval in milliseconds on how long to wait for the
     # undeploy process to finish.
     #
     hot.undeploy.interval=0

     #
     # Set this to true to undeploy a plugin before deploying a new version. This
     # property will only be used if the property "hot.undeploy.enabled" is set
     # to true.
     #
     hot.undeploy.on.redeploy=false

 ##
 ## Plugin
 ##

     #
     # Input a list of comma delimited supported plugin types.
     #
     plugin.types=portlet,theme,layout-template,hook,web

     #
     # Input a list of Liferay plugin repositories separated by \n characters.
     #
     plugin.repositories.trusted=http://plugins.liferay.com/official
     plugin.repositories.untrusted=http://plugins.liferay.com/community

     #
     # Set this property to false to avoid receiving on screen notifications
     # when there is a new version of an installed plugin.
     #
     plugin.notifications.enabled=true

     #
     # Input a list of plugin packages ids separated by \n characters.
     # Administrators won't be notified when a new version of these plugins are
     # available. The ids are of the form groupId/artifactId. You can also end
     # the id with an asterisk to match any id that start with the previous
     # character.
     #
     #plugin.notifications.packages.ignored=liferay/sample-jsp-portlet

 ##
 ## Portlet
 ##

     #
     # Set this property for the portlet container implementation to use. The
     # default implementation is the internal Liferay implementation and provides
     # for the most features and best performance. The Sun implementation
     # demonstrates how to plugin a different portlet container implementation.
     #
     portlet.container.impl=internal
     #portlet.container.impl=sun

     #
     # Set this property to set the default virtual path for all hot deployed
     # portlets. See liferay-portlet-app_5_1_0.dtd and the virtual-path element
     # for more information.
     #
     portlet.virtual.path=

     #
     # Set this property to true to validate portlet.xml against the portlet
     # schema.
     #
     portlet.xml.validate=true

 ##
 ## Portlet Coordination
 ##

     #
     # Set this property to specify how events are distributed. If the value is
     # "ALL_PORTLETS", then events will be distributed to all portlets that are
     # the deployed. If the value is "ALL_PORTLETS_ON_PAGE", then events will be
     # distributed to all portlets that are present on a portal page.
     #
     portlet.event.distribution=ALL_PORTLETS_ON_PAGE

     #
     # Set this property to specify the maximum number of events that can be
     # generated from portlets to prevent infinite loops.
     #
     portlet.event.max.generation=3

     #
     # Set this property to specify how public render parameters are distributed.
     # If the value is "ALL_PORTLETS", then public render parameters will be
     # distributed to all portlets that are the deployed. If the value is
     # "ALL_PORTLETS_ON_PAGE", then public render parameters will be distributed
     # to all portlets that are present on a portal page.
     #
     portlet.public.render.parameter.distribution=ALL_PORTLETS_ON_PAGE

 ##
 ## Theme
 ##

     #
     # Set this property to true to load the theme's merged CSS files for faster
     # loading for production.
     #
     # Set this property to false for easier debugging for development. You can
     # also disable fast loading by setting the URL parameter "css_fast_load" to
     # "0".
     #
     theme.css.fast.load=true

     #
     # Set this property to true to load the theme's merged image files for
     # faster loading for production.
     #
     # Set this property to false for easier debugging for development. You can
     # also disable fast loading by setting the URL parameter "images_fast_load"
     # to "0".
     #
     theme.images.fast.load=true

     #
     # Set the theme's shorcut icon.
     #
     theme.shortcut.icon=liferay.ico

     #
     # Set this property to set the default virtual path for all hot deployed
     # themes. See liferay-look-and-feel_5_1_0.dtd and the virtual-path element
     # for more information.
     #
     theme.virtual.path=

     #
     # Set this with an absolute path to specify where imported theme files from
     # a LAR will be stored. This path will override the file-storage path
     # specified in liferay-theme-loader.xml.
     #
     theme.loader.storage.path=

     #
     # Themes can be imported via LAR files. Set this to true if imported themes
     # should use a new theme id on every import. This will ensure that a copy of
     # the old theme is preserved in the theme loader storage path. However, this
     # also means that a lot of themes that are no longer used remain in the file
     # system. It is recommended that you set this to false.
     #
     theme.loader.new.theme.id.on.import=false

     #
     # Set this to true to decorate portlets by default.
     #
     theme.portlet.decorate.default=true

     #
     # Set this to true to exposing sharing icons for portlets by default.
     #
     theme.portlet.sharing.default=false

 ##
 ## Resource Actions
 ##

     #
     # Input a list of comma delimited resource action configurations that will
     # be read from the class path.
     #
     resource.actions.configs=resource-actions/default.xml

 ##
 ## Model Hints
 ##

     #
     # Input a list of comma delimited model hints configurations.
     #
     model.hints.configs=         META-INF/portal-model-hints.xml,         META-INF/ext-model-hints.xml,         META-INF/portlet-model-hints.xml

 ##
 ## Service Builder
 ##

     #
     # Input a list of common delimited method prefixes designated for read-only
     # transactions. Service Builder will use these prefixes to annotate methods
     # that are to run in read-only transactions.
     #
     service.builder.service.read.only.prefixes=         get,         has,         is,         reIndex,         search

 ##
 ## Spring
 ##

     #
     # Input a list of comma delimited Spring configurations. These will be
     # loaded after the bean definitions specified in the contextConfigLocation
     # parameter in web.xml.
     #
     spring.configs=         META-INF/base-spring.xml,                  META-INF/hibernate-spring.xml,         META-INF/infrastructure-spring.xml,         META-INF/management-spring.xml,                  META-INF/util-spring.xml,                  META-INF/editor-spring.xml,         META-INF/jcr-spring.xml,         META-INF/messaging-spring.xml,         META-INF/scheduler-spring.xml,         META-INF/search-spring.xml,                  META-INF/counter-spring.xml,         META-INF/document-library-spring.xml,         META-INF/lock-spring.xml,         META-INF/mail-spring.xml,         META-INF/portal-spring.xml,         META-INF/portlet-container-spring.xml,         META-INF/wsrp-spring.xml,                  META-INF/mirage-spring.xml,                  #META-INF/dynamic-data-source-spring.xml,         #META-INF/shard-data-source-spring.xml,                  META-INF/ext-spring.xml

     #
     # Set the bean name for the Liferay data source.
     #
     spring.hibernate.data.source=liferayDataSource

     #
     # Set the bean name for the Liferay session factory.
     #
     spring.hibernate.session.factory=&liferaySessionFactory

     #
     # Set this property to false to manually open and close sessions.
     #
     spring.hibernate.session.delegated=true

 ##
 ## Hibernate
 ##

     #
     # Input a list of comma delimited Hibernate configurations.
     #
     hibernate.configs=         META-INF/counter-hbm.xml,         META-INF/mail-hbm.xml,         META-INF/portal-hbm.xml,         META-INF/ext-hbm.xml

     #
     # Liferay will automatically detect the Hibernate dialect in
     # com.liferay.portal.spring.PortalHibernateConfiguration. Set this property
     # to manually override the automatically detected dialect.
     #
     #hibernate.dialect=

     #
     # Set the Hibernate connection release mode. You should not modify this
     # unless you know what you're doing. The default setting works best for
     # Spring managed transactions. See the method buildSessionFactory in class
     # org.springframework.orm.hibernate3.LocalSessionFactoryBean and search for
     # the phrase "on_close" to understand how this works.
     #
     #hibernate.connection.release_mode=on_close

     #
     # Set the Hibernate cache provider. Ehcache is recommended in a clustered
     # environment. See the property "net.sf.ehcache.configurationResourceName"
     # for detailed configuration.
     #
     hibernate.cache.provider_class=com.liferay.portal.dao.orm.hibernate.EhCacheProvider
     #hibernate.cache.provider_class=net.sf.hibernate.cache.HashtableCacheProvider
     #hibernate.cache.provider_class=com.liferay.portal.dao.orm.hibernate.OSCacheProvider
     #hibernate.cache.provider_class=com.liferay.portal.dao.orm.hibernate.TerracottaCacheProvider

     #
     # This property is used if Hibernate is configured to use Ehcache's
     # cache provider.
     #
     net.sf.ehcache.configurationResourceName=/ehcache/hibernate.xml

     #
     # Uncomment the following in a clustered environment.
     #
     #net.sf.ehcache.configurationResourceName=/ehcache/hibernate-clustered.xml

     #
     # Uncomment the following in a Terracotta environment.
     #
     #net.sf.ehcache.configurationResourceName=/ehcache/hibernate-terracotta.xml

     #
     # Set other Hibernate cache settings.
     #
     hibernate.cache.use_query_cache=true
     hibernate.cache.use_second_level_cache=true
     hibernate.cache.use_minimal_puts=true
     hibernate.cache.use_structured_entries=false

     #
     # Uncomment these properties to disable Hibernate caching.
     #
     #hibernate.cache.provider_class=org.hibernate.cache.NoCacheProvider
     #hibernate.cache.use_query_cache=false
     #hibernate.cache.use_second_level_cache=false

     #
     # Set the JDBC batch size to improve performance. However, if you're using
     # Oracle 9i, you must set the batch size to 0 as a workaround for a hanging
     # bug in the Oracle driver. See LEP-1234 for more information.
     #
     hibernate.jdbc.batch_size=20
     #hibernate.jdbc.batch_size=0

     #
     # Set other miscellaneous Hibernate properties.
     #
     hibernate.jdbc.use_scrollable_resultset=true
     hibernate.bytecode.use_reflection_optimizer=true
     hibernate.show_sql=false

     #
     # Use the classic query factory until WebLogic and Hibernate 3 can get
     # along. See http://www.hibernate.org/250.html#A23 for more information.
     #
     hibernate.query.factory_class=org.hibernate.hql.classic.ClassicQueryTranslatorFactory

     #
     # Set this property to true to enable Hibernate cache monitoring. See
     # LPS-2056 for more information.
     #
     hibernate.generate_statistics=false

 ##
 ## JDBC
 ##

     #
     # Set the JNDI name to lookup the JDBC data source. If none is set,
     # then the portal will attempt to create the JDBC data source based on the
     # properties prefixed with "jdbc.default.".
     #
     #jdbc.default.jndi.name=jdbc/LiferayPool

     #
     # Set the properties used to create the JDBC data source. These properties
     # will only be read if the property "jdbc.default.jndi.name" is not set.
     #
     # The default settings are configured for an in-memory database called
     # Hypersonic that is not recommended for production use. Please change the
     # properties to use another database.
     #
     # Add dynamic-data-source-spring.xml to the property "spring.configs" to
     # configure the portal to use one database cluster for read calls and
     # another database cluster for write calls. The convention is to create a
     # set of properties prefixed with "jdbc.read." to handle read calls and
     # another set of properties prefixed with "jdbc.write." to handle write
     # calls. These data sources can also be created via JNDI by setting the
     # properties "jdbc.read.jndi.name" and "jdbc.write.jndi.name".
     #

     #
     # DB2
     #
     #jdbc.default.driverClassName=com.ibm.db2.jcc.DB2Driver
     #jdbc.default.url=jdbc:db2:lportal
     #jdbc.default.username=db2admin
     #jdbc.default.password=lportal

     #
     # Derby
     #
     #jdbc.default.driverClassName=org.apache.derby.jdbc.EmbeddedDriver
     #jdbc.default.url=jdbc:derby:lportal
     #jdbc.default.username=
     #jdbc.default.password=

     #
     # Hypersonic
     #
     jdbc.default.driverClassName=org.hsqldb.jdbcDriver
     jdbc.default.url=jdbc:hsqldb:${liferay.home}/data/hsql/lportal
     jdbc.default.username=sa
     jdbc.default.password=

     #
     # Ingres
     #
     #jdbc.default.driverClassName=com.ingres.jdbc.IngresDriver
     #jdbc.default.url=jdbc:ingres://localhost:II7/lportal
     #jdbc.default.username=
     #jdbc.default.password=

     #
     # MySQL
     #
     #jdbc.default.driverClassName=com.mysql.jdbc.Driver
     #jdbc.default.url=jdbc:mysql://localhost/lportal?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false
     #jdbc.default.username=
     #jdbc.default.password=

     #
     # Oracle
     #
     #jdbc.default.driverClassName=oracle.jdbc.driver.OracleDriver
     #jdbc.default.url=jdbc:oracle:thin:@localhost:1521:xe
     #jdbc.default.username=lportal
     #jdbc.default.password=lportal

     #
     # P6Spy
     #
     #jdbc.default.driverClassName=com.p6spy.engine.spy.P6SpyDriver
     #jdbc.default.url=jdbc:mysql://localhost/lportal?useUnicode=true&characterEncoding=UTF-8&useFastDateParsing=false
     #jdbc.default.username=
     #jdbc.default.password=

     #
     # PostgreSQL
     #
     #jdbc.default.driverClassName=org.postgresql.Driver
     #jdbc.default.url=jdbc:postgresql://localhost:5432/lportal
     #jdbc.default.username=sa
     #jdbc.default.password=

     #
     # SQL Server
     #
     #jdbc.default.driverClassName=net.sourceforge.jtds.jdbc.Driver
     #jdbc.default.url=jdbc:jtds:sqlserver://localhost/lportal
     #jdbc.default.username=sa
     #jdbc.default.password=

     #
     # Sybase
     #
     #jdbc.default.driverClassName=net.sourceforge.jtds.jdbc.Driver
     #jdbc.default.url=jdbc:jtds:sybase://localhost:5000/lportal
     #jdbc.default.username=sa
     #jdbc.default.password=

     #
     # Liferay uses C3PO by default for connection pooling. The data source
     # factory can be configured to use JNDI or another pooling implementation by
     # modifying infrastructure-spring.xml. See
     # http://www.mchange.com/projects/c3p0/index.html#configuration for a list
     # of additional fields used by C3PO for configuring the database connection.
     #
     jdbc.default.acquireIncrement=5
     jdbc.default.maxPoolSize=100
     jdbc.default.minPoolSize=10
     jdbc.default.numHelperThreads=10

 ##
 ## Custom SQL
 ##

     #
     # Input a list of comma delimited custom SQL configurations.
     #
     custom.sql.configs=custom-sql/default.xml

     #
     # Some databases do not recognize a NULL IS NULL check. Set the
     # "custom.sql.function.isnull" and "custom.sql.function.isnotnull"
     # properties for your specific database.
     #
     # There is no need to manually set these properties because
     # com.liferay.portal.spring.PortalHibernateConfiguration already sets it.
     # However, these properties are available so that you can see how you can
     # override it for a database that PortalHibernateConfiguration does not yet
     # know how to auto configure.
     #

     #
     # DB2
     #
     #custom.sql.function.isnull=CAST(? AS VARCHAR(32672)) IS NULL
     #custom.sql.function.isnotnull=CAST(? AS VARCHAR(32672)) IS NOT NULL

     #
     # MySQL (for testing only)
     #
     #custom.sql.function.isnull=IFNULL(?, '1') = '1'
     #custom.sql.function.isnotnull=IFNULL(?, '1') = '0'

     #
     # Sybase
     #
     #custom.sql.function.isnull=ISNULL(?, '1') = '1'
     #custom.sql.function.isnotnull=ISNULL(?, '1') = '0'

 ##
 ## Database
 ##

     #
     # Specify any database vendor specific settings.
     #

     #
     # MySQL
     #

     #
     # Set the MySQL engine type. InnoDB is the recommended engine because it
     #
     database.mysql.engine=InnoDB

     #
     # MySQL
     #
     database.mysql.function.lower.enabled=false

 ##
 ## Transaction Isolation
 ##

     #
     # Set the definition of the "portal" transaction isolation level. The
     # "portal" transaction isolation level is not a real isolation level. It is
     # just a pointer to a real isolation level that can be configured by setting
     # this property. Set the value to -1 to use the database's default isolation
     # level. Set the value to 2 to use "read committed". Set the value to 1 to
     # use "read uncommitted". Set the value to 4 to use "repeatable read". Set
     # the value to 8 to use "serializable".
     #
     transaction.isolation.portal=2

 ##
 ## Sharded Databases
 ##

     #
     # Specify JDBC data sources that are available for database sharding. These
     # must be configured in the "jdbc.*" section above as well as in the
     # shard-data-source-spring.xml file.
     #
     shard.available.names=default
     #shard.available.names=default,one,two

     #
     # Set the database that is to be used for the default company and globally
     # used tables in a sharded environment.
     #
     shard.default.name=default

     #
     # Specify an algorithm for selecting a new shard on portal instance
     # creation. Use ManualShardSelector for shard selection via the web
     # interface.
     #
     shard.selector=com.liferay.portal.dao.shard.RoundRobinShardSelector
     #shard.selector=com.liferay.portal.dao.shard.ManualShardSelector

 ##
 ## Ehcache
 ##

     #
     # Set the classpath to the location of the Ehcache config file for internal
     # caches. Edit the file specified in the property
     # "ehcache.multi-vm.config.location" to enable clustered cache.
     #
     ehcache.single.vm.config.location=/ehcache/liferay-single-vm.xml
     ehcache.multi.vm.config.location=/ehcache/liferay-multi-vm.xml

     #
     # Uncomment the following in a clustered environment.
     #
     #ehcache.multi.vm.config.location=/ehcache/liferay-multi-vm-clustered.xml

 ##
 ## JavaScript
 ##

     #
     # Set a list of JavaScript files that will be loaded automatically in
     # /html/common/themes/top_js.jsp.
     #
     # There are two lists of files specified in the properties
     # "javascript.barebone.files" and "javascript.everything.files".
     #
     # As the name suggests, the barebone list is the minimum list of JavaScript
     # files required for most cases. The everything list includes everything
     # else not listed in the barebone list.
     #
     # The two lists of files exist for performance reasons because
     # unauthenticated users usually do not utilize all the JavaScript that is
     # available. See the property "javascript.barebone.enabled" for more
     # information on the logic of when the barebone list is used and when the
     # everything list is used and how to customize that logic.
     #
     # The list of files are also merged and packed for further performance
     # improvements. See the property "javascript.fast.load" for more details.
     #

     #
     # Specify the list of barebone files.
     #
     # The ordering of the JavaScript files is important. Specifically, all
     # JQuery scripts should go first.
     #
     # The Liferay scripts are grouped in such a way, that the first grouping
     # denotes utility scripts that are used by the second and third groups. The
     # second grouping denotes utility classes that rely on the first group, but
     # does not rely on the second or third group. The third grouping denotes
     # modules that rely on the first and second group.
     #
     javascript.barebone.files=                  #
         # JQuery scripts
         #
                  jquery/jquery.js,         jquery/cookie.js,         jquery/hover_intent.js,         jquery/j2browse.js,         jquery/livequery.js,                  #
         # jQuery UI 1.5
         #
                  jquery/ui.core.js,         jquery/ui.datepicker.js,         jquery/ui.dialog.js,         jquery/ui.draggable.js,         jquery/ui.slider.js,                  #
         # jQuery UI 1.6
         #
                  jquery/ui.color_picker.js,                  #
         # Miscellaneous scripts
         #
                  misc/swfobject.js,                  #
         # Liferay base utility scripts
         #
                  liferay/class.js,         liferay/language.js,         liferay/liferay.js,         liferay/util.js,                  #
         # Liferay utility scripts
         #
                  liferay/events.js,         liferay/popup.js,         liferay/portal.js,         liferay/portlet.js,         liferay/portlet_sharing.js,         liferay/portlet_url.js,                  #
         # Liferay modules
         #
                  liferay/color_picker.js,         liferay/dock.js,         liferay/menu.js

     #
     # Specify the list of everything files (everything else not already in the
     # list of barebone files).
     #
     javascript.everything.files=                  #
         # JQuery scripts
         #
                  jquery/form.js,         jquery/jeditable.js,         jquery/json.js,         jquery/livesearch.js,         jquery/media.js,         jquery/position.js,         jquery/scrollTo.js,         jquery/selection.js,         jquery/treeview.js,                  #
         # jQuery UI 1.5
         #
                  jquery/ui.accordion.js,         jquery/ui.droppable.js,         jquery/ui.resizable.js,         jquery/ui.sortable.js,         jquery/ui.tabs.js,         #jquery/ui.selectable.js,                  #
         # jQuery UI 1.6
         #
                  jquery/ui.autocomplete.js,         jquery/ui.tree.js,                  #
         # jQuery UI 1.5 Effects library
         #
                  #jquery/effects.core.js,         #jquery/effects.blind.js,         #jquery/effects.bounce.js,         #jquery/effects.clip.js,         #jquery/effects.drop.js,         #jquery/effects.explode.js,         #jquery/effects.fold.js,         #jquery/effects.highlight.js,         #jquery/effects.pulsate.js,         #jquery/effects.scale.js,         #jquery/effects.shake.js,         #jquery/effects.slide.js,         #jquery/effects.transfer.js,                  #
         # Liferay base utility scripts
         #
                  liferay/layout.js,         liferay/observable.js,                  #
         # Liferay modules
         #
                  liferay/address.js,         liferay/auto_fields.js,         liferay/dynamic_select.js,         liferay/layout_configuration.js,         liferay/layout_exporter.js,         liferay/notice.js,         liferay/navigation.js,         liferay/panel.js,         liferay/panel_floating.js,         liferay/poller.js,         liferay/search_container.js,         liferay/session.js,         liferay/tags_categories_selector.js,         liferay/tags_entries_selector.js,         liferay/undo_manager.js,         liferay/upload.js

     #
     # Set this property to false to always load JavaScript files listed in the
     # property "javascript.everything.files". Set this to true to sometimes
     # load "javascript.barebone.files" and sometimes load
     # "javascript.everything.files".
     #
     # The default logic is coded in com.liferay.portal.events.ServicePreAction
     # in such a way that unauthenticated users get the list of barebone
     # JavaScript files whereas authenticated users get both the list of barebone
     # JavaScript files and the list of everything JavaScript files.
     #
     javascript.barebone.enabled=true

     #
     # Set this property to true to load the packed version of files listed in
     # the properties "javascript.barebone.files" or
     # "javascript.everything.files".
     #
     # Set this property to false for easier debugging for development. You can
     # also disable fast loading by setting the URL parameter "js_fast_load" to
     # "0".
     #
     javascript.fast.load=true

     #
     # Input a list of comma delimited properties that are valid bundle ids for
     # the JavaScript minifier.
     #
     javascript.bundle.ids=         javascript.barebone.files,         javascript.everything.files

     #
     # Define a bundle directory for each property listed in
     # "javascript.bundle.ids".
     #
     javascript.bundle.dir[javascript.barebone.files]=/html/js
     javascript.bundle.dir[javascript.everything.files]=/html/js

     #
     # Set this to true to enable the display of JavaScript logging.
     #
     javascript.log.enabled=false

 ##
 ## SQL Data
 ##

     #
     # Set the default SQL IDs for common objects.
     #
     sql.data.com.liferay.portal.model.Country.country.id=19
     sql.data.com.liferay.portal.model.Region.region.id=5
     sql.data.com.liferay.portal.model.ListType.account.address=10000
     sql.data.com.liferay.portal.model.ListType.account.email.address=10004
     sql.data.com.liferay.portal.model.ListType.contact.email.address=11003
     sql.data.com.liferay.portal.model.ListType.organization.status=12017

 ##
 ## Company
 ##

     #
     # This sets the default web id. Omniadmin users must belong to the company
     # with this web id.
     #
     company.default.web.id=liferay.com

     #
     # This sets the default home URL of the portal.
     #
     company.default.home.url=/web/guest

     #
     # The login field is prepopulated with the company's domain name if the
     # login is unpopulated and user authentication is based on email addresses.
     # Set this to false to disable the behavior.
     #
     company.login.prepopulate.domain=true

     #
     # The portal can authenticate users based on their email address, screen
     # name, or user id.
     #
     company.security.auth.type=emailAddress
     #company.security.auth.type=screenName
     #company.security.auth.type=userId

     #
     # Set this to true to ensure users login with https.
     #
     company.security.auth.requires.https=false

     #
     # Set this to true to allow users to select the "remember me" feature to
     # automatically login to the portal.
     #
     company.security.auto.login=true

     #
     # Set this to the maximum age (in number of seconds) of the browser cookie
     # that enables the "remember me" feature. A value of 31536000 signifies
     # lifespan of one year. A value of -1 signifies a lifespan of a browser
     # session.
     #
     # Rather than setting this to 0, set the property
     # "company.security.auto.login" to false to disable the "remember me"
     # feature.
     #
     company.security.auto.login.max.age=31536000

     #
     # Set this to true to allow users to ask the portal to send them their
     # password.
     #
     company.security.send.password=true

     #
     # Set this to true to allow strangers to create accounts and register
     # themselves on the portal.
     #
     company.security.strangers=true

     #
     # Enter a friendly URL of a page that will be used to create new accounts
     # whenever the user clicks the "create account" link in the login portlet.
     # This allows providing custom portlets to create accounts. By default, the
     # portal's create account will be used.
     #
     #company.security.strangers.url=/create_account

     #
     # Set this to true if strangers can create accounts with email addresses
     # that match the company mail suffix. This property is not used unless
     # "company.security.strangers" is also set to true.
     #
     company.security.strangers.with.mx=true

     #
     # Set this to true if strangers who create accounts need to be verified via
     # email.
     #
     company.security.strangers.verify=false

     #
     # Set this to true to allow community administrators to use their own logo
     # instead of the enterprise logo.
     #
     company.security.community.logo=true

     #
     # Input a list of sections that will be included as part of the company
     # settings form.
     #
     company.settings.form.configuration=general,authentication,default-user-associations,reserved-credentials,mail-host-names,email-notifications
     company.settings.form.identification=addresses,phone-numbers,additional-email-addresses,websites
     company.settings.form.miscellaneous=display-settings

 ##
 ## Users
 ##

     #
     # Set this to false if users cannot be deleted.
     #
     users.delete=true

     #
     # Set this to true to always autogenerate user screen names even if the user
     # gives a specific user screen name.
     #
     users.screen.name.always.autogenerate=false

     #
     # Input a class name that extends
     # com.liferay.portal.security.auth.ScreenNameGenerator. This class will be
     # called to generate user screen names.
     #
     users.screen.name.generator=com.liferay.portal.security.auth.ScreenNameGenerator

     #
     # Input a class name that extends
     # com.liferay.portal.security.auth.ScreenNameValidator. This class will be
     # called to validate user ids.
     #
     users.screen.name.validator=com.liferay.portal.security.auth.ScreenNameValidator
     #users.screen.name.validator=com.liferay.portal.security.auth.LiberalScreenNameValidator

     #
     # Set this to false if you want to be able to create users without an email
     # address. Note that not requiring an email address disables some features
     # that depend on an email address.
     #
     users.email.address.required=true

     #
     # Set the maximum file size for user portraits. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     users.image.max.size=307200

     #
     # Set this to true to record last login information for a user.
     #
     users.update.last.login=true

     #
     # Input a list of sections that will be included as part of the user form
     # when adding a user.
     #
     users.form.add.main=details,organizations
     users.form.add.identification=
     users.form.add.miscellaneous=

     #
     # Input a list of sections that will be included as part of the user form
     # when updating a user.
     #
     users.form.update.main=details,password,organizations,communities,user-groups,roles,categorization
     users.form.update.identification=addresses,phone-numbers,additional-email-addresses,websites,instant-messenger,social-network,sms,open-id
     users.form.update.miscellaneous=announcements,display-settings,comments,custom-attributes

     #
     # Input a list of sections that will be included as part of the user form
     # when updating a user in the My Account portlet.
     #
     users.form.my.account.main=details,password,organizations,communities,user-groups,roles,categorization
     users.form.my.account.identification=addresses,phone-numbers,additional-email-addresses,websites,instant-messenger,social-network,sms,open-id
     users.form.my.account.miscellaneous=announcements,display-settings,comments,custom-attributes

     #
     # Set this to true to enable reminder queries that are used to help reset a
     # user's password.
     #
     users.reminder.queries.enabled=true
     users.reminder.queries.custom.question.enabled=true

     #
     # Input a list of questions used for reminder queries.
     #
     users.reminder.queries.questions=what-is-your-primary-frequent-flyer-number,what-is-your-library-card-number,what-was-your-first-phone-number,what-was-your-first-teacher's-name,what-is-your-father's-middle-name

 ##
 ## Groups and Roles
 ##

     #
     # Input a list of comma delimited system group names that will exist in
     # addition to the standard system groups. When the server starts, the portal
     # checks to ensure all system groups exist. Any missing system group will be
     # created by the portal.
     #
     system.groups=

     #
     # Input a list of comma delimited system role names that will exist in
     # addition to the standard system roles. When the server starts, the portal
     # checks to ensure all system roles exist. Any missing system role will be
     # created by the portal.
     #
     # The standard system roles are: Administrator, Guest, Power User, and User.
     # These roles cannot be removed or renamed.
     #
     system.roles=

     #
     # Set the description of the Administrator system role.
     #
     system.role.Administrator.description=Administrators are super users who can do anything.

     #
     # Set the description of the Guest system role.
     #
     system.role.Guest.description=Unauthenticated users always have this role.

     #
     # Set the description of the Owner system role.
     #
     system.role.Owner.description=This is an implied role with respect to the objects users create.

     #
     # Set the description of the Power User system role.
     #
     system.role.Power.User.description=Power Users have their own public and private pages.

     #
     # Set the description of the User system role.
     #
     system.role.User.description=Authenticated users should be assigned this role.

     #
     # Input a list of comma delimited system community role names that will
     # exist in addition to the standard system community roles. When the server
     # starts, the portal checks to ensure all system community roles exist. Any
     # missing system community role will be created by the portal.
     #
     # The standard system community roles are: Community Administrator,
     # Community Member, and Community  Owner. These roles cannot be removed or
     # renamed.
     #
     system.community.roles=

     #
     # Set the description of the Community Administrator system community role.
     #
     system.community.role.Community.Administrator.description=Community Administrators are super users of their community but cannot make other users into Community Administrators.

     #
     # Set the description of the Community Member system community role.
     #
     system.community.role.Community.Member.description=All users who belong to a community have this role within that community.

     #
     # Set the description of the Community Owner system community role.
     #
     system.community.role.Community.Owner.description=Community Owners are super users of their community and can assign community roles to users.

     #
     # Input a list of comma delimited system organization role names that will
     # exist in addition to the standard system organization roles. When the
     # server starts, the portal checks to ensure all system organization roles
     # exist. Any missing system organization role will be created by the portal.
     #
     # The standard system organization roles are: Organization Administrator,
     # Organization Member, and Organization  Owner. These roles cannot be
     # removed or renamed.
     #
     system.organization.roles=

     #
     # Set the description of the Organization Administrator system organization
     # role.
     #
     system.organization.role.Organization.Administrator.description=Organization Administrators are super users of their organization but cannot make other users into Organization Administrators.

     #
     # Set the description of the Organization Member system organization role.
     #
     system.organization.role.Organization.Member.description=All users who belong to a organization have this role within that organization.

     #
     # Set the description of the Organization Owner system organization role.
     #
     system.organization.role.Organization.Owner.description=Organization Owners are super users of their organization and can assign organization roles to users.

     #
     # Omniadmin users can administer the portal's core functionality: gc,
     # shutdown, etc. Omniadmin users must belong to the default company.
     #
     # Multiple portal instances might be deployed on one application server, and
     # not all of the administrators should have access to this core
     # functionality. Input the ids of users who are omniadmin users.
     #
     # Leave this field blank if users who belong to the right company and have
     # the Administrator role are allowed to administer the portal's core
     # functionality.
     #
     omniadmin.users=

     #
     # Set this to true if all users are required to agree to the terms of use.
     #
     terms.of.use.required=true

     #
     # Specify the group id and the article id of the Journal article that will
     # be displayed as the terms of use. The default text will be used if no
     # Journal article is specified.
     #
     terms.of.use.journal.article.group.id=
     terms.of.use.journal.article.id=

     #
     # Specify subtypes of roles if you want to be able to search for roles
     # using your custom criteria.
     #
     roles.community.subtypes=
     roles.organization.subtypes=
     roles.regular.subtypes=

 ##
 ## Organizations
 ##

     organizations.types=regular-organization,location

     organizations.rootable[regular-organization]=true
     organizations.children.types[regular-organization]=regular-organization,location
     organizations.country.enabled[regular-organization]=false
     organizations.country.required[regular-organization]=false

     organizations.rootable[location]=false
     #organizations.children.types[location]=
     organizations.country.enabled[location]=true
     organizations.country.required[location]=true

     #
     # Input a list of sections that will be included as part of the organization
     # form when adding an organization.
     #
     organizations.form.add.main=details
     organizations.form.add.identification=
     organizations.form.add.miscellaneous=

     #
     # Input a list of sections that will be included as part of the organization
     # form when updating an organization.
     #
     organizations.form.update.main=details,categorization
     organizations.form.update.identification=addresses,phone-numbers,additional-email-addresses,websites,services
     organizations.form.update.miscellaneous=comments,reminder-queries,custom-attributes

     #
     # Set this property to true if you want any administrator that creates an
     # organization to be automatically assigned to that organization.
     #
     organizations.assignment.auto=false

     #
     # Set this property to false if you want any administrator of an
     # organization to be able to assign any user to that organization. By
     # default, he will only be able to assign the users of the organizations
     # and suborganizations that he can manage.
     #
     organizations.assignment.strict=true

     #
     # Set this property to true if you want users to only be members of the
     # organizations to which they are assigned explicitly. By default they will
     # also become implicit members of the ancestors of those organizations.
     # for example if a user belongs to Liferay Spain he will implicitly be a
     # member of the ancestors Liferay Europe and Liferay Global and will be
     # able to access their private pages.
     #
     organizations.membership.strict=false

 ##
 ## Languages and Time Zones
 ##

     #
     # Specify the available locales. Messages corresponding to a specific
     # language are specified in properties files with file names matching that
     # of content/Language_*.properties. These values can also be overridden in
     # properties files with file names matching that of
     # content/Language-ext_*.properties. Use a comma to separate
     # each entry.
     #
     # All locales must use UTF-8 encoding.
     #
     # See the following links specifiy language and country codes:
     #     http://ftp.ics.uci.edu/pub/ietf/http/related/iso639.txt
     #     http://userpage.chemie.fu-berlin.de/diverse/doc/ISO_3166.html
     #
     locales=ar_SA,eu_ES,ca_AD,ca_ES,zh_CN,zh_TW,cs_CZ,nl_NL,en_US,fi_FI,fr_FR,de_DE,el_GR,hu_HU,it_IT,ja_JP,ko_KR,nb_NO,fa_IR,pl_PL,pt_BR,pt_PT,ru_RU,sk_SK,es_ES,sv_SE,tr_TR,vi_VN

     #
     # Set this to true if unauthenticated users get their preferred language
     # from the Accept-Language header. Set this to false if unauthenticated
     # users get their preferred language from their company.
     #
     locale.default.request=false

     #
     # Specify the available time zones. The specified ids must match those from
     # the class java.util.TimeZone.
     #
     time.zones=         Pacific/Midway,         Pacific/Honolulu,         America/Anchorage,         America/Los_Angeles,         America/Denver,         America/Chicago,         America/New_York,         America/Puerto_Rico,         America/St_Johns,         America/Sao_Paulo,         America/Noronha,         Atlantic/Azores,         UTC,         Europe/Lisbon,         Europe/Paris,         Europe/Istanbul,         Asia/Jerusalem,         Asia/Baghdad,         Asia/Tehran,         Asia/Dubai,         Asia/Kabul,         Asia/Karachi,         Asia/Calcutta,         Asia/Katmandu,         Asia/Dhaka,         Asia/Rangoon,         Asia/Saigon,         Asia/Shanghai,         Asia/Tokyo,         Asia/Seoul,         Australia/Darwin,         Australia/Sydney,         Pacific/Guadalcanal,         Pacific/Auckland,         Pacific/Enderbury,         Pacific/Kiritimati

 ##
 ## Look and Feel
 ##

     #
     # Set this to false if the system does not use allow users to modify the
     # look and feel.
     #
     look.and.feel.modifiable=true

     #
     # Set the default layout template id.
     #
     default.layout.template.id=2_columns_ii

     #
     # Set the default theme id for regular themes.
     #
     default.regular.theme.id=classic

     #
     # Set the default color scheme id for regular themes.
     #
     default.regular.color.scheme.id=01

     #
     # Set the default theme id for wap themes.
     #
     default.wap.theme.id=mobile

     #
     # Set the default color scheme id for wap themes.
     #
     default.wap.color.scheme.id=01

     #
     # Set this to true if you want a change in the theme selection of the public
     # or private group to automatically be applied to the other (i.e. if public
     # and private group themes should always be the same).
     #
     theme.sync.on.group=false

 ##
 ## Request
 ##

     #
     # Portlets that have been configured to use private request attributes in
     # liferay-portlet.xml may still want to share some request attributes. This
     # property allows you to configure which request attributes will be shared.
     # Set a comma delimited list of attribute names that will be shared when the
     # attribute name starts with one of the specified attribute names. For
     # example, if you set the value to "hello_,world_", then all attribute names
     # that start with "hello_" or "world_" will be shared.
     #
     request.shared.attributes=LIFERAY_SHARED_

 ##
 ## Session
 ##

     #
     # Specify the number of minutes before a session expires. This value is
     # always overridden by the value set in web.xml.
     #
     session.timeout=30

     #
     # Specify the number of minutes before a warning is sent to the user
     # informing the user of the session expiration. Specify 0 to disable any
     # warnings.
     #
     session.timeout.warning=1

     #
     # Set the auto-extend mode to true to avoid having to ask the user whether
     # to extend the session or not. Instead it will be automatically extended.
     # The purpose of this mode is to keep the session open as long as the user
     # browser is open and with a portal page loaded. It is recommended to use
     # this setting along with a smaller "session.timeout", such as 5 minutes for
     # better performance.
     #
     session.timeout.auto.extend=false

     #
     # Set this to true if the user is redirected to the default page when the
     # session expires.
     #
     session.timeout.redirect.on.expire=false

     #
     # Portlets that have been configured to use private session attributes in
     # liferay-portlet.xml may still want to share some session attributes. This
     # property allows you to configure which session attributes will be shared.
     # Set a comma delimited list of attribute names that will be shared when the
     # attribute name starts with one of the specified attribute names. For
     # example, if you set the value to "hello_,world_", then all attribute names
     # that start with "hello_" or "world_" will be shared.
     #
     # Note that this property is used to specify the sharing of session
     # attributes from the portal to the portlet. This is not used to specify
     # session sharing between portlet WARs or from the portlet to the portal.
     #
     session.shared.attributes=org.apache.struts.action.LOCALE,COMPANY_,USER_,LIFERAY_SHARED_

     #
     # Set this to false to disable all persistent cookie. Features like
     # automatically logging in will not work.
     #
     session.enable.persistent.cookies=true

     #
     # Set this to true to enable sessions when cookies are disabled. See
     # LEP-4787. This behavior is configurable because enabling it can break
     # certain setups.
     #
     session.enable.url.with.session.id=true

     #
     # The login process sets several cookies if persistent cookies are enabled.
     # Set this property to set the domain of those cookies.
     #
     #session.cookie.domain=

     #
     # Set this to true to invalidate the session when a user logs into the
     # portal. This helps prevents phishing. Set this to false if you need the
     # guest user and the authenticated user to have the same session.
     #
     session.enable.phishing.protection=true

     #
     # Set this to true to test whether users have cookie support before allowing
     # them to sign in. This test will always fail if "tck.url" is set to true
     # because that property disables session cookies.
     #
     session.test.cookie.support=true

     #
     # Set this to true to disable sessions. Doing this will use cookies to
     # remember the user across requests. This is useful if you want to scale
     # very large sites where the user may be sent to a different server for each
     # request. The drawback to this approach is that you must not rely on the
     # API for sessions provided by the servlet and portlet specs.
     #
     # This feature is only available for Tomcat and requires that you set
     # Tomcat's Manager class to
     # "com.liferay.support.tomcat.session.SessionLessManagerBase".
     #
     session.disabled=false

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.portal.struts.SessionAction. These classes will run at the
     # specified event.
     #

     #
     # Servlet session create event
     #
     servlet.session.create.events=com.liferay.portal.events.SessionCreateAction

     #
     # Servlet session destroy event
     #
     servlet.session.destroy.events=com.liferay.portal.events.SessionDestroyAction

     #
     # Set this to true to track user clicks in memory for the duration of a
     # user's session. Setting this to true allows you to view all live sessions
     # in the Admin portlet.
     #
     session.tracker.memory.enabled=true

     #
     # Set this to true to track user clicks in the database after a user's
     # session is invalidated. Setting this to true allows you to generate usage
     # reports from the database. Use this cautiously because this will store a
     # lot of usage data.
     #
     session.tracker.persistence.enabled=false

     #
     # Set this to true to convert the tracked paths to friendly URLs.
     #
     session.tracker.friendly.paths.enabled=false

     #
     # Enter a list of comma delimited paths that should not be tracked.
     #
     session.tracker.ignore.paths=         /portal/render_portlet,                  /document_library/get_file

 ##
 ## JAAS
 ##

     #
     # Set this to false to disable JAAS security checks. Disabling JAAS speeds
     # up login. JAAS must be disabled if administrators are to be able to
     # impersonate other users.
     #
     portal.jaas.enable=false

     #
     # By default, com.liferay.portal.security.jaas.PortalLoginModule loads the
     # correct JAAS login module based on what application server or servlet
     # container the portal is deployed on. Set a JAAS implementation class to
     # override this behavior.
     #
     #portal.jaas.impl=

     #
     # The JAAS process may pass in an encrypted password and the authentication
     # will only succeed if there is an exact match. Set this property to false
     # to relax that behavior so the user can input an unencrypted password.
     #
     portal.jaas.strict.password=false

     #
     # Set this to true to enable administrators to impersonate other users.
     #
     portal.impersonation.enable=true

 ##
 ## Security Manager
 ##

     #
     # Set this to true to use Liferay's java.lang.SecurityManager
     # implementation. This should never be set to true except for debugging
     # purposes.
     #
     portal.security.manager.enable=false

 ##
 ## LDAP
 ##

     #
     # Set the values used to connect to a LDAP store.
     #
     ldap.factory.initial=com.sun.jndi.ldap.LdapCtxFactory
     ldap.base.provider.url=ldap://localhost:10389
     ldap.base.dn=dc=example,dc=com
     ldap.security.principal=uid=admin,ou=system
     ldap.security.credentials=secret
     ldap.referral=follow

     #
     # Settings for com.liferay.portal.security.auth.LDAPAuth can be configured
     # from the Admin portlet. It provides out of the box support for Apache
     # Directory Server, Microsoft Active Directory Server, Novell eDirectory,
     # and OpenLDAP. The default settings are for Apache Directory Server.
     #
     # The LDAPAuth class must be specified in the property "auth.pipeline.pre"
     # to be executed.
     #
     # Encryption is implemented by com.liferay.util.Encryptor.provider.class in
     # system.properties.
     #
     ldap.auth.enabled=false
     ldap.auth.required=false

     #
     # Set either bind or password-compare for the LDAP authentication method.
     # Bind is preferred by most vendors so that you don't have to worry about
     # encryption strategies.
     #
     ldap.auth.method=bind
     #ldap.auth.method=password-compare

     #
     # Set the password encryption to used to compare passwords if the property
     # "ldap.auth.method" is set to password-compare.
     #
     ldap.auth.password.encryption.algorithm=
     ldap.auth.password.encryption.algorithm.types=MD5,SHA

     #
     # Active Directory stores information about the user account as a series of
     # bit fields in the UserAccountControl attribute.
     #
     # If you want to prevent disabled accounts from logging into the portal you
     # need to use a search filter similiar to the following:
     # (&(objectclass=person)(userprincipalname=@email_address@)(!(UserAccountControl:1.2.840.113556.1.4.803:=2)))
     #
     # See the following links:
     #     http://support.microsoft.com/kb/305144/
     #     http://support.microsoft.com/?kbid=269181
     #
     ldap.auth.search.filter=(mail=@email_address@)

     #
     # You can write your own class that extends
     # com.liferay.portal.security.ldap.AttributesTransformer to transform the
     # LDAP attributes before a user or group is imported to the LDAP store.
     #
     ldap.attrs.transformer.impl=com.liferay.portal.security.ldap.AttributesTransformer

     #
     # You can write your own class that extends
     # com.liferay.portal.security.ldap.LDAPUser to customize the behavior for
     # exporting portal users to the LDAP store.
     #
     ldap.user.impl=com.liferay.portal.security.ldap.LDAPUser

     #
     # When a user is exported to LDAP and the user does not exist, the user will
     # be created with the following default object classes.
     #
     ldap.user.default.object.classes=top,person,inetOrgPerson,organizationalPerson

     #
     # When importing and exporting users, the portal will use this mapping to
     # connect LDAP user attributes and portal user variables
     #
     ldap.user.mappings=screenName=cn\npassword=userPassword\nemailAddress=mail\nfirstName=givenName\nlastName=sn\njobTitle=title\ngroup=groupMembership

     #
     # When importing groups, the portal will use this mapping to connect LDAP
     # group attributes and portal user group variables.
     #
     ldap.group.mappings=groupName=cn\ndescription=description\nuser=uniqueMember

     #
     # Settings for importing users and groups from LDAP to the portal.
     #
     ldap.import.enabled=false
     ldap.import.on.startup=false
     ldap.import.interval=10
     ldap.import.user.search.filter=(objectClass=inetOrgPerson)
     ldap.import.group.search.filter=(objectClass=groupOfUniqueNames)

     #
     # Set either user or group for import method. If set to user, portal will
     # import all users and the groups associated with those users. If set to
     # group, the portal import all groups and the users associated those groups.
     # This value should be set based on how your LDAP server stores group
     # membership information.
     #
     ldap.import.method=user
     #ldap.import.method=group

     #
     # Settings for exporting users from the portal to LDAP. This allows a user
     # to modify his first name, last name, etc. in the portal and have that
     # change get pushed to the LDAP server. This will only be active if the
     # property "ldap.auth.enabled" is also set to true. New users and groups
     # will be created at the specified DN.
     #
     ldap.export.enabled=true
     ldap.users.dn=ou=users,dc=example,dc=com
     ldap.groups.dn=ou=groups,dc=example,dc=com

     #
     # Set this to true to use the LDAP's password policy instead of the portal
     # password policy.
     #
     ldap.password.policy.enabled=false

     #
     # Set these values to be a portion of the error message returned by the
     # appropriate directory server to allow the portal to recognize messages
     # from the LDAP server. The default values will work for Fedora DS.
     #
     ldap.error.password.age=age
     ldap.error.password.expired=expired
     ldap.error.password.history=history
     ldap.error.password.not.changeable=not allowed to change
     ldap.error.password.syntax=syntax
     ldap.error.password.trivial=trivial
     ldap.error.user.lockout=retry limit

 ##
 ## CAS
 ##

     #
     # Set this to true to enable CAS single sign on. NTLM will work only if
     # LDAP authentication is also enabled and the authentication is made by
     # screen name. If set to true, then the property "auto.login.hooks" must
     # contain a reference to the class
     # com.liferay.portal.security.auth.CASAutoLogin and the filter
     # com.liferay.portal.servlet.filters.sso.cas.CASFilter must be referenced
     # in web.xml.
     #
     cas.auth.enabled=false

     #
     # A user may be authenticated from CAS and not yet exist in the portal. Set
     # this to true to automatically import users from LDAP if they do not exist
     # in the portal.
     #
     cas.import.from.ldap=false

     #
     # Set the default values for the required CAS URLs. Set either
     # "cas.server.name" or "cas.service.url". Setting "cas.server.name" allows
     # deep linking. See LEP-4423.
     #
     cas.login.url=https://localhost:8443/cas-web/login
     cas.logout.url=https://localhost:8443/cas-web/logout
     cas.server.name=localhost:8080
     cas.service.url=
     #cas.service.url=http://localhost:8080/c/portal/login
     cas.validate.url=https://localhost:8443/cas-web/proxyValidate

 ##
 ## NTLM
 ##

     #
     # Set this to true to enable NTLM single sign on. NTLM will work only if
     # LDAP authentication is also enabled and the authentication is made by
     # screen name. If set to true, then the property "auto.login.hooks" must
     # contain a reference to the class
     # com.liferay.portal.security.auth.NtlmAutoLogin and the filter
     # com.liferay.portal.servlet.filters.sso.ntlm.NtlmFilter must be referenced
     # in web.xml.
     #
     ntlm.auth.enabled=false
     ntlm.auth.domain.controller=127.0.0.1
     ntlm.auth.domain=EXAMPLE

 ##
 ## OpenID
 ##

     #
     # Set this to true to enable OpenId authentication. If set to true, then the
     # property "auto.login.hooks" must contain a reference to the class
     # com.liferay.portal.security.auth.OpenIdAutoLogin.
     #
     open.id.auth.enabled=true

 ##
 ## OpenSSO
 ##

     open.sso.auth.enabled=false
     open.sso.login.url=http://openssohost.example.com:8080/opensso/UI/Login?goto=http://portalhost.example.com:8080/c/portal/login
     open.sso.logout.url=http://openssohost.example.com:8080/opensso/UI/Logout?goto=http://portalhost.example.com:8080/web/guest/home
     open.sso.service.url=http://openssohost.example.com:8080/opensso
     open.sso.screen.name.attr=uid
     open.sso.email.address.attr=mail
     open.sso.first.name.attr=cn
     open.sso.last.name.attr=sn

 ##
 ## SiteMinder
 ##

     #
     # Set this to true to enable CA SiteMinder single sign on. If set to true,
     # then the property "auto.login.hooks" must contain a reference to the class
     # com.liferay.portal.security.auth.SiteMinderAutoLogin and the
     # "logout.events.post" must have a reference to
     # com.liferay.portal.events.SiteMinderLogoutAction for logout to work.
     #
     siteminder.auth.enabled=false

     #
     # A user may be authenticated from SiteMinder and not yet exist in the
     # portal. Set this to true to automatically import users from LDAP if they
     # do not exist in the portal.
     #
     siteminder.import.from.ldap=false

     #
     # Set this to the name of the user header that SiteMinder passes to the
     # portal.
     #
     siteminder.user.header=SM_USER

 ##
 ## Authentication Pipeline
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.security.auth.Authenticator. These classes will run
     # before or after the portal authentication begins.
     #
     # The Authenticator class defines the constant values that should be used
     # as return codes from the classes implementing the interface. If
     # authentication is successful, return SUCCESS; if the user exists but the
     # passwords do not match, return FAILURE; and if the user does not exist on
     # the system, return DNE.
     #
     # Constants in Authenticator:
     #     public static final int SUCCESS = 1;
     #     public static final int FAILURE = -1;
     #     public static final int DNE = 0;
     #
     # In case you have several classes in the authentication pipeline, all of
     # them have to return SUCCESS if you want the user to be able to login. If
     # one of the authenticators returns FAILURE or DNE, the login fails.
     #
     # Under certain circumstances, you might want to keep the information in the
     # portal database in sync with an external database or an LDAP server. This
     # can easily be achieved by implementing a class via LDAPAuth that updates
     # the information stored in the portal user database whenever a user signs
     # in.
     #
     # Each portal instance can be configured at run time to either authenticate
     # based on user ids or email addresses. See the Admin portlet for more
     # information.
     #
     # Available authenticators are:
     #     com.liferay.portal.security.auth.LDAPAuth
     #
     # See the LDAP properties to configure the behavior of the LDAPAuth class.
     #
     auth.pipeline.pre=com.liferay.portal.security.auth.LDAPAuth
     #auth.pipeline.post=

     #
     # Set this to true to enable password checking by the internal portal
     # authentication. If set to false, you're essentially delegating password
     # checking is delegated to the authenticators configured in
     # "auth.pipeline.pre" and "auth.pipeline.post" settings.
     #
     auth.pipeline.enable.liferay.check=true

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.security.auth.AuthFailure. These classes will run when
     # a user has a failed login or when a user has reached the maximum number of
     # failed logins.
     #
     auth.failure=com.liferay.portal.security.auth.LoginFailure
     auth.max.failures=com.liferay.portal.security.auth.LoginMaxFailures
     auth.max.failures.limit=5

     #
     # Set this to true if users are forwarded to the last visited path upon
     # successful login. If set to false, users will be forwarded to their
     # default layout page.
     #
     auth.forward.by.last.path=true

     #
     # The login page reads a redirect by a parameter named "redirect". If this
     # property is set to true, then users will be redirected to the given
     # redirect path upon successful login. If the user does not have permission
     # to view that page, then the rule set by the property
     # "auth.forward.by.last.path" will apply.
     #
     # You can set the redirect manually from another application, by appending
     # the "redirect" parameter in a url that looks like this:
     # /c/portal/login?redirect=%2Fgroup%2Femployees%2Fcalendar. This url will
     # redirect the user to the path "/group/employees/calendar" upon successful
     # login.
     #
     auth.forward.by.redirect=true

     #
     # Enter a list of comma delimited paths that can be considered part of the
     # last visited path.
     #
     auth.forward.last.paths=/document_library/get_file

     #
     # Enter a URL that will be used to login portal users whenever needed. By
     # default, the portal's login page is used.
     #
     #auth.login.url=/web/guest/home

     #
     # Enter a friendly URL of a page that will be used to login portal users
     # whenever the user is navigating a community and authentication is needed.
     # By default, the portal's login page or the URL set in the property
     # "auth.login.url" is used.
     #
     auth.login.community.url=/login

     #
     # Enter the name of the login portlet used in a page identified by the URL
     # of the previous property (if one has been set). This will allow the
     # portlet to have access to the redirect parameter and thus forward the user
     # to the page where he was trying to access when necessary. You should leave
     # the default value unless you have your own custom login portlet
     #
     auth.login.portlet.name=58

     #
     # Enter a list of comma delimited paths that do not require authentication.
     #
     auth.public.paths=         /blogs/find_entry,         /blogs/rss,         /blogs/trackback,                  /bookmarks/open_entry,                  /calendar/find_event,                  /document_library/get_file,                  /flags/edit_flag,                  /iframe/proxy,                  /journal/get_article,         /journal/get_articles,         /journal/get_latest_article_content,         /journal/get_structure,         /journal/get_template,         /journal/view_article_content,         /journal_articles/view_article_content,                  /layout_management/sitemap,                  /message_boards/find_category,         /message_boards/find_message,         /message_boards/find_thread,         /message_boards/get_message_attachment,         /message_boards/rss,                  /my_places/view,                  /polls/view_chart,                  /portal/ee/update_license,         /portal/emoticons,         /portal/expire_session,         /portal/extend_session,         /portal/extend_session_confirm,         /portal/json_service,         /portal/logout,         /portal/open_id_request,         /portal/open_id_response,         /portal/session_click,         /portal/session_tree_js_click,         /portal/status,                  /search/open_search,         /search/open_search_description.xml,                  /shopping/notify,                  /tags/rss,                  /wiki/find_page,         /wiki/get_page_attachment,         /wiki/rss

 ##
 ## Auto Login
 ##

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.security.auth.AutoLogin. These classes will run in
     # consecutive order for all unauthenticated users until one of them return a
     # valid user id and password combination. If no valid combination is
     # returned, then the request continues to process normally. If a valid
     # combination is returned, then the portal will automatically login that
     # user with the returned user id and password combination.
     #
     # For example, com.liferay.portal.security.auth.RememberMeAutoLogin reads
     # from a cookie to automatically log in a user who previously logged in
     # while checking on the "Remember Me" box.
     #
     # This interface allows deployers to easily configure the portal to work
     # with other SSO servers. See com.liferay.portal.security.auth.CASAutoLogin
     # for an example of how to configure the portal with Yale's SSO server.
     #
     auto.login.hooks=com.liferay.portal.security.auth.CASAutoLogin,com.liferay.portal.security.auth.NtlmAutoLogin,com.liferay.portal.security.auth.OpenIdAutoLogin,com.liferay.portal.security.auth.OpenSSOAutoLogin,com.liferay.portal.security.auth.RememberMeAutoLogin,com.liferay.portal.security.auth.SiteMinderAutoLogin

     #
     # Set the hosts that will be ignored for auto login.
     #
     auto.login.ignore.hosts=

     #
     # Set the paths that will be ignored for auto login.
     #
     auto.login.ignore.paths=

 ##
 ## SSO with MAC (Message Authentication Code)
 ##

     #
     # To use SSO with MAC, post to an URL like:
     #     http://localhost:8080/c/portal/login?cmd=already-registered&login=<userId|emailAddress>&password=<MAC>
     #
     # Pass the MAC in the password field. Make sure the MAC gets URL encoded
     # because it might contain characters not allowed in a URL.
     #
     # SSO with MAC also requires that you set the following property in
     # system.properties:
     #
     #     com.liferay.util.servlet.SessionParameters=false
     #
     # See the following links:
     #     http://issues.liferay.com/browse/LEP-1288
     #     http://en.wikipedia.org/wiki/Message_authentication_code
     #
     # Set this to true to enable SSO with MAC.
     #
     auth.mac.allow=false

     #
     # Set the algorithm to use for MAC encryption.
     #
     auth.mac.algorithm=MD5

     #
     # Set the shared key used to generate the MAC.
     #
     auth.mac.shared.key=

 ##
 ## Passwords
 ##

     #
     # Set the following encryption algorithm to encrypt passwords. The default
     # algorithm is SHA (SHA-1). If set to NONE, passwords are stored in the
     # database as plain text. The SHA-512 algorithm is currently unsupported.
     #
     #passwords.encryption.algorithm=CRYPT
     #passwords.encryption.algorithm=MD2
     #passwords.encryption.algorithm=MD5
     #passwords.encryption.algorithm=NONE
     passwords.encryption.algorithm=SHA
     #passwords.encryption.algorithm=SHA-256
     #passwords.encryption.algorithm=SHA-384
     #passwords.encryption.algorithm=SSHA

     #
     # Digested passwords are encoded via base64 or hex encoding. The default is
     # base64.
     #
     passwords.digest.encoding=base64
     #passwords.digest.encoding=hex

     #
     # Input a class name that extends
     # com.liferay.portal.security.pwd.BasicToolkit. This class will be called to
     # generate and validate passwords.
     #
     passwords.toolkit=com.liferay.portal.security.pwd.PasswordPolicyToolkit
     #passwords.toolkit=com.liferay.portal.security.pwd.RegExpToolkit

     #
     # If you choose to use com.liferay.portal.security.pwd.PasswordPolicyToolkit
     # as your password toolkit, you can choose either static or dynamic password
     # generation. Static is set through the property
     # "passwords.passwordpolicytoolkit.static" and dynamic uses the class
     # com.liferay.util.PwdGenerator to generate the password. If you are using
     # LDAP password syntax checking, you will also have to use the static
     # generator so that you can guarantee that passwords obey its rules.
     #
     #passwords.passwordpolicytoolkit.generator=static
     passwords.passwordpolicytoolkit.generator=dynamic
     passwords.passwordpolicytoolkit.static=iheartliferay

     #
     # If you choose to use com.liferay.portal.security.pwd.RegExpToolkit as
     # your password toolkit, set the regular expression pattern that will be
     # used to generate and validate passwords.
     #
     # Note that \ is replaced with \\ to work in Java.
     #
     # The first pattern ensures that passwords must have at least 4 valid
     # characters consisting of digits or letters.
     #
     # The second pattern ensures that passwords must have at least 8 valid
     # characters consisting of digits or letters.
     #
     passwords.regexptoolkit.pattern=(?=.{4})(?:[a-zA-Z0-9]*)
     #passwords.regexptoolkit.pattern=(?=.{8})(?:[a-zA-Z0-9]*)

     #
     # Set the length and key for generating passwords.
     #
     #passwords.regexptoolkit.charset=0123456789
     passwords.regexptoolkit.charset=0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
     #passwords.regexptoolkit.length=4
     passwords.regexptoolkit.length=8

     #
     # Set the name of the default password policy.
     #
     passwords.default.policy.name=Default Password Policy

 ##
 ## Permissions
 ##

     #
     # Set the default permission checker class used by
     # com.liferay.portal.security.permission.PermissionCheckerFactory to check
     # permissions for actions on objects. This class can be overrided with a
     # custom class that implements
     # com.liferay.portal.security.permission.PermissionChecker.
     #
     #permissions.checker=com.liferay.portal.security.permission.SimplePermissionChecker
     permissions.checker=com.liferay.portal.security.permission.AdvancedPermissionChecker

     #
     # Set the algorithm used to check permissions for a user. This is useful so
     # that you can optimize the search for different databases. See
     # com.liferay.portal.service.impl.PermissionLocalServiceImpl.
     #
     # Algoriths 1 through 4 are essentially the same but make calls in different
     # orders depending on how the database is optimized and how the portal
     # permissions are used. Algorithm 5 is is the recommended algorithm because
     # it is the fastest and relies on only role assignments. Algorithm 6 is like
     # Algorithm 5, except that it uses bitwise operations for even faster speed.
     #
     # Algorithm 6 is currently experimental, but will be the new recommended
     # algorithm in a future release.
     #
     #permissions.user.check.algorithm=1
     #permissions.user.check.algorithm=2
     #permissions.user.check.algorithm=3
     #permissions.user.check.algorithm=4
     permissions.user.check.algorithm=5
     #permissions.user.check.algorithm=6

     #
     # Set the default permissions list filter class. This class must implement
     # com.liferay.portal.kernel.security.permission.PermissionsListFilter. This
     # is used if you want to filter the list of permissions before it is
     # actually persisted. For example, if you want to make sure that all users
     # who create objects never have the UPDATE action, then you can filter that
     # list and remove any permissions that have the UPDATE action before it is
     # persisted.
     #
     permissions.list.filter=com.liferay.portal.security.permission.PermissionsListFilterImpl

     #
     # The permissions cache uses a thread local map to store the most frequently
     # accessed items to lower the number of queries to the underlying cache. Set
     # the maximum map size to 0 to disable the thread level cache.
     #
     permissions.thread.local.cache.max.size=100

 ##
 ## Captcha
 ##

     #
     # Set the maximum number of captcha checks per portlet session. Set this
     # value to 0 to always check. Set this value to a number less than 0 to
     # never check. Unauthenticated users will always be checked on every request
     # if captcha checks is enabled.
     #
     captcha.max.challenges=1

     #
     # Set whether or not to use captcha checks for the following actions.
     #
     captcha.check.portal.create_account=true
     captcha.check.portal.send_password=true
     captcha.check.portlet.message_boards.edit_category=false
     captcha.check.portlet.message_boards.edit_message=false

 ##
 ## Startup Events
 ##

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.portal.struts.SimpleAction. These classes will run at the
     # specified event.
     #

     #
     # Global startup event that runs once when the portal initializes.
     #
     global.startup.events=com.liferay.portal.events.GlobalStartupAction

     #
     # Application startup event that runs once for every web site instance of
     # the portal that initializes.
     #
     application.startup.events=com.liferay.portal.events.AppStartupAction
     #application.startup.events=com.liferay.portal.events.AppStartupAction,com.liferay.portal.events.SampleAppStartupAction

 ##
 ## Shutdown Events
 ##

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.portal.struts.SimpleAction. These classes will run at the
     # specified event.
     #

     #
     # Global shutdown event that runs once when the portal shuts down.
     #
     global.shutdown.events=com.liferay.portal.events.GlobalShutdownAction

     #
     # Application shutdown event that runs once for every web site instance of
     # the portal that shuts down.
     #
     application.shutdown.events=com.liferay.portal.events.AppShutdownAction

     #
     # Programmatically kill the Java process on shutdown. This is a workaround
     # for a bug in Tomcat and Linux where the process hangs on forever.
     #
     # See http://issues.liferay.com/browse/LEP-2048 for more information.
     #
     shutdown.programmatically.exit=false

 ##
 ## Portal Events
 ##

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.portal.kernel.events.Action. These classes will run before or
     # after the specified event.
     #

     #
     # Servlet service event (The pre-service events have an associated error
     # page and will forward to that page if an exception is thrown during
     # excecution of the events. The pre-service events process before Struts
     # processes the request. The post-service events process after Struts
     # processes the request.
     #
     servlet.service.events.pre=com.liferay.portal.events.ServicePreAction
     #servlet.service.events.pre=com.liferay.portal.events.LogMemoryUsageAction,com.liferay.portal.events.LogThreadCountAction,com.liferay.portal.events.ServicePreAction
     #servlet.service.events.pre=com.liferay.portal.events.LogSessionIdAction,com.liferay.portal.events.ServicePreAction
     #servlet.service.events.pre=com.liferay.portal.events.ServicePreAction,com.liferay.portal.events.RandomLayoutAction
     #servlet.service.events.pre=com.liferay.portal.events.ServicePreAction,com.liferay.portal.events.RandomLookAndFeelAction
     #servlet.service.events.pre=com.liferay.portal.events.ServicePreAction,com.liferay.portal.events.SecureRequestAction
     servlet.service.events.pre.error.page=/common/error.jsp
     servlet.service.events.post=com.liferay.portal.events.ServicePostAction

     #
     # Login event
     #
     login.events.pre=com.liferay.portal.events.LoginPreAction
     login.events.post=com.liferay.portal.events.LoginPostAction,com.liferay.portal.events.DefaultLandingPageAction

     #
     # Logout event
     #
     logout.events.pre=com.liferay.portal.events.LogoutPreAction
     logout.events.post=com.liferay.portal.events.LogoutPostAction,com.liferay.portal.events.DefaultLogoutPageAction,com.liferay.portal.events.SiteMinderLogoutAction
     #logout.events.post=com.liferay.portal.events.LogoutPostAction,com.liferay.portal.events.GarbageCollectorAction

 ##
 ## Default Landing Page
 ##

     #
     # Set the default landing page path for logged in users relative to the
     # server path. This is the page users are automatically redirected to after
     # logging in. For example, if you want the default landing page to be
     # http://localhost:8080/web/guest/login, set this to /web/guest/login. To
     # activate this feature, set auth.forward.by.last.path to true. To customize
     # the behavior, see com.liferay.portal.events.DefaultLandingPageAction in
     # the "login.events.post" property above.
     #
     #default.landing.page.path=/web/guest/login

 ##
 ## Default Logout Page
 ##

     #
     # Set the default logout page path for users relative to the server path.
     # This is the page users are automatically redirected to after logging out.
     # For example, if you want the default logout page to be
     # http://localhost:8080/web/guest/logout, set this to /web/guest/logout. To
     # activate this feature, set auth.forward.by.last.path to true. To customize
     # the behavior, see com.liferay.portal.events.DefaultLogoutPageAction in
     # the "logout.events.post" property above.
     #
     #default.logout.page.path=/web/guest/logout

 ##
 ## Default Guest Public Layouts
 ##

     #
     # The Guest group must have at least one public page. The settings for the
     # initial public page are specified in the following properties.
     #
     # If you need to add more than one page, set the property
     # "default.guest.public.layouts.lar" to specifiy a LAR file instead.
     #
     # For even more complex behavior, override the addDefaultGuestPublicLayouts
     # method in com.liferay.portal.service.impl.GroupLocalServiceImpl.
     #

     #
     # Set the name of the public layout.
     #
     default.guest.public.layout.name=Welcome

     #
     # Set the layout template id of the public layout.
     #
     default.guest.public.layout.template.id=2_columns_ii

     #
     # Set the portlet ids for the columns specified in the layout template.
     #
     default.guest.public.layout.column-1=58
     default.guest.public.layout.column-2=47
     default.guest.public.layout.column-3=
     default.guest.public.layout.column-4=

     #
     # Set the friendly url of the public layout.
     #
     default.guest.public.layout.friendly.url=/home

     #
     # Set the regular theme id for the public layout.
     #
     #default.guest.public.layout.regular.theme.id=classic

     #
     # Set the regular color scheme id for the public layout.
     #
     #default.guest.public.layout.regular.color.scheme.id=01

     #
     # Set the wap theme id for the public layout.
     #
     #default.guest.public.layout.wap.theme.id=mobile

     #
     # Set the wap color scheme for the public layout.
     #
     #default.guest.public.layout.wap.color.scheme.id=01

     #
     # Specify a LAR file that can be used to create the guest public layouts.
     # If this property is set, the previous layout properties will be ignored.
     #
     #default.guest.public.layouts.lar=${liferay.home}/deploy/default_guest_public.lar

 ##
 ## Default User Private Layouts
 ##

     #
     # If the properties "layout.user.private.layouts.enabled" and
     # "layout.user.private.layouts.auto.create" are both set to true, then users
     # will have private layouts and they will be automatically created. The
     # settings below are used for the creation of for the initial private pages.
     #
     # If you need to add more than one page, set the property
     # "default.user.private.layouts.lar" to specifiy a LAR file instead.
     #
     # For even more complex behavior, override the addDefaultUserPrivateLayouts
     # method in com.liferay.portal.events.ServicePreAction.
     #

     #
     # Set the name of the private layout.
     #
     default.user.private.layout.name=Welcome

     #
     # Set the layout template id of the private layout.
     #
     default.user.private.layout.template.id=2_columns_ii

     #
     # Set the portlet ids for the columns specified in the layout template.
     #
     default.user.private.layout.column-1=71_INSTANCE_OY0d,82,23,61
     default.user.private.layout.column-2=11,29,8,19
     default.user.private.layout.column-3=
     default.user.private.layout.column-4=

     #
     # Set the friendly url of the private layout.
     #
     default.user.private.layout.friendly.url=/home

     #
     # Set the regular theme id for the private layout.
     #
     #default.user.private.layout.regular.theme.id=classic

     #
     # Set the regular color scheme id for the private layout.
     #
     #default.user.private.layout.regular.color.scheme.id=01

     #
     # Set the wap theme id for the private layout.
     #
     #default.user.private.layout.wap.theme.id=mobile

     #
     # Set the wap color scheme for the private layout.
     #
     #default.user.private.layout.wap.color.scheme.id=01

     #
     # Specify a LAR file that can be used to create the user private layouts. If
     # this property is set, the previous layout properties will be ignored.
     #
     #default.user.private.layouts.lar=${liferay.home}/deploy/default_user_private.lar

 ##
 ## Default User Public Layouts
 ##

     #
     # If the properties "layout.user.public.layouts.enabled" and
     # "layout.user.public.layouts.auto.create" are both set to true, then users
     # will have public layouts and they will be automatically created. The
     # settings below are used for the creation of for the initial public pages.
     #
     # If you need to add more than one page, set the property
     # "default.user.public.layouts.lar" to specifiy a LAR file instead.
     #
     # For even more complex behavior, override the addDefaultUserPublicLayouts
     # method in com.liferay.portal.events.ServicePreAction.
     #

     #
     # Set the name of the public layout.
     #
     default.user.public.layout.name=Welcome

     #
     # Set the layout template id of the public layout.
     #
     default.user.public.layout.template.id=2_columns_ii

     #
     # Set the portlet ids for the columns specified in the layout template.
     #
     default.user.public.layout.column-1=82,23
     default.user.public.layout.column-2=8,19
     default.user.public.layout.column-3=
     default.user.public.layout.column-4=

     #
     # Set the friendly url of the public layout.
     #
     default.user.public.layout.friendly.url=/home

     #
     # Set the regular theme id for the public layout.
     #
     #default.user.public.layout.regular.theme.id=classic

     #
     # Set the regular color scheme id for the public layout.
     #
     #default.user.public.layout.regular.color.scheme.id=01

     #
     # Set the wap theme id for the public layout.
     #
     #default.user.public.layout.wap.theme.id=mobile

     #
     # Set the wap color scheme for the public layout.
     #
     #default.user.public.layout.wap.color.scheme.id=01

     #
     # Specify a LAR file that can be used to create the user public layouts. If
     # this property is set, the previous layout properties will be ignored.
     #
     #default.user.public.layouts.lar=${liferay.home}/deploy/default_user_public.lar

 ##
 ## Default Admin
 ##

     #
     # Set the default admin password.
     #
     default.admin.password=test

     #
     # Set the default admin screen name prefix.
     #
     default.admin.screen.name=test

     #
     # Set the default admin email address prefix.
     #
     default.admin.email.address.prefix=test

     #
     # Set the default admin first name.
     #
     default.admin.first.name=Test

     #
     # Set the default admin middle name.
     #
     default.admin.middle.name=

     #
     # Set the default admin last name.
     #
     default.admin.last.name=Test

 ##
 ## Layouts
 ##

     #
     # Set the list of layout types. The display text of each of the layout types
     # is set in content/Language.properties and prefixed with "layout.types.".
     #
     # You can create new layout types and specify custom settings for each
     # layout type. End users input dynamic values as designed in the edit page.
     # End users see the layout as designed in the view page. The generated
     # URL can reference properties set in the edit page. Parentable layouts
     # can contain child layouts. You can also specify a comma delimited list of
     # configuration actions that will be called for your layout when it is
     # updated or deleted.
     #
     layout.types=portlet,panel,embedded,article,url,link_to_layout

     #
     # Set whether or not private layouts are enabled. Set whether or not private
     # layouts are modifiable. Set whether or not private layouts should be auto
     # created if a user has no private layouts. If private layouts are not
     # enabled, the other two properties are assumed to be false.
     #
     layout.user.private.layouts.enabled=true
     layout.user.private.layouts.modifiable=true
     layout.user.private.layouts.auto.create=true

     #
     # Set this to true if users must have the Power User role to have private
     # pages.
     #
     layout.user.private.layouts.power.user.required=false

     #
     # Set whether or not public layouts are enabled. Set whether or not public
     # layouts are modifiable. Set whether or not public layouts should be auto
     # created if a user has no public layouts. If public layouts are not
     # enabled, the other two properties are assumed to be false.
     #
     layout.user.public.layouts.enabled=true
     layout.user.public.layouts.modifiable=true
     layout.user.public.layouts.auto.create=true

     #
     # Set this to true if users must have the Power User role to have public
     # pages.
     #
     layout.user.public.layouts.power.user.required=false

     #
     # Default settings layouts.
     #
     layout.edit.page=/portal/layout/edit/portlet.jsp
     layout.view.page=/portal/layout/view/portlet.jsp
     layout.url=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     layout.url.friendliable=true
     layout.parentable=true
     layout.sitemapable=true
     layout.first.pageable=true
     #layout.configuration.action.update=
     #layout.configuration.action.delete=

     #
     # Settings for portlet layouts are inherited from the default settings.
     #
     #layout.edit.page[portlet]=/portal/layout/edit/portlet.jsp
     #layout.view.page[portlet]=/portal/layout/view/portlet.jsp
     #layout.url[portlet]=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     #layout.url.friendliable[portlet]=true
     #layout.parentable[portlet]=true
     #layout.configuration.action.update[portlet]=
     #layout.configuration.action.delete[portlet]=

     #
     # Settings for panel layouts.
     #
     layout.edit.page[panel]=/portal/layout/edit/panel.jsp
     layout.view.page[panel]=/portal/layout/view/panel.jsp
     layout.url[panel]=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     layout.url.friendliable[panel]=true
     layout.parentable[panel]=true
     layout.first.pageable[panel]=true

     #
     # Settings for control_panel layouts.
     #
     layout.edit.page[control_panel]=/portal/layout/edit/control_panel.jsp
     layout.view.page[control_panel]=/portal/layout/view/control_panel.jsp
     layout.url[control_panel]=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     layout.url.friendliable[control_panel]=true
     layout.parentable[control_panel]=true
     layout.first.pageable[control_panel]=true

     #
     # Settings for embedded layouts.
     #
     layout.edit.page[embedded]=/portal/layout/edit/embedded.jsp
     layout.view.page[embedded]=/portal/layout/view/embedded.jsp
     layout.url[embedded]=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     layout.url.friendliable[embedded]=true
     layout.parentable[embedded]=false
     layout.sitemapable[embedded]=true
     layout.first.pageable[embedded]=true
     #layout.configuration.action.update[embedded]=
     #layout.configuration.action.delete[embedded]=

     #
     # Settings for article layouts.
     #
     layout.edit.page[article]=/portal/layout/edit/article.jsp
     layout.view.page[article]=/portal/layout/view/article.jsp
     layout.url.friendliable[article]=true
     layout.url[article]=${liferay:mainPath}/portal/layout?p_l_id=${liferay:plid}
     layout.parentable[article]=false
     layout.sitemapable[article]=true
     layout.first.pageable[article]=true
     layout.configuration.action.update[article]=com.liferay.portal.model.LayoutTypeArticleConfigurationUpdateAction
     layout.configuration.action.delete[article]=com.liferay.portal.model.LayoutTypeArticleConfigurationDeleteAction

     #
     # Settings for URL layouts.
     #
     layout.edit.page[url]=/portal/layout/edit/url.jsp
     layout.view.page[url]=
     layout.url[url]=${url}
     layout.url.friendliable[url]=true
     layout.parentable[url]=false
     layout.sitemapable[url]=false
     layout.first.pageable[url]=false
     #layout.configuration.action.update[url]=
     #layout.configuration.action.delete[url]=

     #
     # Settings for page layouts.
     #
     layout.edit.page[link_to_layout]=/portal/layout/edit/link_to_layout.jsp
     layout.view.page[link_to_layout]=
     layout.url[link_to_layout]=${liferay:mainPath}/portal/layout?groupId=${liferay:groupId}&privateLayout=${privateLayout}&layoutId=${linkToLayoutId}
     layout.url.friendliable[link_to_layout]=true
     layout.parentable[link_to_layout]=true
     layout.sitemapable[link_to_layout]=false
     layout.first.pageable[link_to_layout]=false
     #layout.configuration.action.update[link_to_layout]=
     #layout.configuration.action.delete[link_to_layout]=

     #
     # Specify static portlets that cannot be moved and will always appear on
     # every layout. Static portlets will take precedence over portlets that may
     # have been dynamically configured for the layout.
     #
     # For example, if you want the Hello World portlet to always appear at the
     # start of the iteration of the first column for user layouts, set the
     # property "layout.static.portlets.start.column-1[user]" to "47". If you
     # want the Hello World portlet to always appear at the end of the second
     # column for user layouts, set the property
     # "layout.static.portlets.end.column-2[user]" to "47". You can input a
     # list of comma delimited portlet ids to specify more than one portlet. If
     # the portlet is instanceable, add the suffix "_INSTANCE_abcd" to the
     # portlet id, where "abcd" is any random alphanumeric string.
     #
     # The static portlets are fetched based on the properties controlled by
     # custom filters using EasyConf. By default, the available filters are
     # user, community, and organization.
     #
     #layout.static.portlets.start.column-1[user]=3,6
     #layout.static.portlets.end.column-1[user]=14
     #layout.static.portlets.start.column-2[user]=71_INSTANCE_abcd,7
     #layout.static.portlets.end.column-2[user]=34,70
     #layout.static.portlets.start.column-3[user]=
     #layout.static.portlets.end.column-3[user]=

     #
     # It is also possible to set static portlets based on the layout's friendly
     # URL.
     #
     #layout.static.portlets.start.column-1[user][/home]=3,6
     #layout.static.portlets.end.column-2[community][/home]=14

     #
     # Set the static portlets for community layouts.
     #
     #layout.static.portlets.start.column-1[community]=
     #layout.static.portlets.end.column-1[community]=
     #layout.static.portlets.start.column-2[community]=
     #layout.static.portlets.end.column-2[community]=
     #layout.static.portlets.start.column-3[community]=
     #layout.static.portlets.end.column-3[community]=

     #
     # Set the static portlets for organization layouts.
     #
     #layout.static.portlets.start.column-1[organization]=
     #layout.static.portlets.end.column-1[organization]=
     #layout.static.portlets.start.column-2[organization]=
     #layout.static.portlets.end.column-2[organization]=
     #layout.static.portlets.start.column-3[organization]=
     #layout.static.portlets.end.column-3[organization]=

     #
     # Set the static portlets that will appear for every layout. See
     # /html/portal/layout/view/portlet.jsp for the logic of when these portlets
     # will be shown. For example, these portlets will only show for layouts that
     # can contain portlets and are not in a pop up state.
     #
     layout.static.portlets.all=1_WAR_chatportlet

     #
     # Set the private group, private user, and public servlet mapping for
     # com.liferay.portal.servlet.FriendlyURLServlet. This value must match the
     # servlet mapping set in web.xml.
     #
     # For example, if the private group pages are mapped to "/group" and the
     # group's friendly URL is set to "/guest" and the layout's friendly URL is
     # set to "/company/community", then the friendly URL for the page will be
     # http://www.liferay.com/group/guest/company/community. Private group pages
     # map to a community's private pages and are only available to authenticated
     # users with the proper permissions.
     #
     # For example, if the public pages are mapped to "/web" and the group or
     # user's friendly URL is set to "/guest" and the layout's friendly URL is
     # set to "/company/community", then the friendly URL for the page will be
     # http://www.liferay.com/web/guest/company/community. Public pages are
     # available to unauthenticated users.
     #
     # The friendly URL's for users, groups, and layouts can be set during
     # runtime.
     #
     layout.friendly.url.private.group.servlet.mapping=/group
     layout.friendly.url.private.user.servlet.mapping=/user
     layout.friendly.url.public.servlet.mapping=/web

     #
     # Redirect to this resource if the user requested a friendly URL that does
     # not exist. Leave it blank to display nothing.
     #
     # Note: For backward compatibility, this overrides the property
     # "layout.show.http.status" for the 404 status code.
     #
     #layout.friendly.url.page.not.found=/html/portal/404.html

     #
     # Set the reserved keywords that cannot be used in a friendly URL.
     #
     layout.friendly.url.keywords=c,group,web,image,wsrp,page,public,private,rss,tags

     #
     # Set this to true if guest users should see the maximize window icon.
     #
     layout.guest.show.max.icon=false

     #
     # Set this to true if guest users should see the minimize window icon.
     #
     layout.guest.show.min.icon=false

     #
     # Set this to true if users are shown that they do not have access to a
     # portlet. The portlet init parameter "show-portlet-access-denied" will
     # override this setting.
     #
     layout.show.portlet.access.denied=true

     #
     # Set this to true if users are shown that a portlet is inactive. The
     # portlet init parameter "show-portlet-inactive" will override this setting.
     #
     layout.show.portlet.inactive=true

     #
     # Set this to true if the portal should show HTTP status codes like 404 if
     # the requested page is not found.
     #
     layout.show.http.status=true

     #
     # Set the default layout template id used when creating layouts.
     #
     layout.default.template.id=2_columns_ii

     #
     # Set this to false to disable parallel rendering. You can also disable it
     # on a per request basis by setting the attribute key
     # com.liferay.portal.util.WebKeys.PORTLET_PARALLEL_RENDER to the
     # Boolean.FALSE in a pre service event or by setting the URL parameter
     # "p_p_parallel" to "0".
     #
     layout.parallel.render.enable=true

     #
     # Set the name of a class that implements
     # com.liferay.portal.util.LayoutClone. This class is used to remember
     # maximized and minimized states on shared pages. The default implementation
     # persists the state in the browser session.
     #
     layout.clone.impl=com.liferay.portal.util.SessionLayoutClone

     #
     # Set this to true to cache the content of layout templates. This is
     # recommended because it improves performance for production servers.
     # Setting it to false is useful during development if you need to make a lot
     # of changes.
     #
     layout.template.cache.enabled=true

     #
     # Set the default value for the "p_l_reset" parameter. If set to true, then
     # render parameters are cleared when different pages are hit. This is not
     # the behavior promoted by the portlet specification, but is the one that
     # most end users seem to prefer.
     #
     layout.default.p_l_reset=true

     #
     # Set this to true to enable comments for pages.
     #
     layout.comments.enabled=true

 ##
 ## Portlet URL
 ##

     #
     # Set this to true if calling setParameter on a portlet URL appends the
     # parameter value versus replacing it. There is some disagreement in the
     # interpretation of the JSR 168 spec among portlet developers over this
     # specific behavior. Liferay Portal successfully passes the portlet TCK
     # tests whether this value is set to true or false.
     #
     # See http://issues.liferay.com/browse/LEP-426 for more information.
     #
     portlet.url.append.parameters=false

     #
     # Set this to true to allow portlet URLs to generate with an anchor tag.
     #
     portlet.url.anchor.enable=false

     #
     # JSR 286 specifies that portlet URLs are escaped by default. Set this to
     # false to provide for better backwards compatibility.
     #
     # If this is set to true, but a specific portlet application requires that
     # its portlet URLs not be escaped by default, then modify portlet.xml and
     # set the container runtime option "javax.portlet.escapeXml" to false.
     #
     portlet.url.escape.xml=false

 ##
 ## Preferences
 ##

     #
     # Set this to true to validate portlet preferences on startup.
     #
     preference.validate.on.startup=false

 ##
 ## Referer
 ##

     #
     # Set this property to "ip" or "domain" for the referer security method. If
     # set to "domain", the portal will only redirect users to domains listed in
     # the property "referer.url.domain.allowed". If set to "ip", the portal will
     # only redirect to domains whose IP address resolve to an IP address listed
     # in the property "referer.url.ip.allowed".
     #
     #referer.url.security.mode=domain
     referer.url.security.mode=ip

     #
     # Input a list of comma delimited domains which the portal is allowed to
     # redirect to. Input a blank list to allow any domain.
     #
     referer.url.domains.allowed=

     #
     # Input a list of comma delimited IPs which the portal is allowed to
     # redirect to. Input a blank list to allow any IP. SERVER_IP will be
     # replaced with the IP of the host server.
     #
     referer.url.ips.allowed=127.0.0.1,SERVER_IP

 ##
 ## Struts
 ##

     #
     # Input the custom Struts request processor that will be used by Struts
     # based portlets. The custom class must extend
     # com.liferay.portal.struts.PortletRequestProcessor and have the same
     # constructor.
     #
     struts.portlet.request.processor=com.liferay.portal.struts.PortletRequestProcessor

 ##
 ## Images
 ##

     #
     # Set the location of the default spacer image that is used for missing
     # images. This image must be available in the class path.
     #
     image.default.spacer=com/liferay/portal/dependencies/spacer.gif

     #
     # Set the location of the default company logo image that is used for
     # missing company logo images. This image must be available in the class
     # path.
     #
     image.default.company.logo=com/liferay/portal/dependencies/company_logo.png

     #
     # Set the location of the default organization logo image that is used for
     # missing organization logo images. This image must be available in the
     # class path.
     #
     image.default.organization.logo=com/liferay/portal/dependencies/organization_logo.png

     #
     # Set the locations of the default user portrait images that are used for
     # missing user portrait images. This image must be available in the class
     # path.
     #
     image.default.user.female.portrait=com/liferay/portal/dependencies/user_female_portrait.png
     image.default.user.male.portrait=com/liferay/portal/dependencies/user_male_portrait.png

     #
     # Set the name of a class that implements com.liferay.portal.image.Hook. The
     # portal will use this persist images.
     #
     # Available hooks are:
     #     com.liferay.portal.image.DatabaseHook
     #     com.liferay.portal.image.DLHook
     #     com.liferay.portal.image.FileSystemHook
     #
     image.hook.impl=com.liferay.portal.image.DatabaseHook
     #image.hook.impl=com.liferay.portal.image.DLHook
     #image.hook.impl=com.liferay.portal.image.FileSystemHook

     #
     # FileSystemHook
     #
     image.hook.file.system.root.dir=${liferay.home}/data/images

 ##
 ## Editors
 ##

     #
     # You can configure individual JSP pages to use a specific implementation of
     # the available WYSIWYG editors: liferay, fckeditor, simple, tinymce,
     # or tinymcesimple.
     #
     editor.wysiwyg.default=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.blogs.edit_entry.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.calendar.edit_configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.enterprise_admin.view.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.invitation.edit_configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_article_content.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_article_content_xsd_el.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.login.configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.mail.edit.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.mail.edit_message.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.message_boards.edit_configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.shopping.edit_configuration.jsp=fckeditor
     editor.wysiwyg.portal-web.docroot.html.portlet.wiki.edit.html.jsp=fckeditor

 ##
 ## Fields
 ##

     #
     # Set the following fields to false so users cannot see them. Some company
     # policies require gender and birthday information to always be hidden.
     #
     field.enable.com.liferay.portal.model.Contact.male=true
     field.enable.com.liferay.portal.model.Contact.birthday=true
     field.enable.com.liferay.portal.model.Organization.status=false

 ##
 ## Mime Types
 ##

     #
     # Input a list of comma delimited mime types that are not available by
     # default from javax.activation.MimetypesFileTypeMap.
     #
     mime.types=         application/msword doc,         application/pdf pdf,         application/vnd.ms-excel xls,         application/vnd.ms-powerpoint ppt,         application/x-ms-wmp wmv,         application/x-shockwave-flash swf flv

     #
     # Input a list of comma delimited extensions for which the content
     # disposition header has to be set to "inline".
     #
     mime.types.content.disposition.inline=flv,pdf,swf,wmv

 ##
 ## Amazon
 ##

     #
     # Enter an Amazon access key ID and an Amazon associate tag. This is made
     # available only for personal use. Please see the Amazons license at
     # http://www.amazon.com for more information.
     #
     #amazon.access.key.id=
     #amazon.associate.tag=

 ##
 ## Browser Launcher
 ##

     #
     # Enter a URL to automatically launch a browser to that URL when the portal
     # has fully initialized. Enter a blank URL to disable this feature.
     #
     browser.launcher.url=http://localhost:8080

 ##
 ## Control Panel
 ##

     #
     # Set the name of the layout.
     #
     control.panel.layout.name=Control Panel

     #
     # Set the friendly URL of the layout.
     #
     control.panel.layout.friendly.url=/manage

     #
     # Set the theme of the layout.
     #
     control.panel.layout.regular.theme.id=controlpanel

     #
     # Set the maximum number of communities that will be shown in the navigation
     # menus. A large value might cause performance problems if the number of
     # communities that the user can administrate is very large.
     #
     control.panel.navigation.max.communities=50

     #
     # Set the maximum number of organizations that will be shown in the
     # navigation menus. A large value might cause performance problems if the
     # number of organizations that the user can administrate is very large.
     #
     control.panel.navigation.max.organizations=50

 ##
 ## Instant Messenger
 ##

     #
     # Set the AIM login and password by which the system will use AIM to
     # communicate with users.
     #
     aim.login=
     aim.password=

     #
     # Due to a bug in JOscarLib 0.3b1, you must set the full path to the ICQ
     # jar.
     #
     # See the following posts:
     #     http://sourceforge.net/forum/message.php?msg_id=1972697
     #     http://sourceforge.net/forum/message.php?msg_id=1990487
     #
     icq.jar=C:/Java/orion-2.0.7/lib/icq.jar

     #
     # Set the ICQ login and password by which the system will use ICQ to
     # communicate with users.
     #
     icq.login=
     icq.password=

     #
     # Set the MSN login and password by which the system will use MSN to
     # communicate with users.
     #
     msn.login=
     msn.password=

     #
     # Set the YM login and password by which the system will use YM to
     # communicate with users.
     #
     ym.login=
     ym.password=

 ##
 ## Lucene Search
 ##

     #
     # Set this to true if you want to avoid any writes to the index. This is
     # useful in some clustering environments where there is a shared index and
     # only one node of the cluster updates it.
     #
     index.read.only=false

     #
     # Set this to true if you want to index your entire library of files on
     # startup. This property is available so that automated test environments
     # index on startup. Do not set this to true on production systems or else
     # your index will be indexed on every startup.
     #
     index.on.startup=false

     #
     # Set this to true to add a delay before indexing on startup. A delay may be
     # necessary if a lot of plugins need to be loaded and reindexed. This
     # property is only valid if "index.on.startup" is set to true.
     #
     index.on.startup.delay=60

     #
     # Set this to true if you want the indexing on startup to be executed on a
     # separate thread to speed up execution.
     #
     index.with.thread=true

     #
     # Designate whether Lucene stores indexes in a database via JDBC, file
     # system, or in RAM.
     #
     #lucene.store.type=jdbc
     lucene.store.type=file
     #lucene.store.type=ram

     #
     # Lucene's storage of indexes via JDBC has a bug where temp files are not
     # removed. This can eat up disk space over time. Set this to true to
     # automatically clean up the temporary files once a day. See LEP-2180.
     #
     #lucene.store.jdbc.auto.clean.up=true

     #
     # Set the JDBC dialect that Lucene uses to store indexes in the database.
     # This is only referenced if Lucene stores indexes in the database. Liferay
     # will attempt to load the proper dialect based on the URL of the JDBC
     # connection. For example, the property "lucene.store.jdbc.dialect.mysql" is
     # read for the JDBC connection URL "jdbc:mysql://localhost/lportal".
     #
     lucene.store.jdbc.dialect.db2=org.apache.lucene.store.jdbc.dialect.DB2Dialect
     lucene.store.jdbc.dialect.derby=org.apache.lucene.store.jdbc.dialect.DerbyDialect
     lucene.store.jdbc.dialect.hsqldb=org.apache.lucene.store.jdbc.dialect.HSQLDialect
     lucene.store.jdbc.dialect.jtds=org.apache.lucene.store.jdbc.dialect.SQLServerDialect
     lucene.store.jdbc.dialect.microsoft=org.apache.lucene.store.jdbc.dialect.SQLServerDialect
     lucene.store.jdbc.dialect.mysql=org.apache.lucene.store.jdbc.dialect.MySQLDialect
     #lucene.store.jdbc.dialect.mysql=org.apache.lucene.store.jdbc.dialect.MySQLInnoDBDialect
     #lucene.store.jdbc.dialect.mysql=org.apache.lucene.store.jdbc.dialect.MySQLMyISAMDialect
     lucene.store.jdbc.dialect.oracle=org.apache.lucene.store.jdbc.dialect.OracleDialect
     lucene.store.jdbc.dialect.postgresql=org.apache.lucene.store.jdbc.dialect.PostgreSQLDialect

     #
     # Set the directory where Lucene indexes are stored. This is only referenced
     # if Lucene stores indexes in the file system.
     #
     lucene.dir=${liferay.home}/data/lucene/

     #
     # Input a class name that extends
     # com.liferay.portal.search.lucene.LuceneFileExtractor. This class is called
     # by Lucene to extract text from complex files so that they can be properly
     # indexed.
     #
     lucene.file.extractor=com.liferay.portal.search.lucene.LuceneFileExtractor

     #
     # The file extractor can sometimes return text that is not valid for Lucene.
     # This property expects a regular expression. Any character that does not
     # matche the regular expression will be replaced with a blank space. Set an
     # empty regular expression to disable this feature.
     #
     lucene.file.extractor.regexp.strip=
     #lucene.file.extractor.regexp.strip=[\\d\\w]

     #
     # Set the default analyzer used for indexing and retrieval.
     #
     #lucene.analyzer=org.apache.lucene.analysis.br.BrazilianAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.cn.ChineseAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.cjk.CJKAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.cz.CzechAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.nl.DutchAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.fr.FrenchAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.de.GermanAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.KeywordAnalyzer
     #lucene.analyzer=org.apache.lucene.index.memory.PatternAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.PerFieldAnalyzerWrapper
     #lucene.analyzer=org.apache.lucene.analysis.ru.RussianAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.SimpleAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.snowball.SnowballAnalyzer
     lucene.analyzer=org.apache.lucene.analysis.standard.StandardAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.StopAnalyzer
     #lucene.analyzer=org.apache.lucene.analysis.WhitespaceAnalyzer

     #
     # Set Lucene's merge factor. Higher numbers mean indexing goes faster but
     # uses more memory. The default value from Lucene is 10. This should never
     # be set to a number lower than 2.
     #
     lucene.merge.factor=10

     #
     # Set how often to run Lucene's optimize method. Optimization speeds up
     # searching but slows down writing. Set this property to 0 to always
     # optimize. Set this property to an integer greater than 0 to optimize every
     # X writes.
     #
     lucene.optimize.interval=100

 ##
 ## SourceForge
 ##

     source.forge.mirrors=         http://downloads.sourceforge.net,\      # Redirect
         http://internap.dl.sourceforge.net,\    # San Jose, CA
         http://superb-east.dl.sourceforge.net,\ # McLean, Virginia
         http://superb-west.dl.sourceforge.net,\ # Seattle, Washington
         http://easynews.dl.sourceforge.net,\    # Phoenix, AZ
         http://kent.dl.sourceforge.net,\        # Kent, UK
         http://ufpr.dl.sourceforge.net,\        # Curitiba, Brazil
         http://belnet.dl.sourceforge.net,\      # Brussels, Belgium
         http://switch.dl.sourceforge.net,\      # Lausanne, Switzerland
         http://mesh.dl.sourceforge.net,\        # Duesseldorf, Germany
         http://ovh.dl.sourceforge.net,\         # Paris, France
         http://dfn.dl.sourceforge.net,\         # Berlin, Germany
         http://heanet.dl.sourceforge.net,\      # Dublin, Ireland
         http://garr.dl.sourceforge.net,\        # Bologna, Italy
         http://surfnet.dl.sourceforge.net       # Amsterdam, The Netherlands
         http://jaist.dl.sourceforge.net,\       # Ishikawa, Japan
         http://nchc.dl.sourceforge.net,\        # Tainan, Taiwan
         http://optusnet.dl.sourceforge.net      # Sydney, Australia

 ##
 ## Value Object
 ##

     #
     # You can add a listener for a specific class by setting the property
     # "value.object.listener" with a list of comma delimited class names that
     # implement com.liferay.portal.model.ModelListener. These classes are pooled
     # and reused and must be thread safe.
     #
     value.object.listener.com.liferay.portal.model.Contact=com.liferay.portal.model.ContactListener
     value.object.listener.com.liferay.portal.model.Layout=com.liferay.portal.model.LayoutListener
     value.object.listener.com.liferay.portal.model.LayoutSet=com.liferay.portal.model.LayoutSetListener,com.liferay.portlet.communities.model.CommunityTemplateModelListener
     value.object.listener.com.liferay.portal.model.PortletPreferences=com.liferay.portal.model.PortletPreferencesListener
     value.object.listener.com.liferay.portal.model.User=com.liferay.portal.model.UserListener
     value.object.listener.com.liferay.portlet.journal.model.JournalArticle=com.liferay.portlet.journal.model.JournalArticleListener
     value.object.listener.com.liferay.portlet.journal.model.JournalTemplate=com.liferay.portlet.journal.model.JournalTemplateListener

     #
     # Value objects are cached at three levels. They first level is "entity",
     # the second level is "finder", and the third level is "Hibernate".
     #
     # The entity level cache stores a value object's primary key to the value
     # object itself.
     #
     # The finder level cache stores the many paths that return a
     # value object and the many paths that return a list of value objects. The
     # finder level cache only caches primary keys and is further helped by the
     # entity level cache that caches the value object to the primary key.
     #
     # The Hibernate level cache is provided by the
     # "hibernate.cache.provider_class" property.
     #

     #
     # Set this to true to enable entity level caching.
     #
     value.object.entity.cache.enabled=true

     #
     # Set this to true to configure entity level caching to block. This improves
     # performance significantly by locking on keys instead of the entire cache.
     # The drawback is that threads can hang if the cache is not used properly.
     # Make sure that all queries that return a miss also immediately populate
     # the cache, or else other threads that are blocked on a query of that same
     # key will continue to hang. Reference Ehcache's BlockingCache for more
     # information.
     #
     value.object.entity.blocking.cache=true

     #
     # The entity level cache uses a thread local map to store the most
     # frequently accessed items to lower the number of queries to the underlying
     # cache. Set the maximum map size to 0 to disable the thread level cache.
     #
     value.object.entity.thread.local.cache.max.size=100

     #
     # Entity level caching for a specific type of value object can be configured
     # by using a property name that includes the value object's class name.
     #
     value.object.entity.cache.enabled.com.liferay.portal.model.Layout=true
     value.object.entity.cache.enabled.com.liferay.portal.model.User=true

     #
     # Set this to true to enable finder level caching.
     #
     value.object.finder.cache.enabled=true

     #
     # Set this to true to configure finder level caching to block. This improves
     # performance significantly by locking on keys instead of the entire cache.
     # The drawback is that threads can hang if the cache is not used properly.
     # Make sure that all queries that return a miss also immediately populate
     # the cache, or else other threads that are blocked on a query of that same
     # key will continue to hang. Reference Ehcache's BlockingCache for more
     # information.
     #
     value.object.finder.blocking.cache=true

     #
     # The finder level cache uses a thread local map to store the most
     # frequently accessed items to lower the number of queries to the underlying
     # cache. Set the maximum map size to 0 to disable the thread level cache.
     #
     value.object.finder.thread.local.cache.max.size=100

     #
     # Finder level caching for a specific type of value object can be configured
     # by using a property name that includes the value object's class name.
     # Mapping tables can also be specified to configure the caching of value
     # object relationships.
     #
     value.object.finder.cache.enabled.com.liferay.portal.model.Layout=true
     value.object.finder.cache.enabled.com.liferay.portal.model.User=true
     value.object.finder.cache.enabled.Users_Roles=true

 ##
 ## Communication Link
 ##

     #
     # Set the JGroups properties used by the portal to communicate with other
     # instances of the portal. This is only needed if the portal is running in a
     # clustered environment. The JGroups settings provides a mechanism for the
     # portal to broadcast messages to the other instances of the portal. The
     # specified multicast address should be unique for internal portal messaging
     # only. You will still need to set the Hibernate and Ehcache settings for
     # database clustering.
     #
     #comm.link.properties=UDP(bind_addr=127.0.0.1;mcast_addr=231.12.21.102;mcast_port=45566;ip_ttl=32;mcast_send_buf_size=150000;mcast_recv_buf_size=80000):PING(timeout=2000;num_initial_members=3):MERGE2(min_interval=5000;max_interval=10000):FD_SOCK:VERIFY_SUSPECT(timeout=1500):pbcast.NAKACK(gc_lag=50;retransmit_timeout=300,600,1200,2400,4800;max_xmit_size=8192):UNICAST(timeout=300,600,1200,2400):pbcast.STABLE(desired_avg_gossip=20000):FRAG(frag_size=8096;down_thread=false;up_thread=false):pbcast.GMS(join_timeout=5000;join_retry_timeout=2000;shun=false;print_local_addr=true)

 ##
 ## Content Delivery Network
 ##

     #
     # Set the hostname that will be used to serve static content via a CDN. This
     # property can be overridden dynamically at runtime by setting the HTTP
     # parameter "cdn_host". The value should include the full protocol and port
     # if they are not the standard HTTP and HTTPS ports.
     #
     cdn.host=

 ##
 ## Counter
 ##

     #
     # Set the number of increments between database updates to the Counter
     # table. Set this value to a higher number for better performance.
     #
     counter.increment=100

     #
     # Set the interval in minutes for the ConnectionHearbeatJob. This will
     # determine how often the database is polled for long running connections
     # and will prevent the database from disconnecting the socket prematurely.
     #
     counter.connection.heartbeat.job.interval=60

 ##
 ## JBI
 ##

     #
     # Connect to either Mule or ServiceMix as your ESB.
     #
     jbi.workflow.url=http://localhost:8080/mule-web/workflow
     #jbi.workflow.url=http://localhost:8080/servicemix-web/workflow

 ##
 ## JCR
 ##

     jcr.initialize.on.startup=false

     jcr.workspace.name=liferay
     jcr.node.documentlibrary=documentlibrary

     jcr.jackrabbit.repository.root=${liferay.home}/data/jackrabbit
     jcr.jackrabbit.config.file.path=${jcr.jackrabbit.repository.root}/repository.xml
     jcr.jackrabbit.repository.home=${jcr.jackrabbit.repository.root}/home
     jcr.jackrabbit.credentials.username=none
     jcr.jackrabbit.credentials.password=none

 ##
 ## Live Users
 ##

     #
     # Set this to true to enable tracking via Live Users.
     #
     live.users.enabled=false

 ##
 ## Lock
 ##

     #
     # Set the lock expiration time for each class.
     #

     #
     # 1 day
     #
     lock.expiration.time.com.liferay.portlet.documentlibrary.model.DLFolder=86400000
     lock.expiration.time.com.liferay.portlet.documentlibrary.model.DLFileEntry=86400000

     #
     # 20 minutes
     #
     lock.expiration.time.com.liferay.portlet.wiki.model.WikiPage=1200000

 ##
 ## Mail
 ##

     #
     # Set the JNDI name to lookup the Java Mail session. If none is set, then
     # the portal will attempt to create the Java Mail session based on the
     # properties prefixed with "mail.session.".
     #
     #mail.session.jndi.name=mail/MailSession

     #
     # Set the properties used to create the Java Mail session. The property
     # prefix "mail.session." will be removed before it is used to create the
     # session object. These properties will only be read if the property
     # "mail.session.jndi.name" is not set.
     #
     mail.session.mail.pop3.host=localhost
     mail.session.mail.pop3.password=
     mail.session.mail.pop3.port=110
     mail.session.mail.pop3.user=
     mail.session.mail.smtp.auth=false
     mail.session.mail.smtp.host=localhost
     mail.session.mail.smtp.password=
     mail.session.mail.smtp.port=25
     mail.session.mail.smtp.user=
     mail.session.mail.store.protocol=pop3
     mail.session.mail.transport.protocol=smtp

     #
     # Set this to false if administrator should not be allowed to change the
     # mail domain via the Admin portlet.
     #
     mail.mx.update=true

     #
     # Input a list of comma delimited email addresses that will receive a BCC of
     # every email sent through the mail server.
     #
     mail.audit.trail=

     #
     # Set the name of a class that implements com.liferay.mail.util.Hook. The
     # mail server will use this class to ensure that the mail and portal servers
     # are synchronized on user information. The portal will not know how to add,
     # update, or delete users from the mail server except through this hook.
     #
     # Available hooks are:
     #     com.liferay.mail.util.CyrusHook
     #     com.liferay.mail.util.DummyHook
     #     com.liferay.mail.util.FuseMailHook
     #     com.liferay.mail.util.SendmailHook
     #     com.liferay.mail.util.ShellHook
     #
     mail.hook.impl=com.liferay.mail.util.DummyHook

     #
     # CyrusHook
     #
     # Set the commands for adding, updating, and deleting a user where
     # %1% is the user id. Replace the password with the password for the cyrus
     # user.
     #
     mail.hook.cyrus.add.user=cyrusadmin password create %1%
     #mail.hook.cyrus.add.user=cyrus_adduser password %1%
     mail.hook.cyrus.delete.user=cyrusadmin password delete %1%
     #mail.hook.cyrus.delete.user=cyrus_userdel password %1%
     mail.hook.cyrus.home=/home/cyrus

     #
     # FuseMailHook
     #
     # See http://www.fusemail.com/support/api.html for more information. You must
     # also update the "mail.account.finder" property.
     #
     mail.hook.fusemail.url=https://www.fusemail.com/api/request.html
     mail.hook.fusemail.username=
     mail.hook.fusemail.password=
     mail.hook.fusemail.account.type=group_subaccount
     mail.hook.fusemail.group.parent=

     #
     # SendmailHook
     #
     # Set the commands for adding, updating, and deleting a user where
     # %1% is the user id and %2% is the password. Set the home and
     # virtual user table information.
     #
     mail.hook.sendmail.add.user=adduser %1% -s /bin/false
     mail.hook.sendmail.change.password=autopasswd %1% %2%
     mail.hook.sendmail.delete.user=userdel -r %1%
     mail.hook.sendmail.home=/home
     mail.hook.sendmail.virtusertable=/etc/mail/virtusertable
     mail.hook.sendmail.virtusertable.refresh=bash -c "makemap hash /etc/mail/virtusertable < /etc/mail/virtusertable"

     #
     # ShellHook
     #
     # Set the location of the shell script that will interface with any mail
     # server.
     #
     mail.hook.shell.script=/usr/sbin/mailadmin.ksh

 ##
 ## OpenOffice
 ##

     #
     # Enabling OpenOffice integration allows the Document Library portlet and
     # the Wiki portlet to provide conversion functionality. This is tested with
     # OpenOffice 2.3.x and 2.4. To start OpenOffice as a service, run the
     # command:
     #
     # soffice -headless -accept="socket,host=127.0.0.1,port=8100;urp;"
     #
     openoffice.server.enabled=false
     openoffice.server.host=127.0.0.1
     openoffice.server.port=8100
     openoffice.cache.enabled=true

 ##
 ## POP
 ##

     #
     # Set this to true to enable polling of email notifications from a POP
     # server. The user credentials are the same used for SMTP authentication
     # and is specified in the mail/MailSession configuration for each
     # application server.
     #
     pop.server.notifications.enabled=false

     #
     # Set the interval on which the POPNotificationsJob will run. The value is
     # set in one minute increments.
     #
     pop.server.notifications.interval=1

     #
     # Set this property to create a special MX subdomain to receive all portal
     # related email (e.g. events.liferay.com). This means configuring a
     # default inbox for the domain and receiving all emails into that inbox.
     #
     # This approach may not be allowed for some organizations. If you cannot use
     # the subdomain approach, unset this value and Liferay will use the replyTo
     # address specified in the portlet preferences.
     #
     pop.server.subdomain=events

 ##
 ## Quartz
 ##

     org.quartz.dataSource.ds.connectionProvider.class=com.liferay.portal.scheduler.quartz.QuartzConnectionProviderImpl
     org.quartz.jobStore.class=org.quartz.impl.jdbcjobstore.JobStoreTX
     org.quartz.jobStore.dataSource=ds
     org.quartz.jobStore.driverDelegateClass=com.liferay.portal.scheduler.quartz.DynamicDriverDelegate
     org.quartz.jobStore.isClustered=false
     org.quartz.jobStore.misfireThreshold=60000
     org.quartz.jobStore.tablePrefix=QUARTZ_
     org.quartz.jobStore.useProperties=true
     org.quartz.scheduler.instanceId=AUTO
     org.quartz.scheduler.instanceName=QuartzSchedulerEngineInstance
     org.quartz.threadPool.class=org.quartz.simpl.SimpleThreadPool
     org.quartz.threadPool.threadCount=5
     org.quartz.threadPool.threadPriority=5

 ##
 ## Scheduler
 ##

     #
     # Set this to false to disable all scheduler classes defined in
     # liferay-portlet.xml and in the property "scheduler.classes".
     #
     scheduler.enabled=true

     #
     # Input a list of comma delimited class names that implement
     # com.liferay.portal.kernel.job.Scheduler. These classes allow jobs to be
     # scheduled on startup. These classes are not associated to any one portlet.
     #
     scheduler.classes=

 ##
 ## Search Container
 ##

     #
     # Set the available values for the number of entries to display per page. An
     # empty value, or commenting out the value, will disable delta resizing.
     # The default of 20 will apply in all cases.
     #
     # Always include 20, since it is the default page size when no delta is
     # specified. The absolute maximum allowed delta is 200.
     #
     search.container.page.delta.values=5,10,20,30,50,75

 ##
 ## Sharepoint
 ##

     #
     # Set the tokens for supported Sharepoint storage paths.
     #
     sharepoint.storage.tokens=document_library

     #
     # Set the class names for supported Sharepoint storage classes.
     #
     sharepoint.storage.class[document_library]=com.liferay.portlet.documentlibrary.sharepoint.DLSharepointStorageImpl

 ##
 ## Social Bookmarks
 ##

     social.bookmark.types=blinklist,delicious,digg,furl,newsvine,reddit,technorati

     social.bookmark.post.url[blinklist]=http://blinklist.com/index.php?Action=Blink/addblink.php&url=${liferay:social-bookmark:url}&Title=${liferay:social-bookmark:title}
     social.bookmark.post.url[delicious]=http://del.icio.us/post?url=${liferay:social-bookmark:url}&title=${liferay:social-bookmark:title}
     social.bookmark.post.url[digg]=http://digg.com/submit?phase=2&url=${liferay:social-bookmark:url}
     social.bookmark.post.url[furl]=http://furl.net/storeIt.jsp?u=${liferay:social-bookmark:url}&t=${liferay:social-bookmark:title}
     social.bookmark.post.url[newsvine]=http://www.newsvine.com/_tools/seed&save?u=${liferay:social-bookmark:url}&h=${liferay:social-bookmark:title}
     social.bookmark.post.url[reddit]=http://reddit.com/submit?url=${liferay:social-bookmark:url}&title=${liferay:social-bookmark:title}
     social.bookmark.post.url[technorati]=http://technorati.com/cosmos/search.html?url=${liferay:social-bookmark:url}

 ##
 ## Velocity Engine
 ##

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.util.velocity.VelocityResourceListener. These classes will
     # run in sequence to allow you to find the applicable ResourceLoader
     # to load a Velocity template.
     #
     velocity.engine.resource.listeners=com.liferay.portal.velocity.ServletVelocityResourceListener,com.liferay.portal.velocity.JournalTemplateVelocityResourceListener,com.liferay.portal.velocity.ThemeLoaderVelocityResourceListener,com.liferay.portal.velocity.ClassLoaderVelocityResourceListener

     #
     # Set the Velocity resource managers. We extend the Velocity's default
     # resource managers for better scalability.
     #
     # Note that the modification check interval is not respected because the
     # resource loader implementation does not know the last modified date of a
     # resource. This means you will need to turn off caching if you want to be
     # able to modify VM templates in themes and see the changes right away.
     #
     velocity.engine.resource.manager=com.liferay.portal.velocity.LiferayResourceManager
     velocity.engine.resource.manager.cache=com.liferay.portal.velocity.LiferayResourceCache
     velocity.engine.resource.manager.cache.enabled=true
     #velocity.engine.resource.manager.modification.check.interval=0

     #
     # Input a list of comma delimited macros that will be loaded. These files
     # must exist in the class path.
     #
     velocity.engine.velocimacro.library=VM_global_library.vm,VM_liferay.vm

     #
     # Set the Velocity logging configuration.
     #
     velocity.engine.logger=org.apache.velocity.runtime.log.SimpleLog4JLogSystem
     velocity.engine.logger.category=org.apache.velocity

 ##
 ## Virtual Hosts
 ##

     #
     # Set the hosts that will be ignored for virtual hosts.
     #
     virtual.hosts.ignore.hosts=         127.0.0.1,         localhost

     #
     # Set the paths that will be ignored for virtual hosts.
     #
     virtual.hosts.ignore.paths=         /c,                  /c/portal/change_password,         /c/portal/extend_session,         /c/portal/extend_session_confirm,         /c/portal/json_service,         /c/portal/layout,         /c/portal/login,         /c/portal/logout,         /c/portal/portlet_url,         /c/portal/render_portlet,         /c/portal/reverse_ajax,         /c/portal/session_tree_js_click,         /c/portal/status,         /c/portal/update_layout,         /c/portal/update_terms_of_use,         /c/portal/upload_progress_poller,                  /c/layout_configuration/templates,         /c/layout_management/update_page

 ##
 ## HTTP
 ##

     #
     # See system.properties for more HTTP settings.
     #

     #
     # Set the maximum number of connections.
     #
     #com.liferay.portal.util.HttpImpl.max.connections.per.host=2
     #com.liferay.portal.util.HttpImpl.max.total.connections=20

     #
     # Set the proxy authentication type.
     #
     #com.liferay.portal.util.HttpImpl.proxy.auth.type=username-password
     #com.liferay.portal.util.HttpImpl.proxy.auth.type=ntlm

     #
     # Set user name and password used for HTTP proxy authentication.
     #
     #com.liferay.portal.util.HttpImpl.proxy.username=
     #com.liferay.portal.util.HttpImpl.proxy.password=

     #
     # Set additional properties for NTLM authentication.
     #
     #com.liferay.portal.util.HttpImpl.proxy.ntlm.domain=
     #com.liferay.portal.util.HttpImpl.proxy.ntlm.host=

     #
     # Set the connection timeout when fetching HTTP content.
     #
     com.liferay.portal.util.HttpImpl.timeout=10000

 ##
 ## Servlet Filters
 ##

     #
     # The cache filter will cache content. See ehcache.xml to modify the cache
     # expiration time to live.
     #
     com.liferay.portal.servlet.filters.cache.CacheFilter=true

     #
     # This double click filter will prevent double clicks at the server side.
     # Prevention of double clicks is already in place on the client side.
     # However, some sites requrie a more robust solution. This is turned off by
     # default since most sites will not need it.
     #
     com.liferay.portal.servlet.filters.doubleclick.DoubleClickFilter=false

     #
     # If the user can unzip compressed HTTP content, the GZip filter will
     # zip up the HTTP content before sending it to the user. This will speed up
     # page rendering for users that are on dial up.
     #
     com.liferay.portal.servlet.filters.gzip.GZipFilter=true

     #
     # The header filter is used to set request headers.
     #
     com.liferay.portal.servlet.filters.header.HeaderFilter=true

     #
     # The minifier filter is used to minify CSS and JavaScript.
     #
     com.liferay.portal.servlet.filters.minifier.MinifierFilter=true

     #
     # The strip filter will remove blank lines from the outputted content. This
     # will speed up page rendering for users that are on dial up.
     #
     com.liferay.portal.servlet.filters.strip.StripFilter=true

     #
     # The session id filter ensure that only one session is created between http
     # and https sessions. This is useful if you want users to login via https
     # but have them view the rest of the site via http. This is disabled by
     # default. Do not enable this unless you thoroughly understand how cookies,
     # http, and https work.
     #
     com.liferay.portal.servlet.filters.sessionid.SessionIdFilter=false

     #
     # The theme preview filter generates a preview of the currently applied
     # theme that can be used by the Dreamweaver Theming plugin. This is disabled
     # by default. Set the "themePreview" parameter to "1" in the URL to access
     # the theme preview for any page. For example, a URL can be
     # http://localhost:8080/web/guest?themePreview=1.
     #
     com.liferay.portal.servlet.filters.theme.ThemePreviewFilter=false

     #
     # The Velocity filter will process */css/main.css as a Velocity template.
     #
     com.liferay.portal.servlet.filters.velocity.VelocityFilter=false

     #
     # The virtual host filter maps hosts to public and private pages. For
     # example, if the public virtual host is www.helloworld.com and the friendly
     # URL is /helloworld, then http://www.helloworld.com is mapped to
     # http://localhost:8080/web/helloworld.
     #
     com.liferay.portal.servlet.filters.virtualhost.VirtualHostFilter=true

 ##
 ## Upload Servlet Request
 ##

     #
     # Set the maximum file size. Default is 1024 * 1024 * 100.
     #
     com.liferay.portal.upload.UploadServletRequestImpl.max.size=104857600

     #
     # Set the temp directory for uploaded files.
     #
     #com.liferay.portal.upload.UploadServletRequestImpl.temp.dir=C:/Temp

     #
     # Set the threshold size to prevent extraneous serialization of uploaded
     # data.
     #
     com.liferay.portal.upload.LiferayFileItem.threshold.size=262144

     #
     # Set the threshold size to prevent out of memory exceptions caused by
     # caching excessively large uploaded data. Default is 1024 * 1024 * 10.
     #
     com.liferay.portal.upload.LiferayInputStream.threshold.size=10485760

 ##
 ## Web Server
 ##

     #
     # Set the HTTP and HTTPs ports when running the portal in a J2EE server that
     # is sitting behind another web server like Apache. Set the values to -1 if
     # the portal is not running behind another web server like Apache.
     #
     web.server.http.port=-1
     web.server.https.port=-1

     #
     # Set the hostname that will be used when the portlet generates URLs.
     # Leaving this blank will mean the host is derived from the servlet
     # container.
     #
     web.server.host=

     #
     # Set the preferred protocol.
     #
     #web.server.protocol=https

     #
     # Set this to true to display the server name at the bottom of every page.
     # This is useful when testing clustering configurations so that you can know
     # which node you are accessing.
     #
     web.server.display.node=false

 ##
 ## WebDAV
 ##

     #
     # Set this to true to enable programmatic configuration to let the WebDAV be
     # configured for litmus testing. This should never be set to true unless you
     # are running the litmus tests.
     #
     webdav.litmus=false

     #
     # Set a list of files for the WebDAV servlet to ignore processing.
     #
     webdav.ignore=.DS_Store,.metadata_index_homes_only,.metadata_never_index,.Spotlight-V100,.TemporaryItems,.Trashes,Backups.backupdb

 ##
 ## Main Servlet
 ##

     #
     # Servlets can be protected by
     # com.liferay.portal.servlet.filters.secure.SecureFilter.
     #
     # Input a list of comma delimited IPs that can access this servlet. Input a
     # blank list to allow any IP to access this servlet. SERVER_IP will be
     # replaced with the IP of the host server.
     #
     main.servlet.hosts.allowed=

     #
     # Set this to true if this servlet can only be accessed via https.
     #
     main.servlet.https.required=false

 ##
 ## Axis Servlet
 ##

     #
     # See Main Servlet on how to protect this servlet.
     #
     axis.servlet.hosts.allowed=127.0.0.1,SERVER_IP
     axis.servlet.https.required=false

 ##
 ## Google Gadget Servlet
 ##

     #
     # Set the servlet mapping for the Google Gadget servlet.
     #
     google.gadget.servlet.mapping=/google_gadget

 ##
 ## JSON Tunnel Servlet
 ##

     #
     # See Main Servlet on how to protect this servlet.
     #
     json.servlet.hosts.allowed=
     json.servlet.https.required=false

 ##
 ## Liferay Tunnel Servlet
 ##

     #
     # See Main Servlet on how to protect this servlet.
     #
     tunnel.servlet.hosts.allowed=127.0.0.1,SERVER_IP
     tunnel.servlet.https.required=false

 ##
 ## Netvibes Servlet
 ##

     #
     # Set the servlet mapping for the Netvibes servlet.
     #
     netvibes.servlet.mapping=/netvibes

 ##
 ## Spring Remoting Servlet
 ##

     #
     # See Main Servlet on how to protect this servlet.
     #
     spring.remoting.servlet.hosts.allowed=127.0.0.1,SERVER_IP
     spring.remoting.servlet.https.required=false

 ##
 ## WebDAV Servlet
 ##

     #
     # See Main Servlet on how to protect this servlet.
     #
     webdav.servlet.hosts.allowed=
     webdav.servlet.https.required=false

 ##
 ## Widget Servlet
 ##

     #
     # Set the servlet mapping for the Widget servlet.
     #
     widget.servlet.mapping=/widget

 ##
 ## Admin Portlet
 ##

     #
     # Input a list of default group names separated by \n characters.
     #
     admin.default.group.names=

     #
     # Input a list of default role names separated by \n characters.
     #
     admin.default.role.names=Power User\nUser

     #
     # Input a list of default user group names separated by \n characters.
     #
     admin.default.user.group.names=

     #
     # Input a list of mail host names separated by \n characters.
     #
     admin.mail.host.names=

     #
     # Input a list of reserved screen names separated by \n characters.
     #
     admin.reserved.screen.names=

     #
     # Input a list of reserved email addresses separated by \n characters.
     #
     admin.reserved.email.addresses=

     #
     # Configure email notification settings.
     #
     admin.email.from.name=Joe Bloggs
     admin.email.from.address=test@liferay.com

     admin.email.user.added.enabled=true
     admin.email.user.added.subject=com/liferay/portlet/admin/dependencies/email_user_added_subject.tmpl
     admin.email.user.added.body=com/liferay/portlet/admin/dependencies/email_user_added_body.tmpl

     admin.email.password.sent.enabled=true
     admin.email.password.sent.subject=com/liferay/portlet/admin/dependencies/email_password_sent_subject.tmpl
     admin.email.password.sent.body=com/liferay/portlet/admin/dependencies/email_password_sent_body.tmpl

 ##
 ## Announcements Portlet
 ##

     #
     # Configure email notification settings.
     #
     announcements.email.from.name=Joe Bloggs
     announcements.email.from.address=test@liferay.com

     announcements.email.to.name=
     announcements.email.to.address=noreply@liferay.com

     announcements.email.subject=com/liferay/portlet/announcements/dependencies/email_subject.tmpl
     announcements.email.body=com/liferay/portlet/announcements/dependencies/email_body.tmpl

     #
     # Set the list of announcement types. The display text of each of the
     # announcement types is set in content/Language.properties.
     #
     announcements.entry.types=general,news,test

     #
     # Set the interval on which the CheckEntryJob will run. The value is set in
     # one minute increments.
     #
     announcements.entry.check.interval=15

 ##
 ## Asset Publisher Portlet
 ##

     #
     # Input a list of  comma separated display styles that will be available in
     # the configuration screen of Asset Publisher portlet.
     #
     asset.publisher.display.styles=table,title-list,abstracts,full-content

 ##
 ## Blogs Portlet
 ##

     #
     # Configure email notification settings.
     #
     blogs.email.comments.added.enabled=true
     blogs.email.comments.added.subject=com/liferay/portlet/blogs/dependencies/email_comments_added_subject.tmpl
     blogs.email.comments.added.body=com/liferay/portlet/blogs/dependencies/email_comments_added_body.tmpl

     blogs.page.abstract.length=400

     blogs.rss.abstract.length=200

     #
     # Set this to true to enable trackbacks.
     #
     blogs.trackback.enabled=true

     #
     # Set the excerpt length for trackbacks.
     #
     blogs.trackback.excerpt.length=50

     #
     # Set the interval on which the TrackbackVerifierJob will run. The value is
     # set in one minute increments.
     #
     blogs.trackback.verifier.job.interval=5

     #
     # Set this to true to enable pinging Google on new and updated blog entries.
     #
     blogs.ping.google.enabled=true

     #
     # Set this to true to enable comments for blogs entries.
     #
     blogs.entry.comments.enabled=true

 ##
 ## Calendar Portlet
 ##

     #
     # Set the list of event types. The display text of each of the event types
     # is set in content/Language.properties.
     #
     calendar.event.types=anniversary,appointment,bill-payment,birthday,breakfast,call,chat,class,club-event,concert,dinner,event,graduation,happy-hour,holiday,interview,lunch,meeting,movie,net-event,other,party,performance,press-release,reunion,sports-event,training,travel,tv-show,vacation,wedding

     #
     # Set the interval on which the CheckEventJob will run. The value is set in
     # one minute increments.
     #
     calendar.event.check.interval=15

     #
     # Configure email notification settings.
     #
     calendar.email.from.name=Joe Bloggs
     calendar.email.from.address=test@liferay.com

     calendar.email.event.reminder.enabled=true
     calendar.email.event.reminder.subject=com/liferay/portlet/calendar/dependencies/email_event_reminder_subject.tmpl
     calendar.email.event.reminder.body=com/liferay/portlet/calendar/dependencies/email_event_reminder_body.tmpl

 ##
 ## Communities Portlet
 ##

     #
     # Configure email notification settings.
     #
     communities.email.from.name=Joe Bloggs
     communities.email.from.address=test@liferay.com

     communities.email.membership.reply.subject=com/liferay/portlet/communities/dependencies/email_membership_reply_subject.tmpl
     communities.email.membership.reply.body=com/liferay/portlet/communities/dependencies/email_membership_reply_body.tmpl

     communities.email.membership.request.subject=com/liferay/portlet/communities/dependencies/email_membership_request_subject.tmpl
     communities.email.membership.request.body=com/liferay/portlet/communities/dependencies/email_membership_request_body.tmpl

 ##
 ## Discussion Tag Library
 ##

     #
     # Set the thread view for discussion comments. This will affect Blogs,
     # Document Library, and other portlets that use the Discussion tag library
     # to provide comments. Set the value to "flat" to paginate comments. Set the
     # value to "combination" to show all comments in one page along with a tree
     # view of the comments.
     #
     #discussion.thread.view=combination
     discussion.thread.view=flat

 ##
 ## Document Library Portlet
 ##

     #
     # Set the name of a class that implements
     # com.liferay.documentlibrary.util.Hook. The
     # document library server will use this persist documents.
     #
     # Available hooks are:
     #     com.liferay.documentlibrary.util.FileSystemHook
     #     com.liferay.documentlibrary.util.JCRHook
     #     com.liferay.documentlibrary.util.S3Hook
     #
     #dl.hook.impl=com.liferay.documentlibrary.util.AdvancedFileSystemHook
     dl.hook.impl=com.liferay.documentlibrary.util.FileSystemHook
     #dl.hook.impl=com.liferay.documentlibrary.util.JCRHook
     #dl.hook.impl=com.liferay.documentlibrary.util.S3Hook

     #
     # FileSystemHook
     #
     dl.hook.file.system.root.dir=${liferay.home}/data/document_library

     #
     # S3Hook
     #
     dl.hook.s3.access.key=
     dl.hook.s3.secret.key=
     dl.hook.s3.bucket.name=

     #
     # S3Hook
     #
     dl.hook.s3.access.key=
     dl.hook.s3.secret.key=
     dl.hook.s3.bucket.name=

     #
     # Set the maximum file size and valid file extensions for documents. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     #dl.file.max.size=307200
     #dl.file.max.size=1024000
     dl.file.max.size=3072000

     #
     # A file extension of * will permit all file extensions.
     #
     # You can map a GIF for the extension by adding the image to the theme's
     # image display and document library folder. The wildcard extension of *
     # will be ignored. For example, the default image for the DOC extension
     # would be found in: /html/themes/_unstyled/images/document_library/doc.gif.
     #
     dl.file.extensions=.bmp,.css,.doc,.docx,.dot,.gif,.gz,.htm,.html,.jpg,.js,.lar,.odb,.odf,.odg,.odp,.ods,.odt,.pdf,.png,.ppt,.pptx,.rtf,.swf,.sxc,.sxi,.sxw,.tar,.tiff,.tgz,.txt,.vsd,.xls,.xlsx,.xml,.zip,.jrxml

     #
     # Set which files extensions are comparable by the diff tool. If OpenOffice
     # integration is enabled, then it is also possible to compare some binary
     # files that are convertable to text.
     #
     dl.comparable.file.extensions=.css,.js,.htm,.html,.txt,.xml
     #dl.comparable.file.extensions=.css,.doc,.js,.htm,.html,.odt,.rtf,.sxw,.txt,.xml

     #
     # Set folder names that will be used to synchronize with a community's set
     # of private and public layouts. This will allow users to manage layouts
     # using the Document Library portlet, and ultimately, via WebDAV. This
     # feature is experimental.
     #
     dl.layouts.sync.enabled=false
     dl.layouts.sync.private.folder=Pages - Private
     dl.layouts.sync.public.folder=Pages - Public

     #
     # Set this to true to enable comments for document library files.
     #
     dl.file.entry.comments.enabled=true

     #
     # Set this to true to enable file rank for document library files.
     #
     dl.file.rank.enabled=true

 ##
 ## Flags Portlet
 ##

     #
     # Input a list of questions used for flag reasons.
     #
     flags.reasons=sexual-content,violent-or-repulsive-content,hateful-or-abusive-content,harmful-dangerous-acts,spam,infringes-my-rights

     #
     # Email Notification Settings
     #
     flags.email.from.name=Joe Bloggs
     flags.email.from.address=test@liferay.com

     flags.email.subject=com/liferay/portlet/flags/dependencies/email_flag_subject.tmpl
     flags.email.body=com/liferay/portlet/flags/dependencies/email_flag_body.tmpl

     #
     # Set this to true to enable guest users to flag content
     #
     flags.guest.users.enabled=false

 ##
 ## Image Gallery Portlet
 ##

     #
     # Set the maximum file size and valid file extensions for images. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     ig.image.max.size=10240000

     #
     # A file extension of * will permit all file extensions.
     #
     ig.image.extensions=.bmp,.gif,.jpeg,.jpg,.png,.tif,.tiff

     #
     # Set the maximum thumbnail height and width in pixels. Set dimension of the
     # custom images to 0 to disable creating a scaled image of that size.
     #
     ig.image.thumbnail.max.dimension=150
     #ig.image.custom1.max.dimension=100
     #ig.image.custom2.max.dimension=0

 ##
 ## Invitation Portlet
 ##

     invitation.email.max.recipients=20
     invitation.email.message.body=com/liferay/portlet/invitation/dependencies/email_message_body.tmpl
     invitation.email.message.subject=com/liferay/portlet/invitation/dependencies/email_message_subject.tmpl

 ##
 ## Journal Portlet
 ##

     #
     # Set this to true if article ids should always be autogenerated.
     #
     journal.article.force.autogenerate.id=true

     #
     # Set this to true so that only the latest version of an article that is
     # also not approved can be saved without incrementing version.
     #
     journal.article.force.increment.version=false

     #
     # Set the list of article types. The display text of each of the article
     # types is set in content/Language.properties.
     #
     journal.article.types=announcements,blogs,general,news,press-release,test

     #
     # Set the token used when inserting simple page breaks in articles.
     #
     journal.article.token.page.break=@page_break@

     #
     # Set the interval on which the CheckArticleJob will run. The value is set
     # in one minute increments.
     #
     journal.article.check.interval=15

     #
     # Set this to true to check that a user has the VIEW permission on a
     # Journal article when its content is rendered.
     #
     journal.article.view.permission.check.enabled=false

     #
     # Set this to true to enable comments for journal articles.
     #
     journal.article.comments.enabled=true

     #
     # Set this to true if feed ids should always be autogenerated.
     #
     journal.feed.force.autogenerate.id=false

     #
     # Set this to true if structure ids should always be autogenerated.
     #
     journal.structure.force.autogenerate.id=false

     #
     # Set this to true if template ids should always be autogenerated.
     #
     journal.template.force.autogenerate.id=false

     #
     # Input a comma delimited list of variables which are restricted from the
     # context in Velocity based Journal templates.
     #
     journal.template.velocity.restricted.variables=serviceLocator

     #
     # Set the maximum file size and valid file extensions for images. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     journal.image.small.max.size=51200

     #
     # A file extension of * will permit all file extensions.
     #
     journal.image.extensions=.gif,.jpeg,.jpg,.png

     #
     # Input a list of comma delimited class names that extend
     # com.liferay.portlet.journal.util.TransformerListener. These classes will
     # run in sequence to allow you to modify the XML and XSL before it's
     # transformed and allow you to modify the final output.
     #
     journal.transformer.listener=         com.liferay.portlet.journal.util.TokensTransformerListener,         #com.liferay.portlet.journal.util.PropertiesTransformerListener,         com.liferay.portlet.journal.util.ContentTransformerListener,         com.liferay.portlet.journal.util.LocaleTransformerListener,         com.liferay.portlet.journal.util.RegexTransformerListener,         com.liferay.portlet.journal.util.ViewCounterTransformerListener

     #
     # Enter a list of regular expression patterns and replacements that will be
     # applied to outputted Journal content. The list of  properties must end
     # with a subsequent integer (0, 1, etc.) and it is assumed that the list has
     # reached an end when the pattern or replacement is not set. See
     # com.liferay.portlet.journal.util.RegexTransformerListener for
     # implementation details.
     #
     #journal.transformer.regex.pattern.0=beta.sample.com
     #journal.transformer.regex.replacement.0=production.sample.com
     #journal.transformer.regex.pattern.1=staging.sample.com
     #journal.transformer.regex.replacement.1=production.sample.com

     #
     # Set this to true if journal should be published to live by default.
     #
     journal.publish.to.live.by.default=true

     #
     # Set whether to synchronize content searches when server starts.
     #
     journal.sync.content.search.on.startup=false

     #
     # Configure email notification settings.
     #
     journal.email.from.name=Joe Bloggs
     journal.email.from.address=test@liferay.com

     journal.email.article.approval.denied.enabled=false
     journal.email.article.approval.denied.subject=com/liferay/portlet/journal/dependencies/email_article_approval_denied_subject.tmpl
     journal.email.article.approval.denied.body=com/liferay/portlet/journal/dependencies/email_article_approval_denied_body.tmpl

     journal.email.article.approval.granted.enabled=false
     journal.email.article.approval.granted.subject=com/liferay/portlet/journal/dependencies/email_article_approval_granted_subject.tmpl
     journal.email.article.approval.granted.body=com/liferay/portlet/journal/dependencies/email_article_approval_granted_body.tmpl

     journal.email.article.approval.requested.enabled=false
     journal.email.article.approval.requested.subject=com/liferay/portlet/journal/dependencies/email_article_approval_requested_subject.tmpl
     journal.email.article.approval.requested.body=com/liferay/portlet/journal/dependencies/email_article_approval_requested_body.tmpl

     journal.email.article.review.enabled=false
     journal.email.article.review.subject=com/liferay/portlet/journal/dependencies/email_article_review_subject.tmpl
     journal.email.article.review.body=com/liferay/portlet/journal/dependencies/email_article_review_body.tmpl

     #
     # Specify the strategy used when Journal content is imported using the LAR
     # system.
     #
     journal.lar.creation.strategy=com.liferay.portlet.journal.lar.JournalCreationStrategyImpl

     #
     # Specify the path to the template used for providing error messages on
     # Journal templates.
     #
     journal.error.template.velocity=com/liferay/portlet/journal/dependencies/error.vm
     journal.error.template.xsl=com/liferay/portlet/journal/dependencies/error.xsl

 ##
 ## Journal Articles Portlet
 ##

     #
     # Set the available values for the number of articles to display per page.
     #
     journal.articles.page.delta.values=5,10,25,50,100

 ##
 ## Journal Content Search Portlet
 ##

     #
     # Set whether unlisted articles are excluded from search results.
     #
     journal.content.search.show.listed=true

 ##
 ## Login Portlet
 ##

     #
     # Set this to true to allow the user to choose a password during account
     # creation.
     #
     login.create.account.allow.custom.password=false

 ##
 ## Message Boards Portlet
 ##

     #
     # Configure email notification settings.
     #
     message.boards.email.from.name=Joe Bloggs
     message.boards.email.from.address=test@liferay.com
     message.boards.email.html.format=true

     message.boards.email.message.added.enabled=true
     message.boards.email.message.added.subject.prefix=com/liferay/portlet/messageboards/dependencies/email_message_added_subject_prefix.tmpl
     message.boards.email.message.added.body=com/liferay/portlet/messageboards/dependencies/email_message_added_body.tmpl
     message.boards.email.message.added.signature=com/liferay/portlet/messageboards/dependencies/email_message_added_signature.tmpl

     message.boards.email.message.updated.enabled=true
     message.boards.email.message.updated.subject.prefix=com/liferay/portlet/messageboards/dependencies/email_message_updated_subject_prefix.tmpl
     message.boards.email.message.updated.body=com/liferay/portlet/messageboards/dependencies/email_message_updated_body.tmpl
     message.boards.email.message.updated.signature=com/liferay/portlet/messageboards/dependencies/email_message_updated_signature.tmpl

     #
     # Set this to true to allow anonymous posting.
     #
     message.boards.anonymous.posting.enabled=true

     #
     # Enter time in minutes on how often this job is run. If a user's ban is set
     # to expire at 12:05 PM and the job runs at 2 PM, the expire will occur
     # during the 2 PM run.
     #
     message.boards.expire.ban.job.interval=120

     #
     # Enter time in days to automatically expire bans on users. Set to 0
     # to disable auto expire.
     #
     message.boards.expire.ban.interval=10
     #message.boards.expire.ban.interval=0

     message.boards.rss.abstract.length=200

     #
     # Set the allowed thread views and the default thread view.
     #
     message.boards.thread.views=combination,flat,tree
     message.boards.thread.views.default=combination

 ##
 ## My Places Portlet
 ##

     #
     # Set this to true to show user public sites with no layouts.
     #
     my.places.show.user.public.sites.with.no.layouts=true

     #
     # Set this to true to show user private sites with no layouts.
     #
     my.places.show.user.private.sites.with.no.layouts=true

     #
     # Set this to true to show organization public sites with no layouts.
     #
     my.places.show.organization.public.sites.with.no.layouts=true

     #
     # Set this to true to show organization private sites with no layouts.
     #
     my.places.show.organization.private.sites.with.no.layouts=true

     #
     # Set this to true to show community public sites with no layouts.
     #
     my.places.show.community.public.sites.with.no.layouts=true

     #
     # Set this to true to show community private sites with no layouts.
     #
     my.places.show.community.private.sites.with.no.layouts=true

     #
     # Set the maximum number of elements that will be shown in the My Places
     # navigation menu. For example, if the maximum is set to 10, then, at most,
     # 1 personal community, 10 organizations, and 10 communities will be shown.
     #
     my.places.max.elements=10

 ##
 ## Navigation Portlet
 ##

     #
     # Specify the options that will be provided to the user in the edit
     # configuration mode of the portlet.
     #
     navigation.display.style.options=1,2,3,4,5,6

     #
     # Define each mode with 4 comma delimited strings that represent the form:
     # headerType, rootLayoutType, rootLayoutLevel, includedLayouts,
     # and nestedChildren.
     #
     navigation.display.style[1]=breadcrumb,relative,0,auto,true
     navigation.display.style[2]=root-layout,absolute,2,auto,true
     navigation.display.style[3]=root-layout,absolute,1,auto,true
     navigation.display.style[4]=none,absolute,1,auto,true
     navigation.display.style[5]=none,absolute,1,all,true
     navigation.display.style[6]=none,absolute,0,auto,true

 ##
 ## Nested Portlets Portlet
 ##

     nested.portlets.layout.template.default=2_columns_i

     #
     # Add a comma separated list of layout template ids that should not be
     # allowed in the Nested Portlets Portlet.
     #
     nested.portlets.layout.template.unsupported=freeform,1_column

 ##
 ## Portlet CSS Portlet
 ##

     #
     # Set this to true to enable the ability to modify portlet CSS at runtime
     # via the Look and Feel icon. Disabling it can speed up performance.
     #
     portlet.css.enabled=true

 ##
 ## Shopping Portlet
 ##

     #
     # Set this to true if cart quantities must be a multiple of the item's
     # minimum quantity.
     #
     shopping.cart.min.qty.multiple=true

     #
     # Set this to true to forward to the cart page when adding an item from the
     # category page. The item must not have dynamic fields. All items with
     # dynamic fields will forward to the item's details page regardless of the
     # following setting.
     #
     shopping.category.forward.to.cart=false

     #
     # Set this to true to show special items when browsing a category.
     #
     shopping.category.show.special.items=false

     #
     # Set this to true to show availability when viewing an item.
     #
     shopping.item.show.availability=true

     #
     # Set the maximum file size and valid file extensions for images. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     shopping.image.small.max.size=51200
     shopping.image.medium.max.size=153600
     shopping.image.large.max.size=307200

     #
     # A file extension of * will permit all file extensions.
     #
     shopping.image.extensions=.gif,.jpeg,.jpg,.png

     #
     # Configure email notification settings.
     #
     shopping.email.from.name=Joe Bloggs
     shopping.email.from.address=test@liferay.com

     shopping.email.order.confirmation.enabled=true
     shopping.email.order.confirmation.subject=com/liferay/portlet/shopping/dependencies/email_order_confirmation_subject.tmpl
     shopping.email.order.confirmation.body=com/liferay/portlet/shopping/dependencies/email_order_confirmation_body.tmpl

     shopping.email.order.shipping.enabled=true
     shopping.email.order.shipping.subject=com/liferay/portlet/shopping/dependencies/email_order_shipping_subject.tmpl
     shopping.email.order.shipping.body=com/liferay/portlet/shopping/dependencies/email_order_shipping_body.tmpl

     #
     # Set this to true to enable comments for shopping orders.
     #
     shopping.order.comments.enabled=true

 ##
 ## Software Catalog Portlet
 ##

     #
     # Set the maximum file size and max file dimensions for thumbnnails. A value
     # of 0 for the maximum file size can be used to indicate unlimited file
     # size. However, the maximum file size allowed is set in the property
     # "com.liferay.portal.upload.UploadServletRequestImpl.max.size".
     #
     sc.image.max.size=307200
     sc.image.thumbnail.max.height=200
     sc.image.thumbnail.max.width=160

     #
     # Set this to true to enable comments for software catalog products.
     #
     sc.product.comments.enabled=true

 ##
 ## Tags Compiler Portlet
 ##

     #
     # Set this to true to enable the ability to compile tags from the URL.
     # Disabling it can speed up performance.
     #
     tags.compiler.enabled=true

 ##
 ## Tags Portlet
 ##

     #
     # Input a class name that implements
     # com.liferay.portlet.tags.util.TagsAssetValidator. This class will be
     # called to validate assets. The DefaultTagsAssetValidator class is just an
     # empty class that doesn't actually do any validation.
     # The MinimalTagsAssetValidator requires all assets to have at least one tag
     # entry.
     #
     tags.asset.validator=com.liferay.portlet.tags.util.DefaultTagsAssetValidator
     #tags.asset.validator=com.liferay.portlet.tags.util.MinimalTagsAssetValidator

     #
     # Input a list of comma delimited default properties for new tag entries.
     # Each item of the list should have the following format: 0:key:value
     #
     tags.properties.default=

     #
     # Set the name of the default tag set where new tags are created by default.
     #
     tags.vocabulary.default=Default Tag Set

 ##
 ## Tasks Portlet
 ##

     #
     # Specify the default number of approval stages.
     #
     tasks.default.stages=2

     #
     # Specify the default role name for each stage of approval ordered from
     # lowest level of approval to highest. These Roles must have the
     # APPROVE_PROPOSAL permission.
     #
     tasks.default.role.names=Community Administrator,Community Owner

 ##
 ## Translator Portlet
 ##

     #
     # Set the default languages to translate a given text.
     #
     translator.default.languages=en_es

 ##
 ## Wiki Portlet
 ##

     #
     # Set the name of the default page for a wiki node. The name for the default
     # page must be a valid wiki word. A wiki word follows the format of having
     # an upper case letter followed by a series of lower case letters followed
     # by another upper case letter and another series of lower case letters. See
     # http://www.usemod.com/cgi-bin/wiki.pl?WhatIsaWiki for more information on
     # wiki naming conventions. It is
     #
     wiki.front.page.name=FrontPage

     #
     # Set the name of the default node that will be automatically created when
     # the Wiki portlet is first used in a community.
     #
     wiki.initial.node.name=Main

     #
     # Specify the requirements for the names of wiki pages. By default only a
     # few characters are forbidden. Uncomment the regular expression below to
     # allow only CamelCase titles.
     #
     wiki.page.titles.regexp=([^/\\[\\]%&?@]+)
     #wiki.page.titles.regexp=(((\\p{Lu}\\p{Ll}+)_?)+)

     #
     # Specify the characters that will be automatically removed from the titles
     # when importing wiki pages. This regexp should remove any characters that
     # are forbidden in the regexp specified in the property
     # "wiki.page.titles.regexp".
     #
     wiki.page.titles.remove.regexp=([/\\[\\]%&?@]+)

     #
     # Set this to true to enable ratings for wiki pages.
     #
     wiki.page.ratings.enabled=true

     #
     # Set this to true to enable comments for wiki pages.
     #
     wiki.page.comments.enabled=true

     #
     # Set the list of supported wiki formats and the default wiki format.
     #
     wiki.formats=creole,html
     wiki.formats.default=creole

     #
     # Configure settings for each of the wiki formats.
     #
     wiki.formats.engine[classic_wiki]=com.liferay.portlet.wiki.engines.friki.FrikiEngine
     wiki.formats.configuration.main[classic_wiki]=wiki.transform
     wiki.formats.configuration.interwiki[classic_wiki]=intermap.txt
     wiki.formats.edit.page[classic_wiki]=/html/portlet/wiki/edit/wiki.jsp
     wiki.formats.help.page[classic_wiki]=/html/portlet/wiki/help/classic_wiki.jsp
     wiki.formats.help.url[classic_wiki]=http://wiki.liferay.com/index.php/Wiki_Portlet

     wiki.formats.engine[creole]=com.liferay.portlet.wiki.engines.jspwiki.JSPWikiEngine
     wiki.formats.configuration.main[creole]=jspwiki.properties
     wiki.formats.edit.page[creole]=/html/portlet/wiki/edit/wiki.jsp
     wiki.formats.help.page[creole]=/html/portlet/wiki/help/creole.jsp
     wiki.formats.help.url[creole]=http://www.wikicreole.org/wiki/Creole1.0

     wiki.formats.engine[html]=com.liferay.portlet.wiki.engines.HtmlEngine
     wiki.formats.edit.page[html]=/html/portlet/wiki/edit/html.jsp

     wiki.formats.engine[plain_text]=com.liferay.portlet.wiki.engines.TextEngine
     wiki.formats.edit.page[plain_text]=/html/portlet/wiki/edit/plain_text.jsp

     #
     # Set the list of supported wiki importers.
     #
     wiki.importers=MediaWiki

     #
     # Configure settings for each of the wiki importers.
     #
     wiki.importers.page[MediaWiki]=/html/portlet/wiki/import/mediawiki.jsp
     wiki.importers.class[MediaWiki]=com.liferay.portlet.wiki.importers.mediawiki.MediaWikiImporter

     #
     # Configure email notification settings.
     #
     wiki.email.from.name=Joe Bloggs
     wiki.email.from.address=test@liferay.com

     wiki.email.page.added.enabled=true
     wiki.email.page.added.subject.prefix=com/liferay/portlet/wiki/dependencies/email_page_added_subject_prefix.tmpl
     wiki.email.page.added.body=com/liferay/portlet/wiki/dependencies/email_page_added_body.tmpl
     wiki.email.page.added.signature=com/liferay/portlet/wiki/dependencies/email_page_added_signature.tmpl

     wiki.email.page.updated.enabled=true
     wiki.email.page.updated.subject.prefix=com/liferay/portlet/wiki/dependencies/email_page_updated_subject_prefix.tmpl
     wiki.email.page.updated.body=com/liferay/portlet/wiki/dependencies/email_page_updated_body.tmpl
     wiki.email.page.updated.signature=com/liferay/portlet/wiki/dependencies/email_page_updated_signature.tmpl

     wiki.rss.abstract.length=200