Commit a351f20e authored by Gabriel Guardincerri's avatar Gabriel Guardincerri Committed by gguardin

[CS-3691] Use Social Groups as the backend of the shared groups

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@10222 b35dd754-fafc-0310-a699-88a17e54d16e
parent 914ead40
......@@ -902,6 +902,8 @@ group.edit.update_user=User(s) updated successfully.
group.edit.update_success=Group created successfully.
group.edit.not_update=User(s) not added successfully.
group.edit.share_title=Contact List (Roster) Sharing
group.edit.share_status_disabled=Contact list group sharing is disabled
group.edit.share_status_enabled=Contact list group sharing is enebled
group.edit.share_content=You can use the form below to automatically add this group to users' contact \
lists. <strong>By default</strong>, <em>this group will only appear in the contact lists of the \
group's members.</em>. However, you can share this group with all users or members of other groups.
......
......@@ -10,12 +10,10 @@
*/
package org.jivesoftware.openfire.clearspace;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node;
import org.jivesoftware.openfire.XMPPServer;
import static org.jivesoftware.openfire.clearspace.ClearspaceManager.HttpType.*;
import static org.jivesoftware.openfire.clearspace.ClearspaceManager.HttpType.GET;
import static org.jivesoftware.openfire.clearspace.WSUtils.getReturn;
import static org.jivesoftware.openfire.clearspace.WSUtils.parseStringArray;
import org.jivesoftware.openfire.group.Group;
......@@ -23,10 +21,8 @@ import org.jivesoftware.openfire.group.GroupAlreadyExistsException;
import org.jivesoftware.openfire.group.GroupNotFoundException;
import org.jivesoftware.openfire.group.GroupProvider;
import org.jivesoftware.openfire.user.UserNotFoundException;
import org.jivesoftware.util.Log;
import org.xmpp.packet.JID;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
......@@ -35,104 +31,38 @@ import java.util.List;
* @author Daniel Henninger
*/
public class ClearspaceGroupProvider implements GroupProvider {
protected static final String URL_PREFIX = "groupService/";
protected static final String URL_PREFIX = "socialGroupService/";
private Boolean readOnly;
private static final String TYPE_ID_OWNER = "0";
private static final String TYPE_ID_MEMBER = "1";
public ClearspaceGroupProvider() {
}
public Group createGroup(String name) throws UnsupportedOperationException, GroupAlreadyExistsException {
// Check if this operation is supported
if (isReadOnly()) {
throw new UnsupportedOperationException("Could not create groups.");
}
try {
String path = URL_PREFIX + "groups";
// Creates the XML with the data
Document groupDoc = DocumentHelper.createDocument();
Element rootE = groupDoc.addElement("createGroup");
Element nameE = rootE.addElement("name");
nameE.addText(name);
rootE.addElement("description");
Element group = ClearspaceManager.getInstance().executeRequest(POST, path, groupDoc.asXML());
return translateGroup(group);
} catch (GroupAlreadyExistsException gaee) {
throw gaee;
} catch (Exception e) {
// It is not supported exception, wrap it into an UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
}
public void deleteGroup(String name) throws UnsupportedOperationException {
// Check if this operation is supported
if (isReadOnly()) {
throw new UnsupportedOperationException("Could not delete groups.");
}
try {
long groupID = ClearspaceManager.getInstance().getGroupID(name);
String path = URL_PREFIX + "groups/" + groupID;
ClearspaceManager.getInstance().executeRequest(DELETE, path);
} catch (GroupNotFoundException gnfe) {
Log.error(gnfe);
// it is ok, the group doesn't exist "anymore"
} catch (Exception e) {
// It is not supported exception, wrap it into an UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
}
public Group getGroup(String name) throws GroupNotFoundException {
return translateGroup(getGroupByName(name));
}
public void setName(String oldName, String newName) throws UnsupportedOperationException, GroupAlreadyExistsException {
try {
Element group = getGroupByName(oldName);
WSUtils.modifyElementText(group, "name", newName);
String path = URL_PREFIX + "groups";
ClearspaceManager.getInstance().executeRequest(PUT, path);
} catch (GroupNotFoundException gnfe) {
Log.error(gnfe);
// no further action required
} catch (Exception e) {
// It is not supported exception, wrap it into a UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
throw new UnsupportedOperationException("Could not modify groups.");
}
public void setDescription(String name, String description) throws GroupNotFoundException {
try {
Element group = getGroupByName(name);
WSUtils.modifyElementText(group, "description", description);
String path = URL_PREFIX + "groups";
ClearspaceManager.getInstance().executeRequest(PUT, path);
} catch (GroupNotFoundException gnfe) {
Log.error(gnfe);
// no further action required
} catch (Exception e) {
// It is not supported exception, wrap it into a UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
throw new UnsupportedOperationException("Could not modify groups.");
}
public int getGroupCount() {
try {
String path = URL_PREFIX + "groupCount";
String path = URL_PREFIX + "socialGroupCount";
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
return Integer.valueOf(getReturn(element));
} catch (Exception e) {
......@@ -143,7 +73,7 @@ public class ClearspaceGroupProvider implements GroupProvider {
public Collection<String> getGroupNames() {
try {
String path = URL_PREFIX + "groupNames";
String path = URL_PREFIX + "socialGroupNames";
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
return parseStringArray(element);
......@@ -155,7 +85,7 @@ public class ClearspaceGroupProvider implements GroupProvider {
public Collection<String> getGroupNames(int startIndex, int numResults) {
try {
String path = URL_PREFIX + "groupNamesBounded/" + startIndex + "/" + numResults;
String path = URL_PREFIX + "socialGroupNamesBounded/" + startIndex + "/" + numResults;
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
return parseStringArray(element);
......@@ -168,7 +98,7 @@ public class ClearspaceGroupProvider implements GroupProvider {
public Collection<String> getGroupNames(JID user) {
try {
long userID = ClearspaceManager.getInstance().getUserID(user);
String path = URL_PREFIX + "userGroupNames/" + userID;
String path = URL_PREFIX + "userSocialGroupNames/" + userID;
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
return parseStringArray(element);
......@@ -181,99 +111,19 @@ public class ClearspaceGroupProvider implements GroupProvider {
}
public void addMember(String groupName, JID user, boolean administrator) throws UnsupportedOperationException {
try {
long userID = ClearspaceManager.getInstance().getUserID(user);
long groupID = ClearspaceManager.getInstance().getGroupID(groupName);
String path = URL_PREFIX;
Document groupDoc = DocumentHelper.createDocument();
Element rootE;
if (administrator) {
rootE = groupDoc.addElement("addAdministratorToGroup");
path += "groupAdmins";
} else {
rootE = groupDoc.addElement("addMemberToGroup");
path += "groupMembers";
}
Element nameE = rootE.addElement("userID");
nameE.addText(String.valueOf(userID));
rootE.addElement("groupID");
nameE.addText(String.valueOf(groupID));
ClearspaceManager.getInstance().executeRequest(POST, path, groupDoc.asXML());
} catch (GroupNotFoundException e) {
throw new UnsupportedOperationException("Group not found", e);
} catch (UserNotFoundException e) {
throw new UnsupportedOperationException("User not found", e);
} catch (Exception e) {
// It is not supported exception, wrap it into an UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
throw new UnsupportedOperationException("Could not modify groups.");
}
public void updateMember(String groupName, JID user, boolean administrator) throws UnsupportedOperationException {
deleteMember(groupName, user);
addMember(groupName, user, administrator);
throw new UnsupportedOperationException("Could not modify groups.");
}
public void deleteMember(String groupName, JID user) throws UnsupportedOperationException {
long userID;
long groupID;
try {
userID = ClearspaceManager.getInstance().getUserID(user);
groupID = ClearspaceManager.getInstance().getGroupID(groupName);
} catch (GroupNotFoundException e) {
// It's ok, that not existing group doesn't contains that memeber, :)
return;
} catch (UserNotFoundException e) {
// It's ok, that group doesn't contains that not existing memeber, :)
return;
} catch (Exception e) {
// It is not supported exception, wrap it into an UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
//Another try catch because it is going to remove it two times, one for admin and one
//for user. Therefore one of them could throw an exception.
try {
String path = URL_PREFIX + "groupAdmins/" + groupID + "/" + userID;
ClearspaceManager.getInstance().executeRequest(DELETE, path);
path = URL_PREFIX + "groupMembers/" + groupID + "/" + userID;
ClearspaceManager.getInstance().executeRequest(DELETE, path);
} catch (GroupNotFoundException e) {
//won't happend, the group exist
} catch (UserNotFoundException e) {
//won't happend, the user exist
} catch (Exception e) {
// It is not supported exception, wrap it into an UnsupportedOperationException
throw new UnsupportedOperationException("Unexpected error", e);
}
throw new UnsupportedOperationException("Could not modify groups.");
}
public boolean isReadOnly() {
if (readOnly == null) {
loadReadOnly();
}
// If it is null returns the most restrictive anwser.
return (readOnly == null ? false : readOnly);
}
private void loadReadOnly() {
try {
// See if the is read only
String path = URL_PREFIX + "isReadOnly";
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
readOnly = Boolean.valueOf(getReturn(element));
} catch (Exception e) {
// if there is a problem, keep it null, maybe in the next call succes.
}
return true;
}
public Collection<String> search(String query) {
......@@ -288,80 +138,110 @@ public class ClearspaceGroupProvider implements GroupProvider {
return false;
}
/**
* Translate a XML respose of a group to a <code>Group</code>.
*
* @param responseNode the XML representation of a CS group.
* @return the group that corresponds to the XML.
*/
private Group translateGroup(Element responseNode) {
Node groupNode = responseNode.selectSingleNode("return");
// Get the name, description and id of the group
String name = null;
String description = null;
long id = -1;
// Gets the CS DISPLAY NAME that is OF NAME
String name = groupNode.selectSingleNode("displayName").getText();
// Gets the group name
name = groupNode.selectSingleNode("name").getText();
// Gets the CS NAME that is OF DISPLAY NAME
String displayName = groupNode.selectSingleNode("name").getText();
// Gets the group ID
id = Long.parseLong(groupNode.selectSingleNode("ID").getText());
long id = Long.parseLong(groupNode.selectSingleNode("ID").getText());
// Gets the group type
int type = Integer.parseInt(groupNode.selectSingleNode("typeID").getText());
// Gets the group description if it exist
String description = null;
Node tmpNode = groupNode.selectSingleNode("description");
if (tmpNode != null) {
description = tmpNode.getText();
}
// Get the members and administrators
Collection<JID> members = null;
Collection<JID> administrators = null;
Collection<JID> members = new ArrayList<JID>();
Collection<JID> administrators = new ArrayList<JID>();
try {
members = getGroupMembers(id, false);
administrators = getGroupMembers(id, true);
XMPPServer server = XMPPServer.getInstance();
// Gets the JID from the response
List<Element> membersElement = (List<Element>) getGroupMembers(id).elements("return");
for (Element memberElement : membersElement) {
String username = memberElement.element("user").element("username").getText();
String typeID = memberElement.element("typeID").getText();
if (TYPE_ID_OWNER.equals(typeID)) {
administrators.add(server.createJID(username, null));
} else if (TYPE_ID_MEMBER.equals(typeID)) {
members.add(server.createJID(username, null));
} else {
// nothing to do, waiting for approval
}
}
} catch (GroupNotFoundException e) {
// this won't happen, the group exists.
}
// Creates the group
return new Group(name, description, members, administrators);
Group group = new Group(name, description, members, administrators);
// Type 0 is OPEN
if (type == 0) {
group.getProperties().put("sharedRoster.showInRoster", "everybody");
} else {
// Types 1, 2 or 3 are MEMBER_ONLY, PRIVATE, SECRET
group.getProperties().put("sharedRoster.showInRoster", "onlyGroup");
}
group.getProperties().put("sharedRoster.displayName", displayName);
group.getProperties().put("sharedRoster.groupList", "");
return group;
}
/**
* Returns a group by its name.
*
* @param name the name of the group to retrive.
* @return the group.
* @throws GroupNotFoundException if a group with that name doesn't exist or there is a problem getting it.
*/
private Element getGroupByName(String name) throws GroupNotFoundException {
try {
String path = URL_PREFIX + "groups/" + URLEncoder.encode(name, "UTF-8");
String path = URL_PREFIX + "socialGroupsByName/" + name;
return ClearspaceManager.getInstance().executeRequest(GET, path);
} catch (GroupNotFoundException gnfe) {
// It is a supported exception, throw it again
throw gnfe;
} catch (Exception e) {
// It is not supported exception, wrap it into a GroupNotFoundException
throw new GroupNotFoundException("Unexpected error", e);
}
}
private Collection<JID> getGroupMembers(long groupID, boolean admin) throws GroupNotFoundException {
/**
* Returns the all the members of the group. It continas the onwers and the members of the group.
*
* @param groupID the group id to return the members of.
* @return all the members of the group.
* @throws GroupNotFoundException if the groups doesn't exist or there is a problem getting the members.
*/
private Element getGroupMembers(long groupID) throws GroupNotFoundException {
try {
XMPPServer server = XMPPServer.getInstance();
Collection<JID> members = new ArrayList<JID>();
// Gets the members or administrators
// Gets the members and administrators
String path = null;
if (admin) {
path = URL_PREFIX + "groupAdmins/" + groupID;
} else {
path = URL_PREFIX + "groupMembers/" + groupID;
}
path = URL_PREFIX + "members/" + groupID;
Element element = ClearspaceManager.getInstance().executeRequest(GET, path);
// Gets the JID from the response
List<Node> users = (List<Node>) element.selectNodes("return");
for (Node user : users) {
String username = user.selectSingleNode("username").getText();
members.add(server.createJID(username, null));
}
return members;
} catch (GroupNotFoundException gnfe) {
// It is a supported exception, throw it again
throw gnfe;
return element;
} catch (Exception e) {
// It is not supported exception, wrap it into a GroupNotFoundException
throw new GroupNotFoundException("Unexpected error", e);
......
......@@ -30,6 +30,7 @@ import org.jivesoftware.openfire.container.BasicModule;
import org.jivesoftware.openfire.group.GroupNotFoundException;
import org.jivesoftware.openfire.muc.spi.MultiUserChatServiceImpl;
import org.jivesoftware.openfire.net.MXParser;
import org.jivesoftware.openfire.session.ComponentSession;
import org.jivesoftware.openfire.user.UserNotFoundException;
import org.jivesoftware.util.*;
import org.jivesoftware.util.cache.Cache;
......@@ -105,6 +106,8 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
exceptionMap.put("com.jivesoftware.base.GroupNotFoundException", "org.jivesoftware.openfire.group.GroupNotFoundException");
exceptionMap.put("com.jivesoftware.base.GroupAlreadyExistsException", "org.jivesoftware.openfire.group.GroupAlreadyExistsException");
exceptionMap.put("org.acegisecurity.BadCredentialsException", "org.jivesoftware.openfire.auth.UnauthorizedException");
exceptionMap.put("com.jivesoftware.base.UnauthorizedException", "org.jivesoftware.openfire.auth.UnauthorizedException");
exceptionMap.put("com.jivesoftware.community.NotFoundException", "org.jivesoftware.util.NotFoundException");
}
private ConfigClearspaceTask configClearspaceTask;
......@@ -342,6 +345,37 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
return false;
}
/**
* Returns true if Openfire is connected to Clearspace.
* This method may delay some time since it has to ping Clearspace to know if
* Openfire is able to connect to it.
*
* @return true if Openfire is connected to Clearspace.
*/
public Boolean isOpenfireConnected() {
return testConnection();
}
/**
* Returns true if Clearspce is connected to Openfire.
*
* @return true if Clearspce is connected to Openfire.
*/
public Boolean isClearspaceConnected() {
XMPPServer server = XMPPServer.getInstance();
if (server == null) {
return false;
}
Collection<ComponentSession> componentSessions = server.getSessionManager().getComponentSessions();
for (ComponentSession cs : componentSessions) {
// All Clearspace sessions start with "clearspace"
if (cs.getAddress().getDomain().startsWith("clearspace")) {
return true;
}
}
return false;
}
/**
* Returns the Clearspace service URI; e.g. <tt>https://localhost:80/clearspace</tt>.
* This value is stored as the Jive Property <tt>clearspace.uri</tt>.
......@@ -545,6 +579,15 @@ public class ClearspaceManager extends BasicModule implements ExternalComponentM
}
}
/**
* Returns true if Clerspace was configured at least one time since Openfire startup.
*
* @return true if Clerspace was configured at least one time since Openfire startup.
*/
public boolean isClearspaceConfigured() {
return configClearspaceTask == null;
}
private List<String> getServerInterfaces() {
List<String> bindInterfaces = new ArrayList<String>();
......
......@@ -81,7 +81,7 @@ public class GroupAdminAdded extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
GroupEventDispatcher.dispatchEvent(group, GroupEventDispatcher.EventType.admin_added, params);
......
......@@ -81,7 +81,7 @@ public class GroupAdminRemoved extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
GroupEventDispatcher.dispatchEvent(group, GroupEventDispatcher.EventType.admin_removed, params);
......
......@@ -63,7 +63,7 @@ public class GroupCreated extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
Map<String, Object> params = Collections.emptyMap();
......
......@@ -63,7 +63,7 @@ public class GroupDeleting extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
Map<String, Object> params = Collections.emptyMap();
......
......@@ -81,7 +81,7 @@ public class GroupMemberAdded extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
GroupEventDispatcher.dispatchEvent(group, GroupEventDispatcher.EventType.member_added, params);
......
......@@ -81,7 +81,7 @@ public class GroupMemberRemoved extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
GroupEventDispatcher.dispatchEvent(group, GroupEventDispatcher.EventType.member_removed, params);
......
......@@ -113,7 +113,7 @@ public class GroupModified extends AdHocCommand {
// Sends the event
Group group;
try {
group = GroupManager.getInstance().getGroup(groupname);
group = GroupManager.getInstance().getGroup(groupname, true);
// Fire event.
GroupEventDispatcher.dispatchEvent(group, GroupEventDispatcher.EventType.group_modified, params);
......
......@@ -448,6 +448,11 @@ public class Group implements Cacheable, Externalizable {
synchronized (keyString.intern()) {
if (properties.containsKey(keyString)) {
String originalValue = properties.get(keyString);
// if is the same value don't update it.
if (originalValue != null && originalValue.equals(value)) {
return value;
}
answer = properties.put(keyString, (String)value);
updateProperty(keyString, (String)value);
// Configure event.
......
......@@ -13,6 +13,7 @@
package org.jivesoftware.openfire.group;
import org.jivesoftware.openfire.XMPPServer;
import org.jivesoftware.openfire.clearspace.ClearspaceManager;
import org.jivesoftware.openfire.event.GroupEventDispatcher;
import org.jivesoftware.openfire.event.GroupEventListener;
import org.jivesoftware.openfire.event.UserEventDispatcher;
......@@ -70,6 +71,15 @@ public class GroupManager {
GroupEventDispatcher.addListener(new GroupEventListener() {
public void groupCreated(Group group, Map params) {
// Adds default properties if they don't exists, since the creator of
// the group could set them.
if (group.getProperties().get("sharedRoster.showInRoster") == null) {
group.getProperties().put("sharedRoster.showInRoster", "nobody");
group.getProperties().put("sharedRoster.displayName", "");
group.getProperties().put("sharedRoster.groupList", "");
}
// Since the group could be created by the provider, add it possible again
groupCache.put(group.getName(), group);
......@@ -244,7 +254,21 @@ public class GroupManager {
* @throws GroupNotFoundException if the group does not exist.
*/
public Group getGroup(String name) throws GroupNotFoundException {
Group group = groupCache.get(name);
return getGroup(name, false);
}
/**
* Returns a Group by name.
*
* @param name The name of the group to retrieve
* @return The group corresponding to that name
* @throws GroupNotFoundException if the group does not exist.
*/
public Group getGroup(String name, boolean forceLookup) throws GroupNotFoundException {
Group group = null;
if (!forceLookup) {
group = groupCache.get(name);
}
// If ID wan't found in cache, load it up and put it there.
if (group == null) {
synchronized (name.intern()) {
......@@ -425,6 +449,16 @@ public class GroupManager {
return provider.isReadOnly();
}
/**
* Returns true if properties of groups are read only.
* They are read only if Clearspace is the group provider.
*
* @return true if properties of groups are read only.
*/
public boolean isPropertyReadOnly() {
return ClearspaceManager.isEnabled();
}
/**
* Returns true if searching for groups is supported.
*
......
......@@ -9,16 +9,16 @@
- agreement with Jive.
--%>
<%@ page import="org.jivesoftware.util.Log,
org.jivesoftware.util.ParamUtils,
org.jivesoftware.openfire.group.Group,
org.jivesoftware.openfire.group.GroupAlreadyExistsException"
<%@ page import="org.jivesoftware.openfire.group.Group,
org.jivesoftware.openfire.group.GroupAlreadyExistsException,
org.jivesoftware.openfire.security.SecurityAuditManager,
org.jivesoftware.util.Log"
errorPage="error.jsp"
%>
<%@ page import="org.jivesoftware.util.ParamUtils"%>
<%@ page import="java.net.URLEncoder"%>
<%@ page import="java.util.HashMap"%>
<%@ page import="java.util.Map"%>
<%@ page import="org.jivesoftware.openfire.security.SecurityAuditManager" %>
<%@ page import="java.util.Map" %>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jstl/fmt_rt" prefix="fmt" %>
......@@ -61,10 +61,6 @@
newGroup.setDescription(description);
}
newGroup.getProperties().put("sharedRoster.showInRoster", "nobody");
newGroup.getProperties().put("sharedRoster.displayName", "");
newGroup.getProperties().put("sharedRoster.groupList", "");
if (!SecurityAuditManager.getSecurityAuditProvider().blockGroupEvents()) {
// Log the event
webManager.logEvent("created new group "+name, "description = "+description);
......@@ -161,6 +157,12 @@
</div><br>
<% } %>
<% if (webManager.getGroupManager().isReadOnly()) { %>
<div class="error">
<fmt:message key="group.read_only"/>
</div>
<% } %>
<p>
<%
// If editing the group.
......@@ -273,5 +275,19 @@
document.f.name.focus();
</script>
<% // Disable the form if a read-only user provider.
if (webManager.getGroupManager().isReadOnly()) { %>
<script language="Javascript" type="text/javascript">
function disable() {
var limit = document.forms[0].elements.length;
for (i=0;i<limit;i++) {
document.forms[0].elements[i].disabled = true;
}
}
disable();
</script>
<% } %>
</body>
</html>%>
\ No newline at end of file
......@@ -9,24 +9,24 @@
- agreement with Jive.
--%>
<%@ page import="org.jivesoftware.stringprep.Stringprep,
org.jivesoftware.util.LocaleUtils,
org.jivesoftware.util.Log,
org.jivesoftware.util.ParamUtils,
org.jivesoftware.openfire.PresenceManager,
<%@ page import="org.jivesoftware.openfire.PresenceManager,
org.jivesoftware.openfire.group.Group,
org.jivesoftware.openfire.group.GroupManager"
org.jivesoftware.openfire.group.GroupManager,
org.jivesoftware.openfire.security.SecurityAuditManager,
org.jivesoftware.openfire.user.User,
org.jivesoftware.openfire.user.UserManager,
org.jivesoftware.openfire.user.UserNotFoundException"
%>
<%@ page import="org.jivesoftware.openfire.user.User"%>
<%@ page import="org.jivesoftware.openfire.user.UserManager"%>
<%@ page import="org.jivesoftware.openfire.user.UserNotFoundException"%>
<%@ page import="org.jivesoftware.stringprep.Stringprep"%>
<%@ page import="org.jivesoftware.util.LocaleUtils"%>
<%@ page import="org.jivesoftware.util.Log"%>
<%@ page import="org.jivesoftware.util.ParamUtils"%>
<%@ page import="org.xmpp.packet.JID"%>
<%@ page import="org.xmpp.packet.Presence"%>
<%@ page import="java.io.UnsupportedEncodingException"%>
<%@ page import="java.net.URLDecoder"%>
<%@ page import="java.net.URLEncoder"%>
<%@ page import="java.util.*"%>
<%@ page import="org.jivesoftware.openfire.security.SecurityAuditManager" %>
<%@ page import="java.util.*" %>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jstl/fmt_rt" prefix="fmt" %>
......@@ -255,6 +255,12 @@
</head>
<body>
<% if (webManager.getGroupManager().isReadOnly() && webManager.getGroupManager().isPropertyReadOnly()) { %>
<div class="error">
<fmt:message key="group.read_only"/>
</div>
<% } %>
<p>
<fmt:message key="group.edit.form_info" />
</p>
......@@ -339,6 +345,16 @@
</div>
<div class="jive-contentBox">
<% if (webManager.getGroupManager().isPropertyReadOnly()) { %>
<p>
<% if (enableRosterGroups) { %>
<fmt:message key="group.edit.share_status_enabled" />
<% } else { %>
<fmt:message key="group.edit.share_status_disabled" />
<% } %>
</p>
<% } else { %>
<p>
<fmt:message key="group.edit.share_content" />
</p>
......@@ -444,8 +460,7 @@
</tr>
</tbody>
</table>
<% } %>
</div>
<!-- END contact list settings -->
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment