/* * Jitsi, the OpenSource Java VoIP and Instant Messaging client. * * Copyright @ 2015 Atlassian Pty Ltd * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.java.sip.communicator.service.protocol; /** * This interface represents chat room participants. Instances are retrieved * through implementations of the <tt>ChatRoom</tt> interface and offer methods * that allow querying member properties, such as, moderation permissions, * associated chat room and other. * * @author Emil Ivov * @author Boris Grozev */ public interface ChatRoomMember { /** * Returns the chat room that this member is participating in. * * @return the <tt>ChatRoom</tt> instance that this member belongs to. */ public ChatRoom getChatRoom(); /** * Returns the protocol provider instance that this member has originated * in. * * @return the <tt>ProtocolProviderService</tt> instance that created this * member and its containing cht room */ public ProtocolProviderService getProtocolProvider(); /** * Returns the contact identifier representing this contact. In protocols * like IRC this method would return the same as getName() but in others * like Jabber, this method would return a full contact id uri. * * @return a String (contact address), uniquely representing the contact * over the service the service being used by the associated protocol * provider instance/ */ public String getContactAddress(); /** * Returns the name of this member as it is known in its containing * chatroom (aka a nickname). The name returned by this method, may * sometimes match the string returned by getContactID() which is actually * the address of a contact in the realm of the corresponding protocol. * * @return the name of this member as it is known in the containing chat * room (aka a nickname). */ public String getName(); /** * Returns the avatar of this member, that can be used when including it in * user interface. * * @return an avatar (e.g. user photo) of this member. */ public byte[] getAvatar(); /** * Returns the protocol contact corresponding to this member in our contact * list. The contact returned here could be used by the user interface to * check if this member is contained in our contact list and in function of * this to show additional information add additional functionality. * * @return the protocol contact corresponding to this member in our contact * list. */ public Contact getContact(); /** * Returns the role of this chat room member in its containing room. * * @return a <tt>ChatRoomMemberRole</tt> instance indicating the role * the this member in its containing chat room. */ public ChatRoomMemberRole getRole(); /** * Sets the role of this chat room member in its containing room. * * @param role <tt>ChatRoomMemberRole</tt> instance indicating the role * to set for this member in its containing chat room. */ public void setRole(ChatRoomMemberRole role); /** * Returns the status of the chat room member as per the last status update * we've received for it. Note that this method is not to perform any * network operations and will simply return the status received in the last * status update message. * * @return the PresenceStatus that we've received in the last status update * pertaining to this contact. */ public PresenceStatus getPresenceStatus(); }