User administration

The User Administration tool has been designed to offer a very complete set of options while keeping it very usable.

This article describes how the new UI can be used and also how it can be customized to a much higher degree than what it used to be possible.

Using the User Administration #

These are the most significant elements of the user administration UI:

Toolbar for top level navigation #

There is a new toolbar located at the top of the users section just below the title “Users”.

This toolbar provides a quick access to the most used functions when working with users:

  • View users → show a list of all the users
  • Add user → show the add user form
  • Custom attributes → management of custom attributes. Only available to users with the Administrator role.
  • Export users → a very simple export functionality to download a CSV file which contains the userId and email address of all the users. Only available to users with the Administrator role.

Searching for users #

The user adminsitration has a very powerful search system powered by Lucene.

By default, the administrator is shown a simple search box to enter some text. That text will be used to search in all of the user's fields (first name, last name, screenname, etc.) and custom attributes.

There is also an advanced search available that allows entering different texts for each of the main user fields. Once an administrator switches to 'advanced search' the user will remember her choice and show the advanced search until she switches back to the simple search.

Editing the user profile #

The user profile of portal is usually complex, with lots of fields and information. It is a challenge to fit all this information into a usable and fast form. To achieve this Liferay's user administration provides a right menu showing all the sections of the form allowing navigating through them in a super fast way that does not require page reload.

Furthermore the menu shows at all times which sections have been modified and are pending a save. This allows making changes to different sections and save everything at once. The "save" and “cancel” have been placed right below the menu so that they are always in the same place independently of how large the form section is so it's easier for users to find it. Also this placement makes it clear that clicking save will save all the changes to any of the sections of the form.

The sections are divided into three categories: Main user info, Identification and Miscellaneous. The following picture shows the three categories and the elements in each of them:

When some data introduced in the form by the user is wrong, it will be shown to the user with a global message at the top of the form and a specific message besides the wrong field. The user is redirected to the section containing the wrong field and the right menu will show the word “Error” besides the name of the section. None of the fields previously filled is lost. When changing the language of a user the dropdown will always show the available locales in the language of the administrator.

Assignment of roles, organizations and communities #

While editing the user profile it's possible to assign roles, organizations and communities to the user without leaving the form. Any change in the assignment of one of those entities will be saved, along with the rest of the form, when the 'Save' button is clicked.

When an administrator edits the profile of a user (assuming he has permission to 'Update' the profile of that user), he will be able to access the sections of the form that shows the Organizations, Communities and Roles of the user. Also he'll be able to assign any organization, communities and roles for which he has the “Assign Members” permission.

There is an important security aspect that has been considered while implementing this functionality. While an administrator may be able to edit a user (for example because he's an administrator of the organization the user belongs to), he should not be able to remove (or even see) certain roles of the edited user that he has no control of. The same applies to organizations and communities.

For that reason the administrator will only see in the list of roles, organisations and communities those that he's allowed to assign (and remove). All others will be invisible to him.

Customizing the User Administration #

The form used for editing or adding users can be completely customized. This customization ranges from the configuring which sections of the form navigation menu are shown to adding custom ones.

Configuring the sections of the user form #

The form sections can be configured through properties at the portal-ext.properties file. The following 3 properties determine which sections are available when creating a new user account:

users.form.add.main=details
users.form.add.identification=
users.form.add.miscellaneous=

Note that those categories that have no sections configured (in the example above that's the case for identification and miscellaneous) won't appear at all in the menu. Also, note that many of the sections, such as password, user associations, roles etc require the user account to exist, so they cannot be used in the above properties. It is possible though to customize those sections or create custom ones that can be used during creation (see below for an explanation of creating new sections).

After the user account has been created the form is expanded to show several additional sections.

[
users.form.my.account.main=details,password,organizations,communities,roles users.form.my.account.identification=websites,instant-messenger,social-network,open-id users.form.my.account.miscellaneous=announcements,display-settings,comments }}}

In this properties we can add the name of the sections we want to show in each section-group separated by commas. For example, if we don't want to show the “websites” section, we would just remove the word websites from users.profile.update.identification. We can also change sections from one group to another or even create new sections.

Creating new sections #

It is possible to add custom new sections to the user form using the extension environment. The following steps detail how to achieve that

  • 1) Choose a name for the section and add it to the desired section in the properties listed above. The name must follow the following rules:
    • It must be lower case
    • If it has several words they should be separated by a dash.
      • Note that the name should never have spaces or non-ascii characters.
      • For example, note that social-network is ok while social_network or social.network are wrong.
  • 2) Create a JSP file which contains the form section. The file must be located in the extension environment in ext-web/docroot/html/portlet/enterprise_admin/user and the name must be the one chosen in the previous step but with underscores instead of dashes (Tip: this change is required to conform to Liferay's own convention of using underscores in the names of the JSPs).
    • For example, the correct jsp file name for the section social-network is social_network.jsp and must be placed in the extension environment in the folder
  • 3) Add a new entry in Language-ext.properties using the name chosen in step 1 as the key and the desired label as the value. Repeat for any languages that are supported in the portal.

Dynamically hiding or showing sections #

In some advanced cases it may be useful to be able to hide or show certain sections based on custom conditions. One simple way to do this is by using jQuery. For example, let's say we want to hide the section "addresses". The following code will do the job:

	<script type="text/javascript">
		jQuery(
			function() {
				jQuery('#addressesLink').parent().hide();
			}
		);
	</script>

The benefit of using JavaScript to do this is that it allows hiding or showing sections when the user changes the value of a certain field in the browser, with no need to do a page refresh.

But sometimes, the condition to show or hide is known in the server and using JavaScript causes the section to be visible for a small period of time while the browser finishes the page loading and then disappears. To solve this Liferay v5.3 has introduced a second mechanism that allows any section JSP to specify that its associated link in the menu or that of any other section should not be included at all. For example:

<%
if (myCustomCondition) {
	request.setAttribute(WebKeys.FORM_NAVIGATOR_SECTION_SHOW + "addresses", Boolean.FALSE);
}
%>

Customizing the fields of any form section #

Each section of the user form has been implemented as a separate JSP template with no business logic so that it can be safely overridden.

All these files have the same name as the section (using hyphens for underscores) and can be found in the following deployment directory:

	/html/portlet/enterprise_admin/user

To modify any of these files copy it to the equivalent directory in the extension environment:

	ext-web/docroot/html/portlet/enterprise_admin/user 

And perform any changes desired.

Customizing the columns of the list of users #

The list of users can also be customized through the extension environment. To do that copy the file: /html/portlet/enterprise_admin/user/search_columns.jspf into:

	ext-web/docroot/html/portlet/enterprise_admin/user 

And perform any changes desired. That file doesn't contain any business logic. It has a taglib invocation for each of the columns making it very easy to change the order or add additional columns. That file provides examples for how to show values of custom attributes in custom columns.

4 附件
123785 查看
平均 (1 投票)
满分为 5,平均得分为 3.0。
评论
讨论主题回复 作者 日期
Hi, this is pretty good. So is here any way how... Milan Jaroš 2009年4月24日 上午3:38
I want to bookmark this article Rafael Cervantes 2009年5月16日 上午8:43
I think the line... Rafael Cervantes 2009年5月18日 上午7:00
Note that while the "My Account" page uses the... Michael Hanisch 2009年7月22日 上午7:08
Made the changes for these lines : ... Paul B. 2009年8月18日 上午8:01
It is pretty good. Thank you, Jorge. Jonas Yuan 2009年8月18日 上午10:26
This is very useful, thanks! However I'm very... Jen Fong 2010年5月19日 下午8:26
its very useful to us Sivachandran Nagendran 2012年4月4日 上午12:35
Hi :-) I customized the user list as described... Stefan Kruppa 2012年5月22日 上午3:11
how about adding new field .. and create new... Arif Rahman 2012年10月8日 上午1:18
Hi Stefan, I am experiencing the same problem.... Alain B 2013年2月21日 下午6:40

Hi,
this is pretty good. So is here any way how to "Configure the sections" for different instances? Thx.
在 09-4-24 上午3:38 发帖。
I want to bookmark this article
在 09-5-16 上午8:43 发帖。
I think the line
users.form.update.main=user-details,password,organizations,communties,roles
s­hould be
users.form.update.main=details,password,organizations,communties,roles
在 09-5-18 上午7:00 发帖。
Note that while the "My Account" page uses the same JSPs as the User administration, the properties for modifying the sections displayed are different (since 5.2.3 - see http://issues.liferay.com/browse/LPS-2470 ).

To modify the sections shown on the "My Account" page, use the following properties:

users.form.my.account.main=${users.form.update.main}
users.form.my.acc­ount.identification=${users.form.update.identification}
users.form.my.account.mis­cellaneous=${users.form.update.miscellaneous}

As you can see it's even possible to reference the config for the user administration pages from the other set of properties!
在 09-7-22 上午7:08 发帖。
Made the changes for these lines :

users.form.my.account.main=details,password,organizations,communities,roles
user­s.form.my.account.identification=websites,instant-messenger,social-network,open-­id
users.form.my.account.miscellaneous=announcements,display-settings,comments
在 09-8-18 上午8:01 发帖以回复 Michael Hanisch
It is pretty good. Thank you, Jorge.
在 09-8-18 上午10:26 发帖。
This is very useful, thanks!

However I'm very new to liferay and I was wondering if anyone out there could help me as to what classes the jsp files in ext-web/docroot/html/portlet/enterprise_admin/user might have access to, and how to add to those. Could I simply define my own classes under ext-impl and let the jsp access them by importing the classes [i.e., com.ext.mypackage.myclass?]?

Also, I see that this wiki was created quite some time ago, so does this still pertain to liferay 5.2.3?
在 10-5-19 下午8:26 发帖。
在 12-4-4 上午12:35 发帖。
Hi :-)

I customized the user list as described above by adding a custom field, looking like this:

<liferay-ui:search-container-column-text
href="<%= rowURL %>"
name="my custom field"
orderable="<%= true %>"
value="<%= StringUtil.valueOf(user2.getExpandoBridge().getAttribute(\"myCustomField\")) %>"
/>

The field is being displayed, but sorting by this field doesn't work (i.e. there is a clickable link and a triangle indicating the sort order but when clicking the link the page refreshes with the sort order remaining the same as before).
Is there something I missed?

I use Liferay 6.1 running on Ubuntu 10.10.

Thanks for your help!
在 12-5-22 上午3:11 发帖以回复 Sivachandran Nagendran
how about adding new field .. and create new form on user jsp section, and new field of database .am i gonna get database field generated by it self ?
在 12-10-8 上午1:18 发帖以回复 Stefan Kruppa
Hi Stefan,

I am experiencing the same problem. Please let me know if you find a solution.
I will do the same

I use Liferay 6.1 running on Glassfish 3.2 Ubuntu 12.04.

Thanks
在 13-2-21 下午6:40 发帖以回复 Stefan Kruppa