Package tigase.db.jdbc
Class JDBCRepository
java.lang.Object
tigase.db.jdbc.JDBCRepository
- All Implemented Interfaces:
AuthRepository,DataSourceAware<DataRepository>,Repository,UserRepository,RepositoryVersionAware
public class JDBCRepository
extends Object
implements AuthRepository, UserRepository, DataSourceAware<DataRepository>, RepositoryVersionAware
Not synchronized implementation! Musn't be used by more than one thread at the same time.
Thanks to Daniele for better unique IDs handling. Created: Thu Oct 26 11:48:53 2006
- Author:
- Artur Hefczyc, Daniele
-
Nested Class Summary
Nested ClassesNested classes/interfaces inherited from interface tigase.db.AuthRepository
AuthRepository.AccountStatus, AuthRepository.DefaultCredentials, AuthRepository.SingleCredentialNested classes/interfaces inherited from interface tigase.db.Repository
Repository.Meta, Repository.SchemaIdNested classes/interfaces inherited from interface tigase.db.util.RepositoryVersionAware
RepositoryVersionAware.SchemaVersionNested classes/interfaces inherited from interface tigase.db.UserRepository
UserRepository.UserBeforeRemovedEvent, UserRepository.UserRemovedEvent -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final Stringstatic final StringStored procedure used to check version of the schema
neither MS SQL Server JDBC driver supports default schema prefix in connection string for stored functionsFields inherited from interface tigase.db.AuthRepository
DATA_KEY, DIGEST_ID_KEY, DIGEST_KEY, MACHANISM_KEY, PASSWORD_KEY, PROTOCOL_KEY, PROTOCOL_VAL_NONSASL, PROTOCOL_VAL_SASL, REALM_KEY, RESULT_KEY, SERVER_NAME_KEY, USER_ID_KEY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddDataList(BareJID user_id, String subnode, String key, String[] list) addDataListmethod adds mode entries to existing data list associated with given key in repository under given node path.voidThisaddUsermethod allows to add new user to repository.voidgetAccountStatus(BareJID user) longgetActiveUsersCountIn(Duration duration) getDatamethod returns a value associated with given key for user repository in default subnode.getDatamethod returns a value associated with given key for user repository in given subnode.getDatamethod returns a value associated with given key for user repository in given subnode.String[]getDataList(BareJID user_id, String subnode, String key) getDataListmethod returns array of values associated with given key ornullif given key does not exist for given user ID in given node path.getDataMap(@NonNull String key) getDataMap(BareJID user_id, String subnode) getDataMapmethod returns a values associated with each key for user repository in given subnode.getDataMap(BareJID user, String subnode, Function<String, T> converter) getDataMapmethod returns a values associated with each key for user repository in given subnode.String[]getKeysmethod returns list of all keys stored in default user repository node.String[]getKeysmethod returns list of all keys stored in given subnode in user repository.getPassword(BareJID user) protected DataRepositorygetResourceUrimethod returns database connection string.String[]getSubnodes(BareJID user_id) getSubnodesmethod returns list of all root nodes for given user.String[]getSubnodes(BareJID user_id, String subnode) Deprecated.getUsers()This method is only used by the data conversion tools.longThis method is only used by the server statistics component to report number of registered users.longgetUsersCount(String domain) This method is only used by the server statistics component to report number of registered users for given domain.longgetUserUID(BareJID user_id) Returns a user unique ID number within the given repository.voidinitRepository(String connection_str, Map<String, String> params) Deprecated.protected booleanbooleanisMechanismSupported(String domain, String mechanism) booleanisUserDisabled(BareJID user) voidDo some actions on repository, when user logs in.voidbooleanvoidqueryAuthreturns mechanisms available for authentication.voidremoveData(BareJID user_id, String key) removeDatamethod removes pair (key, value) from user repository in default repository node.voidremoveData(BareJID user_id, String subnode, String key) removeDatamethod removes pair (key, value) from user repository in given subnode.voidremoveSubnode(BareJID user_id, String subnode) removeSubnodemethod removes given subnode with all subnodes in this node and all data stored in this node and in all subnodes.voidremoveUser(BareJID user_id) removeUsermethod is thread safe.voidsetAccountStatus(BareJID user, AuthRepository.AccountStatus status) voidThissetDatamethod sets data value for given user ID associated with given key in default repository node.voidsetDatamethod sets data value for given user ID in repository under given node path and associates it with given key.voidsetDataList(BareJID user_id, String subnode, String key, String[] list) setDataListmethod sets list of values for given user associated given key in repository under given node path.voidsetDataSource(DataRepository dataSource) Method called to provide class with instance of a data source.voidsetUserDisabled(BareJID user, Boolean value) voidupdateCredential(BareJID user, String credentialId, String password) voidupdateCredential(BareJID user, String credentialId, String mechanism, String data) voidupdatePassword(BareJID user, String password) booleanuserExists(BareJID user) MethoduserExistschecks whether the user (or repository top node) exists in the database.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface tigase.db.AuthRepository
getCredentialIds, getCredentials, getUsernames, removeCredential, setCredentialsCodecsMethods inherited from interface tigase.db.util.RepositoryVersionAware
getVersion, updateSchema
-
Field Details
-
CURRENT_DB_SCHEMA_VER
- See Also:
-
DEF_MAXIDS_TBL
- See Also:
-
DEF_NODES_TBL
- See Also:
-
DEF_PAIRS_TBL
- See Also:
-
DEF_ROOT_NODE
- See Also:
-
DEF_USERS_TBL
- See Also:
-
DERBY_GETSCHEMAVER_QUERY
- See Also:
-
SQLSERVER_GETSCHEMAVER_QUERY
Stored procedure used to check version of the schema
neither MS SQL Server JDBC driver supports default schema prefix in connection string for stored functions- See Also:
-
JDBC_GETSCHEMAVER_QUERY
- See Also:
-
SCHEMA_UPGRADE_LINK
- See Also:
-
-
Constructor Details
-
JDBCRepository
public JDBCRepository()
-
-
Method Details
-
addDataList
public void addDataList(BareJID user_id, String subnode, String key, String[] list) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositoryaddDataListmethod adds mode entries to existing data list associated with given key in repository under given node path. This method is very similar tosetDataList(...)except it doesn't remove existing data.- Specified by:
addDataListin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the specified values list is to be associated.list- aString[]is an array of values to be associated with the specified key.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
addUser
Description copied from interface:UserRepositoryThisaddUsermethod allows to add new user to repository. It must throw en exceptionUserExistsExceptionif such user already exists because user must be unique within user repository data base.
As one XMPP server can support many virtual internet domains it is required thatuserid consists of user name and domain address: username@domain.address.net for example.- Specified by:
addUserin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user id consisting of user name and domain address.- Throws:
UserExistsException- if user with the same id already exists.TigaseDBException- if database backend error occurs.
-
addUser
- Specified by:
addUserin interfaceAuthRepository- Throws:
UserExistsExceptionTigaseDBException
-
getData
public String getData(BareJID user_id, String subnode, String key, String def) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorygetDatamethod returns a value associated with given key for user repository in given subnode. If key is not found in repository given default value is returned.- Specified by:
getDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the needed value is associated.def- aStringvalue which is returned in case if data for specified key does not exixist in repository.- Returns:
- a
Stringvalue - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getData
public String getData(BareJID user_id, String subnode, String key) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorygetDatamethod returns a value associated with given key for user repository in given subnode. If key is not found in repositorynullvalue is returned.- Specified by:
getDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the needed value is associated.- Returns:
- a
Stringvalue - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getData
Description copied from interface:UserRepositorygetDatamethod returns a value associated with given key for user repository in default subnode. If key is not found in repositorynullvalue is returned.- Specified by:
getDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.key- aStringwith which the needed value is associated.- Returns:
- a
Stringvalue - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getDataMap
public Map<BareJID,String> getDataMap(@NonNull String key) throws UserNotFoundException, TigaseDBException - Specified by:
getDataMapin interfaceUserRepository- Parameters:
key- key for which return of map of users and values corresponding to the value- Returns:
- a
Mapwith user JID as key and value corresponding to the key passed as parameter - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getDataMap
Description copied from interface:UserRepositorygetDataMapmethod returns a values associated with each key for user repository in given subnode.- Specified by:
getDataMapin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.- Returns:
- a
Mapwith values - Throws:
TigaseDBException- if database backend error occurs.
-
getDataMap
public <T> Map<String,T> getDataMap(BareJID user, String subnode, Function<String, T> converter) throws TigaseDBExceptionDescription copied from interface:UserRepositorygetDataMapmethod returns a values associated with each key for user repository in given subnode.- Specified by:
getDataMapin interfaceUserRepository- Parameters:
user- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.converter- aFunctionwhich takes value for a key and converts to expected value type- Returns:
- a
Mapwith values - Throws:
TigaseDBException- if database backend error occurs.
-
getDataList
public String[] getDataList(BareJID user_id, String subnode, String key) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorygetDataListmethod returns array of values associated with given key ornullif given key does not exist for given user ID in given node path.- Specified by:
getDataListin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the needed values list is associated.- Returns:
- a
String[]value - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getKeys
public String[] getKeys(BareJID user_id, String subnode) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorygetKeysmethod returns list of all keys stored in given subnode in user repository. There is a value (or list of values) associated with each key. It is up to user (developer) to know what key keeps one value and what key keeps list of values.- Specified by:
getKeysin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.- Returns:
- a
String[]value - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getKeys
Description copied from interface:UserRepositorygetKeysmethod returns list of all keys stored in default user repository node. There is some a value (or list of values) associated with each key. It is up to user (developer) to know what key keeps one value and what key keeps list of values.- Specified by:
getKeysin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored or retrieved. User ID consists of user name and domain name.- Returns:
- a
String[]value - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getResourceUri
Description copied from interface:AuthRepositorygetResourceUrimethod returns database connection string.- Specified by:
getResourceUriin interfaceAuthRepository- Specified by:
getResourceUriin interfaceUserRepository- Returns:
- a
Stringvalue of database connection string.
-
getSubnodes
@Deprecated public String[] getSubnodes(BareJID user_id, String subnode) throws UserNotFoundException, TigaseDBException Deprecated.Description copied from interface:UserRepositorygetSubnodesmethod returns list of all direct subnodes from given node.- Specified by:
getSubnodesin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.- Returns:
- a
String[]value is an array of all direct subnodes. - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getSubnodes
Description copied from interface:UserRepositorygetSubnodesmethod returns list of all root nodes for given user.- Specified by:
getSubnodesin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.- Returns:
- a
String[]value is an array of all root nodes for given user. - Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
getUserUID
Description copied from interface:UserRepositoryReturns a user unique ID number within the given repository. Please note it is also possible that the ID number is unique only for the user domain. The ID is a positive number if the user exists and negative if the user was not found in the repository.- Specified by:
getUserUIDin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored or retrieved. User ID consists of user name and domain name.- Returns:
- a user inique ID number within the repository or domain. The ID is a positive number if the user exists and negative if the user was not found in the repository.
- Throws:
TigaseDBException- if there is a problem with accessing user repository.
-
getUsers
Description copied from interface:UserRepositoryThis method is only used by the data conversion tools. They attempt to copy whole user repositories from one to another database. Databases might not be compatible but as long as the API is implemented and they support adding user the user database can be copied to a different data source.- Specified by:
getUsersin interfaceUserRepository- Returns:
- returns a collection of all user IDs (Jabber IDs) stored in the user repository.
- Throws:
TigaseDBException
-
getActiveUsersCountIn
- Specified by:
getActiveUsersCountInin interfaceAuthRepository- Parameters:
duration- Time range within which active users should be counted. Method is only used by statistics.- Returns:
- number of active users in required range
-
getUsersCount
public long getUsersCount()Description copied from interface:AuthRepositoryThis method is only used by the server statistics component to report number of registered users.- Specified by:
getUsersCountin interfaceAuthRepository- Specified by:
getUsersCountin interfaceUserRepository- Returns:
- a
longnumber of registered users in the repository.
-
getUsersCount
Description copied from interface:AuthRepositoryThis method is only used by the server statistics component to report number of registered users for given domain.- Specified by:
getUsersCountin interfaceAuthRepository- Specified by:
getUsersCountin interfaceUserRepository- Parameters:
domain- for which get the statistics- Returns:
- a
longnumber of registered users in the repository.
-
setDataSource
Description copied from interface:DataSourceAwareMethod called to provide class with instance of a data source.- Specified by:
setDataSourcein interfaceDataSourceAware<DataRepository>- Throws:
DBInitException
-
isMechanismSupported
- Specified by:
isMechanismSupportedin interfaceAuthRepository
-
initRepository
@Deprecated public void initRepository(String connection_str, Map<String, String> params) throws DBInitExceptionDeprecated.Description copied from interface:RepositoryMethod is deprecated and should not be user any more.
The method is called to initialize the data repository. Depending on the implementation all the initialization parameters can be passed either viaresource_uriparameter as the database connection string or viaparamsmap if the required repository parameters are more complex or both.- Specified by:
initRepositoryin interfaceRepository- Parameters:
connection_str- value in most cases representing the database connection string.params- is aMapwith repository properties necessary to initialize and perform all the functions. The initialization parameters are implementation dependent.- Throws:
DBInitException- if there was an error during repository initialization. Some implementations, though, perform so called lazy initialization so even though there is a problem with the underlying repository it may not be signaled through this method call.
-
logout
- Specified by:
logoutin interfaceAuthRepository- Throws:
UserNotFoundExceptionTigaseDBException
-
loggedIn
Description copied from interface:AuthRepositoryDo some actions on repository, when user logs in. (for example updatelast_login_time)- Specified by:
loggedInin interfaceAuthRepository- Parameters:
user- JID of logged user.- Throws:
TigaseDBException- if an error occurs
-
otherAuth
public boolean otherAuth(Map<String, Object> props) throws UserNotFoundException, TigaseDBException, AuthorizationException- Specified by:
otherAuthin interfaceAuthRepository- Throws:
UserNotFoundExceptionTigaseDBExceptionAuthorizationException
-
queryAuth
Description copied from interface:AuthRepositoryqueryAuthreturns mechanisms available for authentication.- Specified by:
queryAuthin interfaceAuthRepository- Parameters:
authProps- aMapvalue with parameters for authentication.
-
removeData
public void removeData(BareJID user_id, String subnode, String key) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositoryremoveDatamethod removes pair (key, value) from user repository in given subnode. If the key exists in user repository there is always a value associated with this key - even emptyString. If key does not exist thenullvalue is returned from repository backend or given default value.- Specified by:
removeDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringfor which the value is to be removed.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
removeData
Description copied from interface:UserRepositoryremoveDatamethod removes pair (key, value) from user repository in default repository node. If the key exists in user repository there is always a value associated with this key - even emptyString. If key does not exist thenullvalue is returned from repository backend or given default value.- Specified by:
removeDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.key- aStringfor which the value is to be removed.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
removeSubnode
public void removeSubnode(BareJID user_id, String subnode) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositoryremoveSubnodemethod removes given subnode with all subnodes in this node and all data stored in this node and in all subnodes. Effectively it removes entire repository tree starting from given node.- Specified by:
removeSubnodein interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path to subnode which has to be removed. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
removeUser
removeUsermethod is thread safe. It uses local variable for storingStatement.- Specified by:
removeUserin interfaceAuthRepository- Specified by:
removeUserin interfaceUserRepository- Parameters:
user_id- aStringvalue the user Jabber ID.- Throws:
UserNotFoundException- if an error occursTigaseDBException- if database backend error occurs.
-
setData
public void setData(BareJID user_id, String subnode, String key, String value) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorysetDatamethod sets data value for given user ID in repository under given node path and associates it with given key. If there already exists value for given key in given node, old value is replaced with new value. No warning or exception is thrown in case if methods overwrites old value.- Specified by:
setDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the specified value is to be associated.value- aStringvalue to be associated with the specified key.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
setData
public void setData(BareJID user_id, String key, String value) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositoryThissetDatamethod sets data value for given user ID associated with given key in default repository node. Default node is dependent on implementation and usually it is root user node. If there already exists value for given key in given node, old value is replaced with new value. No warning or exception is thrown in case if methods overwrites old value.- Specified by:
setDatain interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.key- aStringwith which the specified value is to be associated.value- aStringvalue to be associated with the specified key.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
setDataList
public void setDataList(BareJID user_id, String subnode, String key, String[] list) throws UserNotFoundException, TigaseDBException Description copied from interface:UserRepositorysetDataListmethod sets list of values for given user associated given key in repository under given node path. If there already exist values for given key in given node, all old values are replaced with new values. No warning or exception is thrown in case if methods overwrites old value.- Specified by:
setDataListin interfaceUserRepository- Parameters:
user_id- aBareJIDvalue of user ID for which data must be stored. User ID consists of user name and domain name.subnode- aStringvalue is a node path where data is stored. Node path has the same form as directory path on file system:/root/subnode1/subnode2
.key- aStringwith which the specified values list is to be associated.list- aString[]is an array of values to be associated with the specified key.- Throws:
UserNotFoundException- if user id hasn't been found in repository.TigaseDBException- if database backend error occurs.
-
updateCredential
public void updateCredential(BareJID user, String credentialId, String mechanism, String data) throws TigaseDBException - Specified by:
updateCredentialin interfaceAuthRepository- Throws:
TigaseDBException
-
updateCredential
public void updateCredential(BareJID user, String credentialId, String password) throws TigaseDBException - Specified by:
updateCredentialin interfaceAuthRepository- Throws:
TigaseDBException
-
updatePassword
- Specified by:
updatePasswordin interfaceAuthRepository- Throws:
TigaseDBException
-
userExists
Description copied from interface:UserRepositoryMethoduserExistschecks whether the user (or repository top node) exists in the database. The method doesn't throw any exception nor it creates the user in case it is missing. It just checks whether the user is already in the database.
Please don't overuse this method. All other methods throwUserNotFoundExceptionexception in case the user is missing for which you executed the method. The exception is thrown unlessuserAutoCreateproperty is set to true. In such case the exception is never thrown and the methods are executed for given parameters prior to creating user entry if it is missing.
Therefore this method should be used only to check whether the account exists without creating it.- Specified by:
userExistsin interfaceUserRepository- Parameters:
user- aBareJIDvalue- Returns:
- a
booleanvalue
-
getPassword
- Specified by:
getPasswordin interfaceAuthRepository- Throws:
UserNotFoundExceptionTigaseDBException
-
isUserDisabled
- Specified by:
isUserDisabledin interfaceAuthRepository- Throws:
UserNotFoundExceptionTigaseDBException
-
setAccountStatus
public void setAccountStatus(BareJID user, AuthRepository.AccountStatus status) throws TigaseDBException - Specified by:
setAccountStatusin interfaceAuthRepository- Throws:
TigaseDBException
-
getAccountStatus
- Specified by:
getAccountStatusin interfaceAuthRepository- Throws:
TigaseDBException
-
setUserDisabled
public void setUserDisabled(BareJID user, Boolean value) throws UserNotFoundException, TigaseDBException - Specified by:
setUserDisabledin interfaceAuthRepository- Throws:
UserNotFoundExceptionTigaseDBException
-
getRepository
-
isExceptionKeyViolation
-