public class DefaultRosterItemProvider extends Object implements RosterItemProvider
Rosters are another user resource accessed via the user or chatbot's long ID. A user/chatbot may have zero or more roster items and each roster item may have zero or more groups. Each roster item is additionaly keyed on a XMPP jid. In most cases, the entire roster will be read in from memory and manipulated or sent to the user. However some operations will need to retrive specific roster items rather than the entire roster.
Constructor and Description |
---|
DefaultRosterItemProvider() |
Modifier and Type | Method and Description |
---|---|
RosterItem |
createItem(String username,
RosterItem item)
Creates a new roster item for the given user (optional operation).
|
void |
deleteItem(String username,
long rosterItemID)
Delete the roster item with the given itemJID for the user (optional operation).
|
int |
getItemCount(String username)
Obtain a count of the number of roster items available for the given user.
|
Iterator<RosterItem> |
getItems(String username)
Retrieve an iterator of RosterItems for the given user.
|
Iterator<String> |
getUsernames(String jid)
Returns an iterator on the usernames whose roster includes the specified JID.
|
void |
updateItem(String username,
RosterItem item)
Update the roster item in storage with the information contained in the given item
(optional operation).
|
public RosterItem createItem(String username, RosterItem item) throws UserAlreadyExistsException
RosterItemProvider
Important! The item passed as a parameter to this method is strictly a convenience for passing all of the data needed for a new roster item. The roster item returned from the method will be cached by Openfire. In some cases, the roster item passed in will be passed back out. However, if an implementation may return RosterItems as a separate class (for example, a RosterItem that directly accesses the backend storage, or one that is an object in an object database).
createItem
in interface RosterItemProvider
username
- the username of the user/chatbot that owns the roster item.item
- the settings for the roster item to create.UserAlreadyExistsException
- if a roster item with the username already exists.public void updateItem(String username, RosterItem item) throws UserNotFoundException
RosterItemProvider
If you don't want roster items edited through openfire, throw UnsupportedOperationException.
updateItem
in interface RosterItemProvider
username
- the username of the user/chatbot that owns the roster itemitem
- The roster item to updateUserNotFoundException
- If no entry could be found to updatepublic void deleteItem(String username, long rosterItemID)
RosterItemProvider
If you don't want roster items deleted through openfire, throw UnsupportedOperationException.
deleteItem
in interface RosterItemProvider
username
- the long ID of the user/chatbot that owns the roster itemrosterItemID
- The roster item to deletepublic Iterator<String> getUsernames(String jid)
RosterItemProvider
getUsernames
in interface RosterItemProvider
jid
- the jid that the rosters should include.public int getItemCount(String username)
RosterItemProvider
getItemCount
in interface RosterItemProvider
username
- the username of the user/chatbot that owns the roster itemspublic Iterator<RosterItem> getItems(String username)
RosterItemProvider
This method will commonly be called when a user logs in. The data will be cached in memory when possible. However, some rosters may be very large so items may need to be retrieved from the provider more frequently than usual for provider data.
getItems
in interface RosterItemProvider
username
- the username of the user/chatbot that owns the roster itemsCopyright © 2003-2008 Jive Software.