Package com.smartfoxserver.v2.api
Class SFSBuddyApi
- java.lang.Object
- 
- com.smartfoxserver.v2.api.SFSBuddyApi
 
- 
- All Implemented Interfaces:
- ISFSBuddyApi
 
 public class SFSBuddyApi extends java.lang.Object implements ISFSBuddyApi Provides all necessary functionalities for managing User buddy lists.
- 
- 
Field SummaryFields Modifier and Type Field Description protected org.slf4j.Loggerlogprotected com.smartfoxserver.v2.api.ISFSBuddyResponseApiresponseAPIprotected SmartFoxServersfsprotected ISFSApisfsApi
 - 
Constructor SummaryConstructors Constructor Description SFSBuddyApi(SmartFoxServer sfs)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddBuddy(User owner, java.lang.String buddyName, boolean isTemp, boolean fireClientEvent, boolean fireServerEvent)Adds a new buddy to the BuddyList of the specified User.voidaddBuddy(Zone zone, java.lang.String ownerName, java.lang.String buddyName, boolean isTemp, boolean fireClientEvent, boolean fireServerEvent)Adds a buddy to the User's buddy list even if the User is not online at the moment This feature is not implemented yet.voidblockBuddy(User owner, java.lang.String buddyName, boolean isBlocked, boolean fireClientEvent, boolean fireServerEvent)Block/Unblock a Buddy in the owner's BuddyList Blocked buddies won't be able to see the owner online status and send him messages or updatescom.smartfoxserver.v2.api.ISFSBuddyResponseApigetResponseAPI()voidgoOnline(User user, boolean online, boolean fireServerEvent)Activates/De-activates the Buddy ONLINE status of the User.BuddyListinitBuddyList(User user, boolean fireServerEvent)Initialize the buddy list for the requested User.protected voidinitializeBuddyState(User user)voidremoveBuddy(User owner, java.lang.String buddyName, boolean fireClientEvent, boolean fireServerEvent)Remove a Buddy from the owner's BuddyListvoidremoveBuddy(Zone zone, java.lang.String ownerName, java.lang.String buddyName, boolean fireClientEvent, boolean fireServerEvent)Removes a Buddy from the owner's BuddyList even if the User is not online at the moment This feature is not implemented yet.voidsendBuddyMessage(User sender, User recipient, java.lang.String message, ISFSObject params)Send a Buddy Message to any Buddy in your list.voidsetBuddyVariables(User owner, java.util.List<BuddyVariable> buddyVariables, boolean fireClientEvent, boolean fireServerEvent)Set any number of BuddyVariables for the specified owner
 
- 
- 
- 
Field Detail- 
sfsprotected final SmartFoxServer sfs 
 - 
logprotected final org.slf4j.Logger log 
 - 
responseAPIprotected final com.smartfoxserver.v2.api.ISFSBuddyResponseApi responseAPI 
 - 
sfsApiprotected final ISFSApi sfsApi 
 
- 
 - 
Constructor Detail- 
SFSBuddyApipublic SFSBuddyApi(SmartFoxServer sfs) 
 
- 
 - 
Method Detail- 
getResponseAPIpublic com.smartfoxserver.v2.api.ISFSBuddyResponseApi getResponseAPI() - Specified by:
- getResponseAPIin interface- ISFSBuddyApi
 
 - 
initBuddyListpublic BuddyList initBuddyList(User user, boolean fireServerEvent) throws java.io.IOException Initialize the buddy list for the requested User. This involves loading previous data from the BuddyList storage.- Specified by:
- initBuddyListin interface- ISFSBuddyApi
- Parameters:
- user- the User
- fireServerEvent- if true fires a server side event (BUDDY_LIST_INIT)
- Returns:
- the loaded BuddyList
- Throws:
- java.io.IOException
 
 - 
goOnlinepublic void goOnline(User user, boolean online, boolean fireServerEvent) Activates/De-activates the Buddy ONLINE status of the User. All clients who have the User as their Buddy will see him as online.- Specified by:
- goOnlinein interface- ISFSBuddyApi
- Parameters:
- user- the User
- online- the online status
- fireServerEvent- if true fires a server side event (BUDDY_ONLINE)
 
 - 
addBuddypublic void addBuddy(User owner, java.lang.String buddyName, boolean isTemp, boolean fireClientEvent, boolean fireServerEvent) throws SFSBuddyListException Adds a new buddy to the BuddyList of the specified User.- Specified by:
- addBuddyin interface- ISFSBuddyApi
- Parameters:
- owner- the owner User
- buddyName- the name of the buddy to add
- isTemp- if true, the Buddy is only temporary and will be lost when the user logs out
- fireClientEvent- if true, send a client update
- fireServerEvent- if true, fire a server event (BUDDY_ADDED)
- Throws:
- SFSBuddyListException- an error might occur if the BuddyList is full or the buddy was already added
 
 - 
addBuddypublic void addBuddy(Zone zone, java.lang.String ownerName, java.lang.String buddyName, boolean isTemp, boolean fireClientEvent, boolean fireServerEvent) throws SFSBuddyListException Adds a buddy to the User's buddy list even if the User is not online at the moment This feature is not implemented yet.- Specified by:
- addBuddyin interface- ISFSBuddyApi
- Throws:
- SFSBuddyListException
 
 - 
removeBuddypublic void removeBuddy(User owner, java.lang.String buddyName, boolean fireClientEvent, boolean fireServerEvent) Remove a Buddy from the owner's BuddyList- Specified by:
- removeBuddyin interface- ISFSBuddyApi
- Parameters:
- owner- the owner
- buddyName- the Buddy name
- fireClientEvent- if true send a client update
- fireServerEvent- if true fire a server side event (BUDDY_REMOVED)
 
 - 
removeBuddypublic void removeBuddy(Zone zone, java.lang.String ownerName, java.lang.String buddyName, boolean fireClientEvent, boolean fireServerEvent) Description copied from interface:ISFSBuddyApiRemoves a Buddy from the owner's BuddyList even if the User is not online at the moment This feature is not implemented yet.- Specified by:
- removeBuddyin interface- ISFSBuddyApi
 
 - 
blockBuddypublic void blockBuddy(User owner, java.lang.String buddyName, boolean isBlocked, boolean fireClientEvent, boolean fireServerEvent) Block/Unblock a Buddy in the owner's BuddyList Blocked buddies won't be able to see the owner online status and send him messages or updates- Specified by:
- blockBuddyin interface- ISFSBuddyApi
- Parameters:
- owner- the BuddyList owner
- buddyName- the name of the Buddy to block/unblock
- isBlocked- the 'blocked' flag
- fireClientEvent- if true send a client update
- fireServerEvent- if true fire a server side event (BUDDY_BLOCK_UPDATE)
 
 - 
setBuddyVariablespublic void setBuddyVariables(User owner, java.util.List<BuddyVariable> buddyVariables, boolean fireClientEvent, boolean fireServerEvent) throws SFSBuddyListException Set any number of BuddyVariables for the specified owner- Specified by:
- setBuddyVariablesin interface- ISFSBuddyApi
- Parameters:
- owner- the owner User
- buddyVariables- a list of variables
- fireClientEvent- if true, send a client update
- fireServerEvent- if true, fire a server event (BUDDY_VARIABLES_UPDATE)
- Throws:
- SFSBuddyListException- an error might occur if the limit of variables allowed is exceeded
 
 - 
sendBuddyMessagepublic void sendBuddyMessage(User sender, User recipient, java.lang.String message, ISFSObject params) throws SFSBuddyListException Send a Buddy Message to any Buddy in your list. A Buddy message is similar to a regular chat Private Message but it is meant to work with the BuddyList taking into account the Buddy blocked state etc...- Specified by:
- sendBuddyMessagein interface- ISFSBuddyApi
- Parameters:
- sender- the sender of the message
- recipient- the recipient of the message (must be a Buddy in the sender's BuddyList)
- message- the message
- params- custom parameters
- Throws:
- SFSBuddyListException- thrown if the Buddy is not in the sender's Buddy List or if the recipient has blocked the sender
 
 - 
initializeBuddyStateprotected void initializeBuddyState(User user) throws SFSBuddyListException - Throws:
- SFSBuddyListException
 
 
- 
 
-