 This wiki does not contain official documentation and is currently deprecated and read only. Please try reading the documentation on the Liferay Developer Network, the new site dedicated to Liferay documentation.      DISCOVER Build your web site, collaborate with your colleagues, manage your content, and more.   DEVELOP Build applications that run inside Liferay, extend the features provided out of the box with Liferay's APIs.   DISTRIBUTE Let the world know about your app by publishing it in Liferay's marketplace.   PARTICIPATE Become a part of Liferay's community, meet other Liferay users, and get involved in the open source project.
  This wiki does not contain official documentation and is currently deprecated and read only. Please try reading the documentation on the Liferay Developer Network, the new site dedicated to Liferay documentation.      DISCOVER Build your web site, collaborate with your colleagues, manage your content, and more.   DEVELOP Build applications that run inside Liferay, extend the features provided out of the box with Liferay's APIs.   DISTRIBUTE Let the world know about your app by publishing it in Liferay's marketplace.   PARTICIPATE Become a part of Liferay's community, meet other Liferay users, and get involved in the open source project.    « 返回到 Portal Properties  
  Portal Properties 6.0.4
Table of Contents [-]
- Properties Override
- Liferay Home
- Portal Context
- TCK
- Schema
- Upgrade
- Verify
- Convert
- Auto Deploy
- Hot Deploy
- Hot Undeploy
- Sandbox Deploy
- Plugin
- Portlet
- Portlet Coordination
- Theme
- Resource Actions
- Model Hints
- Service Builder
- Spring
- Persistence
- Hibernate
- JPA
- JDBC
- Custom SQL
- Database
- Transaction
- Sharded Databases
- Ehcache
- JavaScript
- SQL Data
- Company
- Users
- Groups and Roles
- Organizations
- Languages and Time Zones
- Look and Feel
- Request
- Session
- JAAS
- Security Manager
- LDAP
- Basic Authentication
- CAS
- Facebook Connect SSO
- NTLM
- OpenID
- OpenSSO
- Request Header Authentication
- SiteMinder
- Authentication Pipeline
- Authentication Token
- Auto Login
- SSO with MAC (Message Authentication Code)
- Passwords
- Permissions
- Captcha
- Startup Events
- Shutdown Events
- Portal Events
- Default Landing Page
- Default Logout Page
- Default Guest Public Layouts
- Default User Private Layouts
- Default User Public Layouts
- Default Admin
- Layouts
- Portlet URL
- Preferences
- Redirect
- Struts
- Images
- Editors
- Fields
- Mime Types
- Amazon
- Browser Launcher
- Control Panel
- Instant Messenger
- Lucene Search
- SourceForge
- Value Object
- Cluster Link
- Cluster Executor
- Combo
- CMIS
- Content Delivery Network
- Counter
- Finalize Manager
- FreeMarker Engine
- Google Apps
- HTTP
- JCR
- Live Users
- Lock
- Mail
- Minifier
- Monitoring
- Multicast
- OpenOffice
- Poller
- POP
- Quartz
- Sanitizer
- Scheduler
- Scripting
- Search Container
- Sharepoint
- Strip
- Social Bookmarks
- Social Equity
- Vaadin
- Velocity Engine
- Virtual Hosts
- JSP
- Servlet Filters
- Upload Servlet Request
- Web Server
- WebDAV
- Main Servlet
- Axis Servlet
- Google Gadget Servlet
- JSON Tunnel Servlet
- Liferay Tunnel Servlet
- Netvibes Servlet
- Spring Remoting Servlet
- WebDAV Servlet
- Widget Servlet
- Admin Portlet
- Announcements Portlet
- Asset
- Asset Publisher Portlet
- Blogs Portlet
- Breadcrumb Portlet
- Calendar Portlet
- Communities Portlet
- Discussion Tag Library
- Document Library Portlet
- Dockbar Portlet
- Flags Portlet
- IFrame Portlet
- Image Gallery Portlet
- Invitation Portlet
- Journal Portlet
- Journal Articles Portlet
- Journal Content Search Portlet
- Login Portlet
- Message Boards Portlet
- My Places Portlet
- Navigation Portlet
- Nested Portlets Portlet
- Portlet CSS Portlet
- Search Portlet
- Shopping Portlet
- Software Catalog Portlet
- Tags Compiler Portlet
- Tasks Portlet
- Translator Portlet
- Wiki Portlet
You can see another [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-companyWebId.properties. To enable this feature, set
    # the "company-id-properties" system property to true.
    #
    # To enable:
    #
    #     java ... -Dcompany-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,\
        com.liferay.portal.upgrade.UpgradeProcess_6_0_0,\
        com.liferay.portal.upgrade.UpgradeProcess_6_0_1,\
        com.liferay.portal.upgrade.UpgradeProcess_6_0_2,\
        com.liferay.portal.upgrade.UpgradeProcess_6_0_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.ConvertDatabase,\
        com.liferay.portal.convert.ConvertDocumentLibrary,\
        com.liferay.portal.convert.ConvertPermissionAlgorithm,\
        com.liferay.portal.convert.ConvertPermissionTuner,\
        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.ExtAutoDeployListener,\
        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.HookExplodedTomcatListener,\
        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.home.dir}/deploy
    auto.deploy.glassfish.dest.dir=${com.sun.aas.instanceRoot}/autodeploy
    auto.deploy.jboss.dest.dir=${jboss.server.home.dir}/deploy
    auto.deploy.jetty.dest.dir=${jetty.home}/webapps
    auto.deploy.jonas.dest.dir=${jonas.base}/deploy
    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://cdn.files.liferay.com/public/quercus/3.1.9/quercus.jar
    library.download.url.resin-util.jar=http://cdn.files.liferay.com/public/quercus/3.1.9/resin-util.jar
    library.download.url.script-10.jar=http://cdn.files.liferay.com/public/quercus/3.1.9/script-10.jar
    #
    # Set the Glassfish settings to enable JSR 88 application deployment.
    #
    auto.deploy.glassfish.jee.deployment.enabled=false
    auto.deploy.glassfish.jee.dm.id=deployer:Sun:AppServer::localhost:4848
    auto.deploy.glassfish.jee.dm.user=admin
    auto.deploy.glassfish.jee.dm.passwd=adminadmin
    auto.deploy.glassfish.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.ExtHotDeployListener,\
        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
Sandbox Deploy#
    #
    # Input a list of comma delimited class names that implement
    # com.liferay.portal.kernel.deploy.sandbox.SandboxDeployListener. These
    # classes are used to process sandbox style plugins.
    #
    sandbox.deploy.listeners=\
        com.liferay.portal.deploy.sandbox.ThemeSandboxDeployListener
    #
    # Set this to true to enable sandbox style plugin development.
    #
    sandbox.deploy.enabled=false
    #
    # Set the directory to scan for sand box style plugins.
    #
    sandbox.deploy.dir=${liferay.home}/sandbox
    #
    # Set the interval in milliseconds on how often to scan the directory for
    # changes.
    #
    sandbox.deploy.interval=10000
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 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
    #
    # Portlets that have configured liferay-portlet.xml with the element
    # "add-default-resource" set to true will allow those portlets to be
    # dynamically added to any page by any user. This is useful
    # (and necessary) for some portlets that need to be dynamically added to a
    # page, but it can also pose a security risk because it also allows any user
    # to do it.
    #
    # Set this property to true to add a security check around this behavior.
    # If set to true, then portlets can only be dynamically added to a page if
    # it contains a proper security token. This security token is automatically
    # passed when using a portlet URL from one portlet to another portlet.
    #
    # Modify the property "portlet.add.default.resource.check.whitelist" to
    # whitelist certain portlets from this security check.
    #
    # The security check utilizes the implementation set in the property
    # "auth.token.impl".
    #
    portlet.add.default.resource.check.enabled=true
    #
    # Set a list of comma delimited list of portlet ids that will bypass the
    # security check set in the property
    # "portlet.add.default.resource.check.enabled".
    #
    portlet.add.default.resource.check.whitelist=58,86,87,88,103,113,145
    #
    # Input a list of comma delimited struts actions that will bypass the
    # security check set in the property
    # "portlet.add.default.resource.check.enabled".
    #
    portlet.add.default.resource.check.whitelist.actions=\
        /journal/rss,\
        /language/view
    #
    # Input a regular expression to ban paths that cannot be used to serve
    # resources in portlets.
    #
    portlet.resource.id.banned.paths.regexp=.*/WEB-INF/.*
Portlet Coordination#
    #
    # Set this property to specify how events are distributed. If the value is
    # "layout-set", then events will be distributed to all portlets contained in
    # a layout set. If the value is "layout", then events will be distributed to
    # all portlets that are present in a layout.
    #
    portlet.event.distribution=layout
    #
    # Set this property to specify how public render parameters are distributed.
    # If the value is "layout-set", then public render parameters will be
    # distributed to all portlets contained in a layout set. This will only work
    # correctly if the property "layout.default.p_l_reset" is set to false. If
    # the value is "layout", then public render parameters will be distributed
    # to all portlets that are present in a layout.
    #
    portlet.public.render.parameter.distribution=layout
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 shortcut icon.
    #
    theme.shortcut.icon=favicon.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
    #
    # This should only be set to false when it is called by Service Builder
    # outside of an application server or servlet container.
    #
    resource.actions.read.portlet.resources=true
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.
    #
    # Note that there is a special case for hibernate-spring.xml and
    # jpa-spring.xml. Even though both files are specified, only one will
    # actually load at runtime based on the property "persistence.provider".
    #
    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/jpa-spring.xml,\
        \
        META-INF/audit-spring.xml,\
        META-INF/cluster-spring.xml,\
        META-INF/editor-spring.xml,\
        META-INF/jcr-spring.xml,\
        META-INF/ldap-spring.xml,\
        META-INF/messaging-core-spring.xml,\
        META-INF/messaging-misc-spring.xml,\
        META-INF/poller-spring.xml,\
        META-INF/rules-spring.xml,\
        META-INF/scheduler-spring.xml,\
        META-INF/scripting-spring.xml,\
        META-INF/search-spring.xml,\
        META-INF/workflow-spring.xml,\
        \
        META-INF/counter-spring.xml,\
        META-INF/document-library-spring.xml,\
        META-INF/mail-spring.xml,\
        META-INF/portal-spring.xml,\
        META-INF/portlet-container-spring.xml,\
        \
        #META-INF/dynamic-data-source-spring.xml,\
        #META-INF/shard-data-source-spring.xml,\
        #META-INF/memcached-spring.xml,\
        #META-INF/monitoring-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
Persistence#
    #
    # Set the provider used for ORM persistence. If this property is set to
    # "jpa", then the properties with the prefix "jpa." will be read. If this
    # property is set to "hibernate", then the properties with the prefix
    # "hibernate." will be read.
    #
    # Note that this property affects the loading of hibernate-spring.xml or
    # jpa-spring.xml in the property "spring.configs".
    #
    persistence.provider=hibernate
    #persistence.provider=jpa
Hibernate#
    #
    # Input a list of comma delimited Hibernate configurations.
    #
    hibernate.configs=\
        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
    #
    # 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
    net.sf.ehcache.configurationResourceName.peerProviderProperties=peerDiscovery=automatic,multicastGroupAddress=${multicast.group.address["hibernate"]},multicastGroupPort=${multicast.group.port["hibernate"]},timeToLive=1
    #
    # 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.
    #
    # If you're using Hypersonic, you SHOULD set the batch size to 0 as a
    # workaround for a logging bug in the Hypersonic driver. See LPS-5426 for
    # more information.
    #
    # 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
JPA#
    #
    # Input a list of comma delimited JPA configurations.
    #
    jpa.configs=\
        META-INF/mail-orm.xml,\
        META-INF/portal-orm.xml
    #
    # Set the name of the JPA provider.
    #
    jpa.provider=eclipselink
    #jpa.provider=hibernate
    #jpa.provider=openjpa
    #jpa.provider=toplink
    #
    # Specify provider specific properties prefixed with "jpa.provider.property."
    #
    jpa.provider.property.eclipselink.allow-zero-id=true
    #jpa.provider.property.eclipselink.logging.level=FINEST
    #jpa.provider.property.eclipselink.logging.timestamp=true
    #
    # The LoadTimeWeaver interface is a Spring class that allows JPA
    # ClassTransformer instances to be plugged in a specific manner depending on
    # the environment.
    #
    # Not all JPA providers require a JVM agent (Hibernate is an example). If
    # your provider does not require an agent or you have other alternatives
    # (such as applying enhancements at build time through a custom compiler or
    # an Ant task), then the loadtime weaver should not be used.
    #
    jpa.load.time.weaver=org.springframework.instrument.classloading.ReflectiveLoadTimeWeaver
    #jpa.load.time.weaver=org.springframework.instrument.classloading.glassfish.GlassFishLoadTimeWeaver
    #jpa.load.time.weaver=org.springframework.instrument.classloading.oc4j.OC4JLoadTimeWeaver
    #jpa.load.time.weaver=org.springframework.instrument.classloading.weblogic.WebLogicLoadTimeWeaver
    #
    # Specify a specific database platform setting if the JPA provider is not
    # able to detect the database platform.
    #
    # Valid values for the Hibernate and OpenJPA providers are: DB2, DERBY,
    # HSQL, INFORMIX, MYSQL, ORACLE, POSTGRESQL, SQL_SERVER, and SYBASE.
    #
    # Valid values for the EclipseLink provider are:
    # org.eclipse.persistence.platform.database.DB2MainframePlatform,
    # org.eclipse.persistence.platform.database.DB2Platform,
    # org.eclipse.persistence.platform.database.DerbyPlatform,
    # org.eclipse.persistence.platform.database.HSQLPlatform,
    # org.eclipse.persistence.platform.database.InformixPlatform,
    # org.eclipse.persistence.platform.database.MySQLPlatform,
    # org.eclipse.persistence.platform.database.OraclePlatform,
    # org.eclipse.persistence.platform.database.PostgreSQLPlatform,
    # org.eclipse.persistence.platform.database.SQLServerPlatform, or
    # org.eclipse.persistence.platform.database.SybasePlatform.
    #
    # Check with JPA provider's documentation for details and all possible
    # values.
    #
    #jpa.database.platform=
    #
    # Liferay will automatically detect the database type by initializing
    # DBUtil. You can override the value here if needed. Expected values are:
    # db2, derby, firebird, hypersonic, informix, ingres, interbase, jdatastore,
    # mysql, oracle, postgresql, sap, sqlserver, and sybase.
    #
    #jpa.database.type=
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". Note that
    # these settings, though separate, are a copy of the default settings with
    # the newly overridden values.
    #
    #
    # DB2
    #
    #jdbc.default.driverClassName=com.ibm.db2.jcc.DB2Driver
    #jdbc.default.url=jdbc:db2://localhost:50000/lportal:deferPrepares=false;fullyMaterializeInputStreams=true;fullyMaterializeLobData=true;progresssiveLocators=2;progressiveStreaming=2;
    #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 can use C3PO, DBCP, or Primrose for connection pooling. See
    # com.liferay.portal.dao.jdbc.util.DataSourceFactoryBean for the actual
    # implementation. It is important to understand the strengths and weaknesses
    # of each provider so that you can choose the best one that fits your
    # deployment scenario. Provider specific properties can also be passed along
    # directly to the provider. For example, the property
    # "jdbc.default.acquireIncrement" is read by C3PO, the property
    # "jdbc.default.maxActive" is read by DBCP, and the property
    # "jdbc.default.base" is read by Primrose.
    #
    # The default provider is C3PO.
    #
    jdbc.default.liferay.pool.provider=c3po
    #jdbc.default.liferay.pool.provider=dbcp
    #jdbc.default.liferay.pool.provider=primrose
    #
    # The following properties will be read by C3PO if Liferay is configured to
    # use C3PO in the property "jdbc.default.liferay.pool.provider". See
    # http://www.mchange.com/projects/c3p0/index.html#configuration for a list
    # of additional fields used by C3PO for configuring database connections.
    #
    jdbc.default.acquireIncrement=5
    jdbc.default.connectionCustomizerClassName=com.liferay.portal.dao.jdbc.pool.c3p0.PortalConnectionCustomizer
    jdbc.default.idleConnectionTestPeriod=60
    jdbc.default.maxIdleTime=3600
    jdbc.default.maxPoolSize=100
    jdbc.default.minPoolSize=10
    jdbc.default.numHelperThreads=3
    #jdbc.default.transactionIsolation=1
    #
    # The following properties will be read by DBCP if Liferay is configured to
    # use DBCP in the property "jdbc.default.liferay.pool.provider". See
    # http://commons.apache.org/dbcp/configuration.html for a list of additional
    # fields used by DBCP for configuring database connections.
    #
    #jdbc.default.defaultTransactionIsolation=READ_UNCOMMITTED
    jdbc.default.maxActive=100
    jdbc.default.minIdle=10
    jdbc.default.removeAbandonedTimeout=3600
    #
    # The following properties will be read by Primrose if Liferay is configured
    # to use Primrose in the property "jdbc.default.liferay.pool.provider". See
    # http://www.primrose.org.uk/primrose3/primroseConfig.html for a list of
    # additional fields used by Primrose for configuring database connections.
    #
    jdbc.default.base=100
    #jdbc.default.connectionTransactionIsolation=TRANSACTION_READ_UNCOMMITTED
    jdbc.default.idleTime=1800000
    jdbc.default.numberOfConnectionsToInitializeWith=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(CONVERT(VARCHAR,?), '1') = '1'
    #custom.sql.function.isnotnull=ISNULL(CONVERT(VARCHAR,?), '1') = '0'
Database#
    #
    # Specify any database vendor specific settings.
    #
    #
    # MySQL
    #
    #
    # Set the MySQL engine type. InnoDB is the recommended engine because it
    # provides transactional integrity.
    #
    database.mysql.engine=InnoDB
Transaction#
    #
    # 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
    #
    # Set the transaction manager. It must be a class that extends
    # org.springframework.transaction.support.AbstractPlatformTransactionManager.
    #
    # The application server specific transaction managers provide XA
    # transactions by leveraging application server specific data sources and
    # thus require additional application server specific configuration. You
    # should not modify this unless you know what you're doing.
    #
    transaction.manager.impl=org.springframework.orm.hibernate3.HibernateTransactionManager
    #transaction.manager.impl=org.springframework.transaction.jta.JtaTransactionManager
    #transaction.manager.impl=org.springframework.transaction.jta.OC4JJtaTransactionManager
    #transaction.manager.impl=org.springframework.transaction.jta.WebLogicJtaTransactionManager
    #transaction.manager.impl=org.springframework.transaction.jta.WebSphereUowTransactionManager
    #
    # Additional properties that follow the pattern
    # "transaction.manager.property.*" will be read to call the setters on the
    # transaction manager. For example, the property
    # "transaction.manager.property.globalRollbackOnParticipationFailure", will
    # call the setter "setGlobalRollbackOnParticipationFailure" on the
    # transaction manager. The list of available setters depends on the
    # implementation specified in the property "transaction.manager.impl".
    #
    # "allowCustomIsolationLevels" should be set to true when using the
    # JtaTransactionManager.
    #
    #transaction.manager.property.allowCustomIsolationLevels=true
    transaction.manager.property.globalRollbackOnParticipationFailure=false
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
    ehcache.multi.vm.config.location.peerProviderProperties=peerDiscovery=automatic,multicastGroupAddress=${multicast.group.address["multi-vm"]},multicastGroupPort=${multicast.group.port["multi-vm"]},timeToLive=1
    #
    # Input a class name that extends
    # net.sf.ehcache.bootstrap.BootstrapCacheLoaderFactory. This class is used
    # by Ehcache to determine how caches communicate with each other in a
    # clustered environment.
    #
    ehcache.bootstrap.cache.loader.factory=net.sf.ehcache.distribution.RMIBootstrapCacheLoaderFactory
    #ehcache.bootstrap.cache.loader.factory=com.liferay.portal.cache.ehcache.JGroupsBootstrapCacheLoaderFactory
    #
    # Input a class name that extends
    # net.sf.ehcache.event.CacheEventListenerFactory. This class is used by
    # Ehcache to determine how caches communicate with each other in a clustered
    # environment.
    #
    ehcache.cache.event.listener.factory=net.sf.ehcache.distribution.RMICacheReplicatorFactory
    #ehcache.cache.event.listener.factory=net.sf.ehcache.distribution.jgroups.JGroupsCacheReplicatorFactory
    #
    # Input a class name that extends
    # net.sf.ehcache.distribution.CacheManagerPeerProviderFactory. This class is
    # used by Ehcache to determine how caches communicate with each other in a
    # clustered environment.
    #
    ehcache.cache.manager.peer.provider.factory=net.sf.ehcache.distribution.RMICacheManagerPeerProviderFactory
    #ehcache.cache.manager.peer.provider.factory=net.sf.ehcache.distribution.jgroups.JGroupsCacheManagerPeerProviderFactory
    #
    # Set this to true to enable JMX integration in
    # com.liferay.portal.cache.EhcachePortalCacheManager. Set this to false if
    # the portal needs to be reloaded under WebSphere.
    #
    ehcache.portal.cache.manager.jmx.enabled=true
    #
    # Set this to true to allow Ehcache to use blocking caches. 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. The blocking cache is no longer implemented by Ehcache's
    # BlockingCache, but by Liferay's BlockingPortalCache for better safety and
    # faster performance.
    #
    ehcache.blocking.cache.allowed=true
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.
    #
    # 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=\
        \
        #
        # YUI core
        #
        \
        aui/yui/yui.js,\
        \
        #
        # YUI modules
        #
        \
        aui/attribute/attribute.js,\
        aui/event-custom/event-custom.js,\
        aui/loader/loader.js,\
        aui/oop/oop.js,\
        \
        #
        # Alloy core
        #
        \
        aui/aui-base/aui-base.js,\
        \
        #
        # Liferay base utility scripts
        #
        \
        liferay/dependency.js,\
        liferay/language.js,\
        liferay/liferay.js,\
        liferay/modules.js,\
        liferay/util.js,\
        \
        #
        # Liferay utility scripts
        #
        \
        liferay/events.js,\
        liferay/portal.js,\
        liferay/portlet.js,\
        liferay/portlet_sharing.js
    #
    # Specify the list of everything files (everything else not already in the
    # list of barebone files).
    #
    javascript.everything.files=\
        \
        #
        # Liferay modules
        #
        \
        liferay/address.js,\
        liferay/layout_configuration.js,\
        liferay/layout_exporter.js,\
        liferay/workflow.js,\
        \
        #
        # Deprecated JS
        #
        \
        liferay/deprecated.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
    #
    # Define the bundle dependencies using any property listed in
    # "javascript.bundle.ids".
    #
    javascript.bundle.dependencies[javascript.everything.files]=javascript.barebone.files
    #
    # 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
    #
    # Set the maximum parameters that a SQL transaction query can contain. Some
    # databases do not allow for more than 2000 paremters in a query.
    #
    sql.data.max.parameters=1000
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. If this is set to true
    # and you want your HTTP session to contain your credentials after logging
    # in, then the property "session.enable.phishing.protection" must be set to
    # false or your credentials will only be available in the HTTPS session.
    #
    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 users to ask the portal to send them a password
    # reset link.
    #
    company.security.send.password.reset.link=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,users,mail-host-names,email-notifications
    company.settings.form.identification=addresses,phone-numbers,additional-email-addresses,websites
    company.settings.form.miscellaneous=display-settings,google-apps
Users#
    #
    # Set this to false if users cannot be deleted.
    #
    users.delete=true
    #
    # Set this to true when you want the validation to allow for creation of
    # numeric screen names.
    #
    users.screen.name.allow.numeric=false
    #
    # Set this to true to always autogenerate user screen names even if the user
    # gives a specific user screen name. If this is set to true, the LDAP
    # importer will fetch users by their email address even if the property
    # "company.security.auth.type" is set to screenName.
    #
    users.screen.name.always.autogenerate=false
    #
    # Input a class name that implements
    # 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.DefaultScreenNameGenerator
    #
    # Input a class name that implements
    # com.liferay.portal.security.auth.ScreenNameValidator. This class will be
    # called to validate user screen names.
    #
    users.screen.name.validator=com.liferay.portal.security.auth.DefaultScreenNameValidator
    #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. An email address will be automatically assigned to a user based
    # on the property "users.email.address.auto.suffix".
    #
    users.email.address.required=true
    #
    # Set the suffix of the email address that will be automatically generated
    # for a user that does not have an email address. This property is not used
    # unless the property "users.email.address.required" is set to false. The
    # autogenerated email address will be the user id plus the specified suffix.
    #
    users.email.address.auto.suffix=@no-emailaddress.com
    #
    # Input a class name that implements
    # com.liferay.portal.security.auth.EmailAddressGenerator. This class will be
    # called to generate an email address for a user that does not specify an
    # email address. This class will only be used if the property
    # "users.email.address.required" is set to false.
    #
    users.email.address.generator=com.liferay.portal.security.auth.DefaultEmailAddressGenerator
    #
    # Input a class name that implements
    # com.liferay.portal.security.auth.FullNameGenerator. This class will be
    # called to generate a full name from the user's first, middle and last names.
    #
    users.full.name.generator=com.liferay.portal.security.auth.DefaultFullNameGenerator
    #
    # Input a class name that implements
    # com.liferay.portal.security.auth.FullNameValidator. This class will be
    # called to validate user first, middle and last names.
    #
    users.full.name.validator=com.liferay.portal.security.auth.DefaultFullNameValidator
    #
    # 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 the maximum user portrait height and width in pixels. A value of 0
    # indicates no restictions on user portrait dimensions.
    #
    users.image.max.height=120
    users.image.max.width=100
    # 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,pages
    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,pages,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-fields
    #
    # 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-fields
    #
    # 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
    #
    # Set this to false to enable users without a reminder query to reset their
    # password.
    #
    users.reminder.queries.required=false
    #
    # 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
    #
    # Set this to true to search users from the index. Set this to false to
    # search users from the database. Note that setting this to false will
    # disable the ability to search users based on Expando attributes.
    #
    users.search.with.index=true
    #
    # Set a property with the prefix "users.update.user.name." and a suffix
    # with the class name that should be updated whenever a user's name has
    # changed.
    #
    users.update.user.name.com.liferay.portlet.messageboards.model.MBMessage=true
    #
    # Input a list of user attributes that will be included when exporting users
    # to a CSV file. You can include custom fields by adding the prefix
    # "expando:" to the attribute name.
    #
    users.export.csv.fields=fullName,emailAddress
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 an 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,pages
    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,pages,categorization
    organizations.form.update.identification=addresses,phone-numbers,additional-email-addresses,websites,services
    organizations.form.update.miscellaneous=comments,reminder-queries,custom-fields
    #
    # 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
    #
    # Set this property to true to allow user groups to be a member of
    # organizations.
    #
    organizations.user.group.membership.enabled=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,bg_BG,ca_AD,ca_ES,zh_CN,zh_TW,cs_CZ,nl_NL,en_US,et_EE,fi_FI,fr_FR,gl_ES,de_DE,el_GR,iw_IL,hi_IN,hu_HU,in_ID,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,uk_UA,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
    #
    # Set this to 0 if the locale is not automatically prepended to a URL. This
    # means that each URL could potentially point to many different languages.
    # For example, the URL http://localhost:8080/web/guest/home could then be
    # viewed by users in many different languages.
    #
    # Set this to 1 if the locale is automatically prepended to a URL when the
    # requested locale is not the default locale. This means that each URL
    # points to just one language. For example, the URL
    # http://localhost:8080/web/guest/home would point to the default language.
    # The URL http://localhost:8080/zh/web/guest/home and
    # http://localhost:8080/zh_CN/web/guest/home would both point to the Chinese
    # language.
    #
    # In cases where the prepended locale is "zh" and not complete locale
    # "zh_CN", then the full locale returned will be based on the order in which
    # the locales appear in the property "locales". If "zh_CN" appears before
    # "zh_TW", then "zh" will be a short hand for "zh_TW".
    #
    # The default language is set in system.properties with the properties
    # "user.country" and "user.language".
    #
    # Set this to 2 if the locale is automatically prepended to every URL. This
    # means that each URL points to just one language.
    #
    # Note that each language requires an entry in the property "locales" and a
    # servlet mapping in web.xml for the I18n Servlet.
    #
    locale.prepend.friendly.url.style=1
    #
    # 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/Caracas,\
        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_
    #
    # Explicitly exclude attributes that are shared from the portal to portlets.
    #
    session.shared.attributes.excludes=USER_PASSWORD
    #
    # Set this to true to store the user's password in the session.
    #
    session.store.password=false
    #
    # 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.
    #
    # Set this to false if the property "company.security.auth.requires.https"
    # is set to true and you want to maintain the same credentials across HTTP
    # and HTTPS sessions.
    #
    session.enable.phishing.protection=true
    #
    # Set a comma delimited list of attribute names that will be copied to the
    # new session when the property "session.enable.phishing.protection" is set
    # to true.
    #
    session.phishing.protected.attributes=HTTPS_INITIAL,LAST_PATH
    #
    # 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 the page size for directory servers that supports paging. This value
    # needs to be 1000 or less for Microsoft Active Directory Server.
    #
    ldap.page.size=1000
    #
    # Set the number of values to return in each query to a multivalued
    # attribute for directory servers that support range retrieval. The range
    # size must be 1000 or less for Windows 2000 and 1500 or less for Windows
    # Server 2003.
    #
    ldap.range.size=1000
    #
    # 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 implements
    # 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.DefaultAttributesTransformer
    #
    # When importing and exporting users, the portal will use this mapping to
    # connect LDAP user attributes and portal contact attributes.
    #
    # See com.liferay.portal.model.ContactModel for a list of attributes.
    #
    ldap.contact.mappings=
    #
    # When importing and exporting users, the portal will use this mapping to
    # connect LDAP user attributes and portal contact's custom attributes.
    #
    ldap.contact.custom.mappings=
    #
    # 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 attributes.
    #
    # See com.liferay.portal.model.UserModel for a list of attributes.
    #
    ldap.user.mappings=uuid=uuid\nscreenName=cn\npassword=userPassword\nemailAddress=mail\nfirstName=givenName\nlastName=sn\njobTitle=title\ngroup=groupMembership
    #
    # When importing and exporting users, the portal will use this mapping to
    # connect LDAP user attributes and portal user's custom attributes.
    #
    ldap.user.custom.mappings=
    #
    # When importing groups, the portal will use this mapping to connect LDAP
    # group attributes and portal user group attributes.
    #
    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, the 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
    #
    # Set this to true if the portal should automatically create a role per
    # group imported from LDAP. The role will be assigned to the group so that
    # users can automatically inherit that role when they are assigned to the
    # group.
    #
    ldap.import.create.role.per.group=false
    #
    # 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
Basic Authentication#
    #
    # Set this to true to require a password when using basic authentication.
    # Only set this to false if additional security measures are in place to
    # ensure users have been properly authenticated.
    #
    basic.auth.password.required=true
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.server.url=https://localhost:8443/cas-web
    cas.service.url=
    #cas.service.url=http://localhost:8080/c/portal/login
Facebook Connect SSO#
    facebook.connect.auth.enabled=false
    facebook.connect.app.id=
    facebook.connect.app.secret=
    facebook.connect.graph.url=https://graph.facebook.com
    facebook.connect.oauth.auth.url=https://graph.facebook.com/oauth/authorize
    facebook.connect.oauth.redirect.url=http://localhost:8080/c/login/facebook_connect_oauth
    facebook.connect.oauth.token.url=https://graph.facebook.com/oauth/access_token
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.controller.name=EXAMPLE
    ntlm.auth.domain=EXAMPLE
    ntlm.auth.service.account=LIFERAY$@EXAMPLE.COM
    ntlm.auth.service.password=test
    #
    # See http://jcifs.samba.org/src/docs/ntlmhttpauth.html for more available
    # properties.
    #
    jcifs.netbios.cachePolicy=30
    jcifs.smb.client.soTimeout=35000
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=givenname
    open.sso.last.name.attr=sn
Request Header Authentication#
    #
    # Set this to true to automatically import users from LDAP if they do not
    # exist in the portal. The property "auto.login.hooks" must contain a
    # referece to the class
    # com.liferay.portal.security.auth.RequestHeaderAutoLogin to enable request
    # header authentication.
    #
    request.header.auth.import.from.ldap=false
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
    #
    # 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=\
        /asset/get_categories,\
        \
        /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/rss,\
        /journal/view_article_content,\
        /journal_articles/view_article_content,\
        \
        /layout_management/sitemap,\
        \
        /login/facebook_connect_oauth,\
        \
        /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/portlet_url,\
        /portal/session_click,\
        /portal/session_tree_js_click,\
        /portal/status,\
        \
        /search/open_search,\
        /search/open_search_description.xml,\
        \
        /shopping/notify,\
        \
        /wiki/find_page,\
        /wiki/get_page_attachment,\
        /wiki/rss
Authentication Token#
    #
    # Set this to true to enable authentication token security checks. The
    # checks can be disabled for specific actions via the property
    # "auth.token.ignore.actions" or for specific portlets via the init
    # parameter "check-auth-token" in portlet.xml.
    #
    auth.token.check.enabled=true
    #
    # Set the authentication token class. This class must implement
    # com.liferay.portal.security.auth.AuthToken. This class is used to prevent
    # CSRF attacks. See http://issues.liferay.com/browse/LPS-8399 for more
    # information.
    #
    auth.token.impl=com.liferay.portal.security.auth.SessionAuthToken
    #
    # Input a list of comma delimited struts actions that will not be checked
    # for an authentication token.
    #
    auth.token.ignore.actions=\
        /asset/rss,\
        \
        /blogs/rss,\
        \
        /document_library/edit_file_entry,\
        \
        /journal/rss,\
        \
        /image_gallery/edit_image,\
        \
        /login/login,\
        \
        /message_boards/rss,\
        \
        /wiki/edit_page_attachment,\
        /wiki/rss
    #
    # Set the shared secret that is used for requests where it is not possible
    # to generate an authentication token (i.e. WSRP).
    #
    auth.token.shared.secret=BAHyWOT9TbPB
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.FacebookAutoLogin,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
    #
    # Set the character sets for password validation.
    #
    passwords.passwordpolicytoolkit.charset.lowercase=abcdefghjkmnpqrstuvwxyz
    passwords.passwordpolicytoolkit.charset.numbers=23456789
    passwords.passwordpolicytoolkit.charset.symbols=_.!@$*=-?
    passwords.passwordpolicytoolkit.charset.uppercase=ABCDEFGHJKLMNPQRSTUVWXYZ
    #
    # 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
    #
    # Set this to true to configure permission caching to block. See the
    # property "ehcache.blocking.cache.allowed" for more information.
    #
    permissions.object.blocking.cache=false
    #
    # 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
    #
    # Set the following to true to automatically check the view permission on
    # parent categories or folders when checking the permission on an specific
    # item.
    # 
    # For example, if set to true, to be able to have access to a
    # document, a user must have the view permission on the document's folder
    # and all its parent folders. Or, to have access to a comment, a user must
    # have the view permission on the comments's category and all its parent
    # categories.
    #
    permissions.view.dynamic.inheritance=true
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
    #
    # Set the engine used to generate captchas. reCAPTCHA uses an external
    # service that must be configured independently but provides an audible
    # alternative which makes the captcha accessible to the visually impaired.
    #
    #captcha.engine.impl=com.liferay.portal.captcha.recaptcha.ReCaptchaImpl
    captcha.engine.impl=com.liferay.portal.captcha.simplecaptcha.SimpleCaptchaImpl
    #
    # reCAPTCHA
    #
    captcha.engine.recaptcha.key.private=
    captcha.engine.recaptcha.key.public=
    captcha.engine.recaptcha.url.script=http://api.recaptcha.net/challenge?k=
    captcha.engine.recaptcha.url.noscript=http://api.recaptcha.net/noscript?k=
    captcha.engine.recaptcha.url.verify=http://api-verify.recaptcha.net/verify
    #
    # SimpleCaptcha
    #
    #
    # Set the height and width for captcha images generated by SimpleCaptcha.
    #
    captcha.engine.simplecaptcha.height=50
    captcha.engine.simplecaptcha.width=150
    #
    # Input a list of comma delimited class names that implement
    # nl.captcha.backgrounds.BackgroundProducer. These classes will be randomly
    # used by SimpleCaptcha to generate a background for a captcha image.
    #
    captcha.engine.simplecaptcha.background.producers=nl.captcha.backgrounds.FlatColorBackgroundProducer,nl.captcha.backgrounds.GradiatedBackgroundProducer,nl.captcha.backgrounds.SquigglesBackgroundProducer,nl.captcha.backgrounds.TransparentBackgroundProducer
    #
    # Input a list of comma delimited class names that implement
    # nl.captcha.gimpy.GimpyRenderer. These classes will be randomly
    # used by SimpleCaptcha to gimp a captcha image.
    #
    #captcha.engine.simplecaptcha.gimpy.renderers=nl.captcha.gimpy.RippleGimpyRenderer
    captcha.engine.simplecaptcha.gimpy.renderers=nl.captcha.gimpy.BlockGimpyRenderer,nl.captcha.gimpy.DropShadowGimpyRenderer,nl.captcha.gimpy.FishEyeGimpyRenderer,nl.captcha.gimpy.RippleGimpyRenderer,nl.captcha.gimpy.ShearGimpyRenderer
    #
    # Input a list of comma delimited class names that implement
    # nl.captcha.noise.NoiseProducer. These classes will be randomly
    # used by SimpleCaptcha to add noise to a captcha image.
    #
    #captcha.engine.simplecaptcha.noise.producers=nl.captcha.noise.CurvedLineNoiseProducer
    captcha.engine.simplecaptcha.noise.producers=nl.captcha.noise.CurvedLineNoiseProducer,nl.captcha.noise.StraightLineNoiseProducer
    #
    # Input a list of comma delimited class names that implement
    # nl.captcha.text.producer.TextProducer. These classes will be randomly
    # used by SimpleCaptcha to generate text for a captcha image.
    #
    captcha.engine.simplecaptcha.text.producers=com.liferay.portal.captcha.simplecaptcha.PinNumberTextProducer
    #captcha.engine.simplecaptcha.text.producers=com.liferay.portal.captcha.simplecaptcha.DictionaryWordTextProducer,com.liferay.portal.captcha.simplecaptcha.PinNumberTextProducer,nl.captcha.text.producer.DefaultTextProducer,nl.captcha.text.producer.FiveLetterFirstNameTextProducer
    #
    # Input a list of comma delimited class names that implement
    # nl.captcha.text.renderer .WordRenderer. These classes will be randomly
    # used by SimpleCaptcha to render text for a captcha image.
    #
    captcha.engine.simplecaptcha.word.renderers=nl.captcha.text.renderer.DefaultWordRenderer
    #captcha.engine.simplecaptcha.word.renderers=nl.captcha.text.renderer.ColoredEdgesWordRenderer,nl.captcha.text.renderer.DefaultWordRenderer
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=
    #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=
    #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=82,23,11
    default.user.private.layout.column-2=29,8
    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,3
    default.user.public.layout.column-2=33
    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
    #
    # Set this to true to remember maximized window states across different
    # pages.
    #
    layout.remember.maximized.window.state=false
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
Redirect#
    #
    # Set this property to "ip" or "domain" for the redirect security method. If
    # set to "domain", the portal will only redirect users to domains listed in
    # the property "redirect.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 "redirect.url.ip.allowed".
    #
    #redirect.url.security.mode=domain
    redirect.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.
    #
    redirect.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.
    #
    redirect.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.kernel.image.Hook. The portal will use this persist
    # images.
    #
    #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: ckeditor, fckeditor, liferay, simple,
    # tinymce, or tinymcesimple.
    #
    editor.wysiwyg.default=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.blogs.edit_entry.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.calendar.edit_configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.enterprise_admin.view.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.invitation.edit_configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_article_content.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_article_content_xsd_el.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.journal.edit_configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.login.configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.mail.edit.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.mail.edit_message.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.message_boards.edit_configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.shopping.edit_configuration.jsp=ckeditor
    editor.wysiwyg.portal-web.docroot.html.portlet.wiki.edit.html.jsp=ckeditor
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
    #
    # Input a list of comma delimited user types who can edit their own fields.
    # Valid types are "administrator", "user-mx", and "user-without-mx".
    #
    # Set a value of "administrator" if an administrator can edit the specified
    # field. An administrator is anyone who has the Administrator role.
    #
    # Set a value of "user-mx" if a user who has an email address that matches
    # the company mail suffix can edit the specified field.
    #
    # Set a value of "user-without-mx" if a user who does not have an email
    # address that matches the company mail suffix can edit the specified field.
    #
    # Set all three values if all users can edit the specified field. Set a
    # combination of the three values if only a combination of the users can
    # edit the specified field.
    #
    field.editable.com.liferay.portal.model.User.screenName=administrator,user-with-mx,user-without-mx
    field.editable.com.liferay.portal.model.User.emailAddress=administrator,user-with-mx,user-without-mx
Mime Types#
    #
    # 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
    #
    # Set the name of a class that implements
    # com.liferay.portlet.ControlPanelEntry. This class denotes the default
    # value of of the element "control-panel-entry-class" in liferay-portlet.xml
    # and is called by the Control Panel to decide whether the portlet should be
    # shown to a specific user in a specific context.
    #
    control.panel.default.entry.class=com.liferay.portlet.DefaultControlPanelEntry
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 the limit for results used when performing index searches that are
    # subsequently filtered by permissions.
    #
    index.filter.search.limit=5000
    #
    # 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 to index your entire library of files after
    # an upgrade. Only set this property to false if you are running a small
    # upgrade and you do not need to reindex everything.
    #
    index.on.upgrade=true
    #
    # 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 regularly. See LEP-2180.
    #
    #lucene.store.jdbc.auto.clean.up.enabled=true
    #
    # Set the interval on which the lucene automatic clean up is set run. The
    # value is set in one minute increments.
    #
    lucene.store.jdbc.auto.clean.up.interval=1440
    #
    # 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.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 how often index updates will be committed. Set the batch size to
    # configure how many consecutive updates will trigger a commit. If the value
    # is 0, then the index will be committed on every update. Set the time
    # interval in milliseconds to configure how often to commit the index. The
    # time interval is not read unless the batch size is greater than 0 because
    # the time interval works in conjunction with the batch size to guarantee
    # that the index is committed after a specified time interval. Set the time
    # interval to 0 to disable committing the index by a time interval.
    #
    lucene.commit.batch.size=0
    lucene.commit.time.interval=0
    #
    # Set Lucene's buffer size in megabytes. Higher numbers mean indexing goes
    # faster but uses more memory.
    #
    lucene.buffer.size=16
    #
    # 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
    #
    # Set this to true if you want the portal to replicate an index write across
    # all members of the cluster. This is useful in some clustered environments
    # where you wish each server instance to have its own copy of the Lucene
    # search index. This is only relevant when using the default Lucene indexing
    # engine.
    #
    lucene.replicate.write=false
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
    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. See the
    # property "ehcache.blocking.cache.allowed" 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
    value.object.entity.cache.enabled.com.liferay.portlet.social.model.SocialEquityAssetEntry=false
    value.object.entity.cache.enabled.com.liferay.portlet.social.model.SocialEquityLog=false
    value.object.entity.cache.enabled.com.liferay.portlet.social.model.SocialEquityUser=false
    #
    # 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. See the
    # property "ehcache.blocking.cache.allowed" 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.com.liferay.portlet.social.model.SocialEquityAssetEntry=false
    value.object.finder.cache.enabled.com.liferay.portlet.social.model.SocialEquityLog=false
    value.object.finder.cache.enabled.com.liferay.portlet.social.model.SocialEquityUser=false
    value.object.finder.cache.enabled.Users_Roles=true
Cluster Link#
    #
    # Set this to true to enable the cluster link. This is required if you want
    # to cluster indexing and other features that depend the cluster link.
    #
    cluster.link.enabled=false
    #
    # Set the JGroups properties for each channel, we support up to 10 transport
    # channels and 1 single required control channel. Use as few transport
    # channels as possible for best performance. By default, only one UDP
    # control channel and one UDP transport channel are enabled. Channels can be
    # configured by XML files that are located in the class path or by inline
    # properties.
    #
    cluster.link.channel.properties.control=UDP(bind_addr=localhost;mcast_addr=${multicast.group.address["cluster-link-control"]};mcast_port=${multicast.group.port["cluster-link-control"]};ip_ttl=8;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)
    cluster.link.channel.properties.transport.0=UDP(bind_addr=localhost;mcast_addr=${multicast.group.address["cluster-link-udp"]};mcast_port=${multicast.group.port["cluster-link-udp"]};ip_ttl=8;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)
    #cluster.link.channel.properties.transport.1=udp.xml
    #cluster.link.channel.properties.transport.2=mping.xml
    #
    # Set JGroups' system properties. System properties have higher priority
    # than individual properties given to each channel. That means system
    # properties will override individual properties.
    #
    cluster.link.channel.system.properties=\
        #
        # Common
        #
        \
        jgroups.bind_addr:localhost,\
        #jgroups.bind_interface:eth0,\
        \
        #
        # Multicast
        #
        \
        jgroups.mping.mcast_addr:${multicast.group.address["cluster-link-mping"]},\
        jgroups.mping.mcast_port:${multicast.group.port["cluster-link-mping"]},\
        jgroups.mping.ip_ttl:8
    #
    # Set this property to autodetect the default outgoing IP address so that
    # JGroups can bind to it. The property must point to an address that is
    # accessible to the portal server, www.google.com or your local gateway.
    #
    cluster.link.autodetect.address=www.google.com:80
Cluster Executor#
    #
    # Set this to true to enable the cluster executor debugging. This will
    # attach a debugging listener which will log every cluster event it
    # receives.
    #
    cluster.executor.debug.enabled=false
Combo#
    #
    # The combo servlet combines multiple JavaScript files into a bundle based
    # on shared dependencies. This makes loading JavaScript files much faster.
    # Set this to false if the combination should refresh when one of its
    # JavaScript files has changed. This property should be set to true during
    # development for easier debugging but set to false during production for
    # faster performance.
    #
    combo.check.timestamp=false
CMIS#
    cmis.credentials.username=none
    cmis.credentials.password=none
    cmis.repository.url=http://localhost:8080/alfresco/service/api/cmis
    #cmis.repository.version=0.61
    cmis.repository.version=1.0
    cmis.system.root.dir=Liferay Home
Content Delivery Network#
    #
    # Set the hostname that will be used to serve static content via a CDN for
    # requests made over the HTTP protocol. This property can be overridden
    # dynamically at runtime by setting the URL parameter "cdn_host". The value
    # must always include the full protocol.
    #
    cdn.host.http=
    #
    # Set the hostname that will be used to serve static content via a CDN for
    # requests made over the HTTPS protocol. This property can be overridden
    # dynamically at runtime by setting the URL parameter "cdn_host". The value
    # must always include the full protocol.
    #
    cdn.host.https=
Counter#
    #
    # The counter operates with is own data source to prevent deadlocks. By
    # default, the data source created for the counter uses the same settings as
    # those used to create the data source used for the rest of the portal. That
    # happens by because the counter service will look up the properties
    # prefixed with "jdbc.default." to create its data source. See the JDBC
    # properties prefixed with "jdbc.default." for more information.
    #
    # Setting a different value for the counter JDBC prefix allows you to better
    # fine tune the counter data source with its own set of configuration
    # settings for high availability installations. Note that these settings,
    # though separate, are a copy of the default settings with the newly
    # overridden values.
    #
    counter.jdbc.prefix=jdbc.default.
    #
    # 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
    #
    # You can further fine tune the counter increment for specific counter
    # names. This entry will ensure that the counter name
    # "com.liferay.portal.model.Layout" or anything that starts with
    # "com.liferay.portal.model.Layout#" will only increment by 1.
    #
    counter.increment.com.liferay.portal.model.Layout=1
Finalize Manager#
    #
    # Set this to true to enable the finalize manager to use a separate thread
    # to do clean up. Otherwise, finalize manager will only do clean up during
    # registration.
    #
    finalize.manager.thread.enabled=false
FreeMarker Engine#
    freemarker.engine.cache.storage=com.liferay.portal.freemarker.LiferayCacheStorage
    freemarker.engine.localized.lookup=false
    freemarker.engine.modification.check.interval=60
    #
    # Exception handler can have it's value a class name implementing FreeMarker
    # TemplateExceptionHandler or rethrow, debug, debug_html, ignore
    #
    freemarker.engine.template.exception.handler=rethrow
    #
    # Input a list of comma delimited class names that extend
    # com.liferay.portal.freemarker.FreeMarkerTemplateLoader. These classes will
    # run in sequence to allow you to find the applicable TemplateLoader
    # to load a FreeMarker template.
    #
    freemarker.engine.template.loaders=com.liferay.portal.freemarker.ServletTemplateLoader,com.liferay.portal.freemarker.JournalTemplateLoader,com.liferay.portal.freemarker.ThemeLoaderTemplateLoader
    #
    # Input a list of comma delimited macros that will be loaded. These files
    # must exist in the class path.
    #
    freemarker.engine.macro.library=FTL_liferay.ftl as liferay
Google Apps#
    #
    # Set the default user name and password for Google Apps integration. The
    # domain used by Google Apps is retrieved from the portal's mail domain.
    # See http://code.google.com/apis/apps for more information.
    #
    # Google Apps integration is not used unless the property "mail.hook.impl"
    # is set with the value "com.liferay.mail.util.GoogleHook".
    #
    google.apps.username=
    google.apps.password=
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
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.
    #
    #
    # Locks for document library folders and files should expire after 1 day.
    #
    lock.expiration.time.com.liferay.portlet.documentlibrary.model.DLFolder=86400000
    lock.expiration.time.com.liferay.portlet.documentlibrary.model.DLFileEntry=86400000
    #
    # Locks for message board threads should never expire.
    #
    lock.expiration.time.com.liferay.portlet.messageboards.model.MBThread=0
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.
    #
    #mail.hook.impl=com.liferay.mail.util.CyrusHook
    mail.hook.impl=com.liferay.mail.util.DummyHook
    #mail.hook.impl=com.liferay.mail.util.FuseMailHook
    #mail.hook.impl=com.liferay.mail.util.GoogleHook
    #mail.hook.impl=com.liferay.mail.util.SendmailHook
    #mail.hook.impl=com.liferay.mail.util.ShellHook
    #
    # 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=
    #
    # GoogleHook
    #
    # See the properties "google.apps.username" and "google.apps.password".
    #
    #
    # 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
Minifier#
    #
    # The strip filter will attempt to cache inline minified CSS and JavaScript
    # content. Set this property configure the maximum pieces of cached content.
    # Set this property to 0 to disable caching of inline minified content.
    #
    minifier.inline.content.cache.size=10000
    #
    # Input a list of comma delimited values that will cause the minified CSS to
    # not be cached if those values are contained in the content.
    #
    minifier.inline.content.cache.skip.css=
    #
    # Input a list of comma delimited values that will cause the minified
    # JavaScript to not be cached if those values are contained in the content.
    #
    minifier.inline.content.cache.skip.javascript=getSessionId,encryptedUserId
Monitoring#
    #
    # Configure the appropriate level for monitoring Liferay.
    # Valid values are: HIGH, LOW, MEDIUM, OFF.
    #
    monitoring.level.com.liferay.monitoring.Portal=HIGH
    monitoring.level.com.liferay.monitoring.Portlet=HIGH
    #
    # Set this to true to store data samples of the current request as a thread
    # local variable. This allows you to obtain each request's statistics for
    # further processing
    #
    monitoring.data.sample.thread.local=false
    #
    # Set this to true to monitor portal requests.
    #
    monitoring.portal.request=false
    #
    # Set this to true to monitor portlet action requests.
    #
    monitoring.portlet.action.request=false
    #
    # Set this to true to monitor portlet event requests.
    #
    monitoring.portlet.event.request=false
    #
    # Set this to true to monitor portlet render requests.
    #
    monitoring.portlet.render.request=false
    #
    # Set this to true to monitor portlet resource requests.
    #
    monitoring.portlet.resource.request=false
    #
    # Set this to true to show data samples at the bottom of each portal page.
    # In order for data to show, the property
    # "monitoring.data.sample.thread.local" must be set to true.
    #
    monitoring.show.per.request.data.sample=false
Multicast#
    #
    # Consolidate multicast address and port settings in one location for easier
    # maintenance. These settings must correlate to your physical network
    # configuration (i.e. firewall, switch, and other network hardware matter)
    # to ensure speedy and accurate communication across a cluster.
    #
    # Each address and port combination represent a conversation that is made
    # between different nodes. If they are not unique or correctly set, there
    # will be a potential of unnecessary network traffic that may cause slower
    # updates or inaccurate updates.
    #
    #
    # See the property "cluster.link.channel.properties.control".
    #
    multicast.group.address["cluster-link-control"]=233.0.0.1
    multicast.group.port["cluster-link-control"]=23301
    #
    # See the properties "cluster.link.channel.properties.transport.0" and
    # "cluster.link.channel.system.properties".
    #
    multicast.group.address["cluster-link-udp"]=233.0.0.2
    multicast.group.port["cluster-link-udp"]=23302
    #
    # See the property "cluster.link.channel.system.properties".
    #
    multicast.group.address["cluster-link-mping"]=233.0.0.3
    multicast.group.port["cluster-link-mping"]=23303
    #
    # See the properties "net.sf.ehcache.configurationResourceName" and
    # "net.sf.ehcache.configurationResourceName.peerProviderProperties".
    #
    multicast.group.address["hibernate"]=233.0.0.4
    multicast.group.port["hibernate"]=23304
    #
    # See the properties "ehcache.multi.vm.config.location" and
    # "ehcache.multi.vm.config.location.peerProviderProperties".
    #
    multicast.group.address["multi-vm"]=233.0.0.5
    multicast.group.port["multi-vm"]=23305
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
Poller#
    #
    # Specify the poller request timeout in milliseconds. This prevents the
    # poller from locking up the application server.
    #
    poller.request.timeout=1000
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 POPNotificationsMessageListener 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=com.liferay.portal.scheduler.quartz.PortalJobStore
    org.quartz.jobStore.dataSource=ds
    org.quartz.jobStore.isClustered=false
    org.quartz.jobStore.misfireThreshold=60000
    org.quartz.jobStore.tablePrefix=QUARTZ_
    org.quartz.jobStore.useProperties=false
    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
Sanitizer#
    #
    # Set the name of a class that implements
    # com.liferay.portal.kernel.sanitizer.Sanitizer. This class is used to
    # sanitize content.
    #
    sanitizer.impl=com.liferay.portal.sanitizer.DummySanitizerImpl
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=
Scripting#
    #
    # Input a list of comma delimited class names that will never be available
    # to user defined server side scripts. The special string "all_classes"
    # disables access to any Java class. This property is only effective when
    # using the Scripting service and invoking eval or exec methods.
    #
    scripting.forbidden.classes=com.liferay.portal.kernel.scripting.ScriptingUtil,com.liferay.portal.scripting.ScriptingImpl,java.lang.System
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
    #
    # Set the maximum number of pages available above and below the currently
    # displayed page.
    #
    search.container.page.iterator.max.pages=25
    #
    # Set this to false to remove the pagination controls above or below
    # results.
    #
    search.container.show.pagination.top=true
    search.container.show.pagination.bottom=true
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
Strip#
    #
    # Enter a list of comma delimited paths that should not have its content
    # stripped by the strip filter.
    #
    strip.ignore.paths=/document_library/get_file
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}
Social Equity#
    #
    # Set the interval on which the CheckEquityLogMessageListener will run. The
    # value is set in one minute increments.
    #
    social.equity.equity.log.check.interval=1440
    #
    # Set this to true to enable social equity logs.
    #
    social.equity.equity.log.enabled=true
Vaadin#
    #
    # Specify the location of the portal wide Vaadin themes and widget set
    # (client side JavaScript).
    #
    vaadin.resources.path=/html
    #
    # Specify the base Vaadin theme to load automatically for all Vaadin
    # portlets. A portlet can include an additional theme that is loaded after
    # the shared theme.
    #
    vaadin.theme=reindeer
    #
    # Specify the shared widget set (client side JavaScript) that is used by all
    # Vaadin portlets running in the portal.
    #
    vaadin.widgetset=com.vaadin.portal.gwt.PortalDefaultWidgetSet
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 extensions that will be ignored for virtual hosts.
    #
    virtual.hosts.ignore.extensions=\
        /c,\
        .css,\
        .gif,\
        .image/company_logo,\
        .ico,\
        .js,\
        .jpeg,\
        .jsp,\
        .png,\
        /portal/layout,\
        /portal/login,\
        /portal/logout
    #
    # 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
    #
    # Specify the community name that will default to the company's virtual
    # host. If the specified community has a virtual host, then that will take
    # precedence. If it does not, then it will use the company's virtual host.
    # This property is useful to remove "/web/guest" (or any other community)
    # from the default URL. For example, if this property is not set, then the
    # default URL may be http://localhost:8080/web/guest/home. If this property
    # is set, then the default URL may be http://localhost:8080/home.
    #
    virtual.hosts.default.community.name=Guest
JSP#
    #
    # Set the JspWriter buffer size. JspFactoryWrapper reads this value as the
    # buffer size when creating new JspWriters. This value should be kept at 0
    # for performance reasons.
    #
    jsp.writer.buffer.size=0
Servlet Filters#
    #
    # The audit filter populates the AuditRequestThreadLocal with the
    # appropriate request values to generate audit requests.
    #
    com.liferay.portal.servlet.filters.audit.AuditFilter=false
    #
    # The auto login filter processes the classes in the property
    # "auto.login.hooks" to provide auto login functionality.
    #
    com.liferay.portal.servlet.filters.autologin.AutoLoginFilter=true
    #
    # 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
    #
    # The CAS filter is used to provide CAS based single sign on.
    #
    com.liferay.portal.servlet.filters.sso.cas.CASFilter=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
    #
    # The ETag filter is used to generate ETag headers.
    #
    com.liferay.portal.servlet.filters.etag.ETagFilter=true
    #
    # 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 I18n filter is used to internationalize URLs. See the property
    # "locale.prepend.friendly.url.style" for more information.
    #
    com.liferay.portal.servlet.filters.i18n.I18nFilter=true
    #
    # The Language filter replaces JavaScript code that make a client side call
    # to translate a piece of text with the actual translated value. For
    # example, a typical piece of JavaScript code fits the pattern
    # "Liferay.Language.get('key')" where 'key' is the text to translate. This
    # filter will replace the entire piece of code with the translated text.
    # This is very useful because it will lower the number of client calls by
    # translating the text before the browser receives the JavaScript file.
    #
    com.liferay.portal.servlet.filters.language.LanguageFilter=true
    #
    # The minifier filter is used to minify CSS and JavaScript.
    #
    com.liferay.portal.servlet.filters.minifier.MinifierFilter=true
    #
    # The monitoring filter monitors portal request performance.
    #
    com.liferay.portal.servlet.filters.monitoring.MonitoringFilter=true
    #
    # The NTLM filter is used to provide NTLM based single sign on.
    #
    com.liferay.portal.servlet.filters.sso.ntlm.NtlmFilter=true
    #
    # The NTLM post filter is used to fix known issues with NTLM and ajax
    # requests. See LPS-3795.
    #
    com.liferay.portal.servlet.filters.sso.ntlm.NtlmPostFilter=true
    #
    # The OpenSSO filter is used to provide OpenSSO based single sign on.
    #
    com.liferay.portal.servlet.filters.sso.opensso.OpenSSOFilter=true
    #
    # The secure filter is used to protect servlets based on IP and protocol.
    # See the properties "*.servlet.hosts.allowed" and
    # "*.servlet.https.required".
    #
    com.liferay.portal.servlet.filters.secure.SecureFilter=true
    #
    # The servlet authorizing filter allows external servlets to be authorized
    # by the portal. See LEP-4682.
    #
    com.liferay.portal.servlet.filters.servletauthorizing.ServletAuthorizingFilter=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 Sharepoint filter allows users to access documents in the Document
    # Library directly from Microsoft Office using the Sharepoint protocol.
    #
    com.liferay.portal.sharepoint.SharepointFilter=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 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.themepreview.ThemePreviewFilter=false
    #
    # The thread local filter cleans up registered thread locals to prevent
    # memory leaks. Register your thread local with
    # com.liferay.portal.kernel.util.ThreadLocalRegistry.
    #
    com.liferay.portal.servlet.filters.threadlocal.ThreadLocalFilter=true
    #
    # The valid HTML filter will move JavaScript that is outside of the closing
    # body tag to its proper place inside the body tag. Most sites will prefer
    # to leave this filter disabled because having JavaScript outside of the
    # body tag causes the page to render faster. However, the side effect is
    # that it will also make the site unaccessible to screen readers because the
    # HTML is technically invalid. Setting this property to true optimizes for
    # accessibility while setting this property to false optimzes for browser
    # performance.
    #
    com.liferay.portal.servlet.filters.validhtml.ValidHtmlFilter=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 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 that are
    # associated with newly created users.
    #
    admin.default.group.names=
    #
    # Input a list of default role names separated by \n characters that are
    # associated with newly created users.
    #
    admin.default.role.names=Power User\nUser
    #
    # Input a list of default user group names separated by \n characters that
    # are associated with newly created users.
    #
    admin.default.user.group.names=
    #
    # Set this to true to ensure that a user is synchronized with the default
    # associations of groups, roles, and user groups upon every login. Set this
    # to false if default associations should only be applied to a user when a
    # user is created.
    #
    admin.sync.default.associations=false
    #
    # 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.reset.subject=com/liferay/portlet/admin/dependencies/email_password_reset_subject.tmpl
    admin.email.password.reset.body=com/liferay/portlet/admin/dependencies/email_password_reset_body.tmpl
    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 CheckEntryMessageListener will run. The
    # value is set in one minute increments.
    #
    announcements.entry.check.interval=15
Asset#
    #
    # Input a list of comma delimited default properties for new categories.
    # Each item of the list should have the following format: "key:value".
    #
    asset.categories.properties.default=
    #
    # Set the following to false to specify that searching and browsing using
    # categories should only show assets that have been assigned the selected
    # category explicitly. When set to true, the children categories are also
    # included in the search.
    #
    asset.categories.search.hierarchical=true
    #
    # Set this to true to enable incrementing the view counter for assets.
    #
    asset.entry.increment.view.counter.enabled=true
    # Input a class name that implements
    # com.liferay.portlet.asset.util.AssetEntryValidator. This class will be
    # called to validate entries. The DefaultAssetEntryValidator class is just
    # an empty class that doesn't actually do any validation. The
    # MinimalAssetEntryValidator requires all enties to have at least one tag.
    #
    asset.entry.validator=com.liferay.portlet.asset.util.DefaultAssetEntryValidator
    #asset.entry.validator=com.liferay.portlet.asset.util.MinimalAssetEntryValidator
    #
    # Input a list of comma delimited default tag properties for new tags. Each
    # item of the list should have the following format: "key:value".
    #
    asset.tag.properties.default=
    #
    # Set the name of the default vocabulary which will be created by default.
    #
    asset.vocabulary.default=Topic
    #
    # Set a property with the prefix "asset.renderer.enabled." and a suffix
    # with the asset renderer factory class name to enable or disable an asset
    # renderer factory. The default setting is true. See LPS-6085 for more
    # information.
    #
    #asset.renderer.enabled.com.liferay.portlet.documentlibrary.asset.DLFileEntryAssetRendererFactory=false
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.from.name=Joe Bloggs
    blogs.email.from.address=test@liferay.com
    blogs.email.entry.added.enabled=true
    blogs.email.entry.added.subject=com/liferay/portlet/blogs/dependencies/email_entry_added_subject.tmpl
    blogs.email.entry.added.body=com/liferay/portlet/blogs/dependencies/email_entry_added_body.tmpl
    blogs.email.entry.updated.enabled=true
    blogs.email.entry.updated.subject=com/liferay/portlet/blogs/dependencies/email_entry_updated_subject.tmpl
    blogs.email.entry.updated.body=com/liferay/portlet/blogs/dependencies/email_entry_updated_body.tmpl
    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 the excerpt length for linkbacks.
    #
    blogs.linkback.excerpt.length=200
    #
    # Set the interval on which the LinkbackMessageListener will run. The value
    # is set in one minute increments.
    #
    blogs.linkback.job.interval=5
    #
    # Set this to true to enable pingbacks.
    #
    blogs.pingback.enabled=true
    #
    # Set this to true to enable trackbacks.
    #
    blogs.trackback.enabled=true
    #
    # 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
    #
    # Set this to true to enable previous and next navigation for blogs entries.
    #
    blogs.entry.previous.and.next.navigation.enabled=true
Breadcrumb Portlet#
    #
    # Set this to true to show the Guest community as the top level parent in
    # the breadcrumbs. It will only show if it has at least one page.
    #
    breadcrumb.show.guest.group=true
    #
    # Set this to true to show the path of parent communities or organizations
    # in the breadcrumbs. An community or organization will only be shown if it
    # has at least one page.
    #
    breadcrumb.show.parent.groups=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 CheckEventMessageListener will run. The
    # value is set in one minute increments.
    #
    calendar.event.check.interval=15
    #
    # Set this to true to enable comments for calendar events.
    #
    calendar.event.comments.enabled=true
    #
    # 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#
    #
    # Set this to true to allow community members to see the Communities portlet
    # and the communities he is a member of in the Control Panel. Setting this
    # to false will only allow administrators to see this portlet in the Control
    # Panel.
    #
    communities.control.panel.members.visible=true
    #
    # 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.
    #
    #dl.hook.impl=com.liferay.documentlibrary.util.AdvancedFileSystemHook
    #dl.hook.impl=com.liferay.documentlibrary.util.CMISHook
    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
    #
    # JCRHook
    #
    dl.hook.jcr.fetch.delay=500
    dl.hook.jcr.fetch.max.failures=5
    #
    # 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.
    #
    dl.file.extensions=*
    #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 this to false to allow users to update file entries by uploading a
    # file with an extension different from the one of the originally uploaded
    # file. There is a known issue where setting this to true will break OSX
    # compatibility. See LPS-10770 for more information.
    #
    dl.file.extensions.strict.check=false
    #
    # Set the maximum file size for indexing file contents. Files larger than
    # this property will not have their contents indexed, only their metadata
    # will be indexed. A value of -1 indicates that all file contents will be
    # indexed. A value of 0 indicates that no file contents will be indexed.
    #
    dl.file.indexing.max.size=10485760
    #
    # 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/file_system/small/doc.gif.
    #
    dl.file.icons=.bmp,.css,.doc,.docx,.dot,.gif,.gz,.htm,.html,.jpeg,.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 the read count for document library files.
    #
    dl.file.entry.read.count.enabled=true
    #
    # Set this to true to enable file rank for document library files.
    #
    dl.file.rank.enabled=true
    #
    # Set this to true if document library should be published to live by
    # default.
    #
    dl.publish.to.live.by.default=true
    #
    # Set this to true to hold the lock when an unlock is requested through
    # WebDAV until a user manually releases the lock from the Document Library
    # portlet. Set this to false to release the lock.
    #
    dl.webdav.hold.lock=false
    #
    # Set this to true to create only one document library file version when
    # saving multiple times during a WebDAV session.
    #
    dl.webdav.save.to.single.version=false
Dockbar Portlet#
    #
    # Set the portlet ids that will be shown directly in the "Add Application"
    # menu.
    #
    dockbar.add.portlets=56,101,110,71
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
IFrame Portlet#
    #
    # Specify a role name that a user must be associated with in order to
    # configure the IFrame portlet to use the @password@ token. This token is
    # used to post the password of users who access this portlet in order to
    # automatically login to the framed site.
    #
    # No role is required by default. However, it is recommended that you
    # specify a role in high security environments where users who configure
    # this portlet may attempt password theft. See LPS-5272 for more
    # information.
    #
    iframe.password.token.role=
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
    #
    # Set this to true if image gallery should be published to live by default.
    #
    ig.publish.to.live.by.default=true
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 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 a list of custom tokens that will be replaced when article content is
    # rendered. For example, if set to "custom_token_1", then "@custom_token_1@"
    # will be replaced with its token value before an article is displayed.
    #
    #journal.article.custom.tokens=custom_token_1,custom_token_2
    #journal.article.custom.token.value[custom_token_1]=This is the first custom token.
    #journal.article.custom.token.value[custom_token_2]=This is the second custom token.
    #
    # Set the token used when inserting simple page breaks in articles.
    #
    journal.article.token.page.break=@page_break@
    #
    # Set the interval on which the CheckArticleMessageListener 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
    #
    # Set the language types available for templates.
    #
    journal.template.language.types=css,ftl,vm,xsl
    #
    # Set the location of the default content for each language type.
    #
    journal.template.language.content[css]=com/liferay/portlet/journal/dependencies/template.css
    journal.template.language.content[ftl]=com/liferay/portlet/journal/dependencies/template.ftl
    journal.template.language.content[vm]=com/liferay/portlet/journal/dependencies/template.vm
    journal.template.language.content[xsl]=com/liferay/portlet/journal/dependencies/template.xsl
    #
    # Set the parser for each language type. A parser is only needed for
    # language types that require parsing. The classes must implement
    # com.liferay.portlet.journal.util.TemplateParser.
    #
    journal.template.language.parser[css]=
    journal.template.language.parser[ftl]=com.liferay.portlet.journal.util.FreeMarkerTemplateParser
    journal.template.language.parser[vm]=com.liferay.portlet.journal.util.VelocityTemplateParser
    journal.template.language.parser[xsl]=com.liferay.portlet.journal.util.XSLTemplateParser
    #
    # Input a comma delimited list of variables which are restricted from the
    # context in FreeMarker based Journal templates.
    #
    journal.template.freemarker.restricted.variables=serviceLocator
    #
    # 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.added.enabled=false
    journal.email.article.added.subject=com/liferay/portlet/journal/dependencies/email_article_added_subject.tmpl
    journal.email.article.added.body=com/liferay/portlet/journal/dependencies/email_article_added_body.tmpl
    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
    journal.email.article.updated.enabled=false
    journal.email.article.updated.subject=com/liferay/portlet/journal/dependencies/email_article_updated_subject.tmpl
    journal.email.article.updated.body=com/liferay/portlet/journal/dependencies/email_article_updated_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.freemarker=com/liferay/portlet/journal/dependencies/error.ftl
    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 this
    # property or the property "message.boards.expire.ban.job.interval" to 0 to
    # disable auto expire.
    #
    message.boards.expire.ban.interval=10
    #message.boards.expire.ban.interval=0
    #
    # Set this to true to enable pingbacks.
    #
    message.boards.pingback.enabled=true
    message.boards.rss.abstract.length=200
    #
    # Set this to true to enable previous and next navigation for message boards
    # threads
    #
    message.boards.thread.previous.and.next.navigation.enabled=true
    #
    # 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 the display style for the My Places navigation menu.
    #
    my.places.display.style=simple
    #my.places.display.style=classic
    #
    # 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
Search Portlet#
    #
    # Set any of these to false to disable the portlet from being searched by
    # the Search portlet.
    #
    com.liferay.portlet.blogs.util.BlogsOpenSearchImpl=true
    com.liferay.portlet.bookmarks.util.BookmarksOpenSearchImpl=true
    com.liferay.portlet.calendar.util.CalendarOpenSearchImpl=true
    com.liferay.portlet.directory.util.DirectoryOpenSearchImpl=true
    com.liferay.portlet.documentlibrary.util.DLOpenSearchImpl=true
    com.liferay.portlet.imagegallery.util.IGOpenSearchImpl=true
    com.liferay.portlet.journal.util.JournalOpenSearchImpl=true
    com.liferay.portlet.messageboards.util.MBOpenSearchImpl=true
    com.liferay.portlet.wiki.util.WikiOpenSearchImpl=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 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
Tasks Portlet#
    #
    # Specify the default number of approval stages.
    #
    tasks.default.stages=1
    #
    # 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[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  34070 查看 
 