/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
// www.projectforge.org
//
// Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de)
//
// ProjectForge is dual-licensed.
//
// This community edition is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published
// by the Free Software Foundation; version 3 of the License.
//
// This community edition is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
// Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, see http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////
package org.projectforge.web.user;
import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Logger;
import org.apache.wicket.request.mapper.parameter.PageParameters;
import org.apache.wicket.spring.injection.annot.SpringBean;
import org.projectforge.ldap.GroupDOConverter;
import org.projectforge.user.GroupDO;
import org.projectforge.user.GroupDao;
import org.projectforge.web.wicket.AbstractEditPage;
import org.projectforge.web.wicket.AbstractSecuredBasePage;
import org.projectforge.web.wicket.EditPage;
import org.projectforge.web.wicket.WicketUtils;
@EditPage(defaultReturnPage = GroupListPage.class)
public class GroupEditPage extends AbstractEditPage<GroupDO, GroupEditForm, GroupDao>
{
/**
* Parameter for pre-defining group name (e. g. used by a wizard for creating new groups).
*/
public static final String PARAM_GROUP_NAME = "groupName";
private static final long serialVersionUID = 4636922408954211544L;
private static final org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger(GroupEditPage.class);
@SpringBean(name = "groupDao")
private GroupDao groupDao;
/**
* Used by the TutorialPage.
* @param group
*/
public GroupEditPage(final GroupDO group)
{
super(new PageParameters(), "group");
super.init(group);
}
public GroupEditPage(final PageParameters parameters)
{
super(parameters, "group");
super.init();
final String groupName = WicketUtils.getAsString(parameters, PARAM_GROUP_NAME);
if (StringUtils.isNotEmpty(groupName) == true) {
getData().setName(groupName);
}
}
@Override
public AbstractSecuredBasePage onSaveOrUpdate()
{
groupDao.setAssignedUsers(getData(), form.assignUsersListHelper.getAssignedItems());
//groupDao.setNestedGroups(getData(), form.nestedGroupsListHelper.getAssignedItems());
if (form.ldapGroupValues.isValuesEmpty() == false) {
final String xml = GroupDOConverter.getLdapValuesAsXml(form.ldapGroupValues);
getData().setLdapValues(xml);
}
return super.onSaveOrUpdate();
}
@Override
protected GroupDao getBaseDao()
{
return groupDao;
}
@Override
protected GroupEditForm newEditForm(final AbstractEditPage< ? , ? , ? > parentPage, final GroupDO data)
{
return new GroupEditForm(this, data);
}
@Override
protected Logger getLogger()
{
return log;
}
}