Commit aa03ff5e authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Added statistics.

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@3841 b35dd754-fafc-0310-a699-88a17e54d16e
parent fd99960a
......@@ -166,6 +166,11 @@
## Removed key: 'group.summary.list_group'
## Removed key: 'session.summary.info'
## Removed key: 'user.summary.info'
##
## 3.0.0
## Added key: 'startup.multiplexer'
## Added section: 'muc.stats..*'
## Removed key: 'pubsub.form.authorization.node'
# Wildfire
......@@ -291,6 +296,7 @@ startup.starting.muc=Multi User Chat domain: {0}
startup.caches=Initializing caches
startup.channels=Initializing channels
startup.server=Started server (unencrypted) socket on port: {0}
startup.multiplexer=Started multiplexer (unencrypted) socket on port: {0}
startup.component=Started component (unencrypted) socket on port: {0}
startup.plain=Started plain (unencrypted) socket on port: {0}
startup.ssl=Started SSL (encrypted) socket on port: {0}
......@@ -854,6 +860,20 @@ muc.tasks.conversation.logging=Conversation Logging
muc.tasks.flush=Flush interval (seconds):
muc.tasks.batch=Batch size:
# MUC Statistics
muc.stats.occupants.name=Occupants
muc.stats.occupants.description=Total Room Occupants
muc.stats.occupants.label=Total Room Occupants
muc.stats.users.name=Users
muc.stats.users.description=Number of Connected Users
muc.stats.users.label=Number of Connected Users
muc.stats.incoming.name=Incoming Messages
muc.stats.incoming.description=Rate of Incoming Messages
muc.stats.incoming.label=Incoming Messages
muc.stats.outgoing.name=Outgoing Messages
muc.stats.outgoing.description=Rate of Outgoing Messages
muc.stats.outgoing.label=Outgoing Messages
# Offline messages Page
offline.messages.title=Offline Messages
......@@ -1723,7 +1743,6 @@ pubsub.form.subscription.keywords=Keyword to match
pubsub.form.authorization.title=PubSub subscriber request
pubsub.form.authorization.instruction=Use the following form to approve or deny the subscription \
request.
pubsub.form.authorization.node=Node ID
pubsub.form.authorization.subscriber=Subscriber Address
pubsub.form.authorization.allow=Allow this JID to subscribe to this pubsub node?
pubsub.command.pending-subscriptions.label=Authorize Pending Subscriptions
......
......@@ -82,6 +82,13 @@ public interface MUCUser extends ChannelHandler {
*/
void removeRole(String roomName);
/**
* Returns true if the user is currently present in one or more rooms.
*
* @return true if the user is currently present in one or more rooms.
*/
boolean isJoined();
/**
* Get time (in milliseconds from System currentTimeMillis()) since last packet.
*
......
......@@ -11,14 +11,14 @@
package org.jivesoftware.wildfire.muc;
import java.util.List;
import java.util.Collection;
import org.jivesoftware.wildfire.auth.UnauthorizedException;
import org.jivesoftware.wildfire.user.UserNotFoundException;
import org.xmpp.packet.Message;
import org.xmpp.packet.JID;
import org.xmpp.component.Component;
import org.xmpp.packet.JID;
import org.xmpp.packet.Message;
import java.util.Collection;
import java.util.List;
/**
* Manages groupchat conversations, chatrooms, and users. This class is designed to operate
......@@ -283,4 +283,12 @@ public interface MultiUserChatServer extends Component {
* @param sender the real XMPPAddress of the sender (e.g. john@example.org).
*/
void logConversation(MUCRoom room, Message message, JID sender);
/**
* Notification message indicating the server that an incoming message was broadcasted
* to a given number of occupants.
*
* @param numOccupants number of occupants that received the message.
*/
void messageBroadcastedTo(int numOccupants);
}
\ No newline at end of file
......@@ -844,7 +844,7 @@ public class MUCRoomImpl implements MUCRoom {
}
if (isLogEnabled()) {
MUCRole senderRole = null;
JID senderAddress = null;
JID senderAddress;
if (message.getTo() != null && message.getTo().getResource() != null) {
senderRole = occupants.get(message.getTo().getResource());
}
......@@ -859,6 +859,7 @@ public class MUCRoomImpl implements MUCRoom {
// Log the conversation
server.logConversation(this, message, senderAddress);
}
server.messageBroadcastedTo(occupants.size());
}
/**
......
......@@ -11,19 +11,21 @@
package org.jivesoftware.wildfire.muc.spi;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import org.dom4j.Element;
import org.jivesoftware.wildfire.muc.*;
import org.jivesoftware.util.*;
import org.jivesoftware.wildfire.*;
import org.jivesoftware.util.LocaleUtils;
import org.jivesoftware.util.Log;
import org.jivesoftware.util.NotFoundException;
import org.jivesoftware.wildfire.PacketException;
import org.jivesoftware.wildfire.PacketRouter;
import org.jivesoftware.wildfire.auth.UnauthorizedException;
import org.jivesoftware.wildfire.muc.*;
import org.jivesoftware.wildfire.user.UserAlreadyExistsException;
import org.jivesoftware.wildfire.user.UserNotFoundException;
import org.xmpp.packet.*;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
/**
* Implementation of MUCUser. There will be a MUCUser per user that is connected to one or more
* rooms. A MUCUser contains a collection of MUCRoles for each room where the user has joined.
......@@ -74,6 +76,10 @@ public class MUCUserImpl implements MUCUser {
return role;
}
public boolean isJoined() {
return !roles.isEmpty();
}
public Iterator<MUCRole> getRoles() {
return Collections.unmodifiableCollection(roles.values()).iterator();
}
......
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