
« Voltar para Portal Properties
Portal Properties 6.0.3
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,\ \ # # TCP # \ jgroups.tcpping.initial_hosts:localhost[7800],localhost[7801] # # 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= # # 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
34764 Visualizações