ComunicWeb/assets/js/user/userInfos.js

218 lines
5.3 KiB
JavaScript
Raw Normal View History

2017-01-29 15:49:21 +01:00
/**
* User informations functions
*
* @author Pierre HUBERT
*/
2017-05-27 11:57:05 +02:00
ComunicWeb.user.userInfos = {
2017-01-29 15:49:21 +01:00
2017-05-27 15:11:30 +02:00
/**
* @var {String} User infos cache
*/
usersInfos: {},
/**
* Get user informations
*
* @param {String} userID User on which to make request (current to get connected user)
* @param {function} afterGetUserInfos What to do once user informations are available
2017-05-27 15:35:10 +02:00
* @param {Boolean} forceRequest Force the request to be made
2017-05-27 15:11:30 +02:00
* @return {Boolean} True for a success
*/
2017-05-27 15:35:10 +02:00
getUserInfos: function(userID, afterGetUserInfos, forceRequest){
2017-05-27 15:11:30 +02:00
2017-05-27 15:25:26 +02:00
//Check if current user infos were required
if(userID == "current")
userID = ComunicWeb.user.userLogin.getUserID();
2017-05-27 15:11:30 +02:00
2017-05-27 15:25:26 +02:00
//getMultipleUsersInfos mirror
var usersID = [userID];
2017-05-27 15:11:30 +02:00
2017-05-27 15:25:26 +02:00
return this.getMultipleUsersInfos(usersID, function(result){
//We check if an error occured
if(result.error)
2017-05-27 15:11:30 +02:00
afterGetUserInfos(result);
2017-05-27 15:25:26 +02:00
//Return a simple array
else
afterGetUserInfos(result["user-"+userID]);
2017-05-27 15:35:10 +02:00
}, forceRequest);
2017-05-27 15:11:30 +02:00
},
/**
* Get multiple users informations
*
2017-06-13 11:58:08 +02:00
* @param {Array~Object} usersID User on which to make request (current to get connected user)
2017-05-27 15:11:30 +02:00
* @param {function} afterGetUserInfos What to do once users informations are available
2017-05-27 15:35:10 +02:00
* @param {Boolean} forceRequest Force the request to be made
2017-05-27 15:11:30 +02:00
* @return {Boolean} True for a success
*/
2017-05-27 15:35:10 +02:00
getMultipleUsersInfos: function(usersID, afterGetUserInfos, forceRequest){
2017-05-27 15:11:30 +02:00
//First, check if informations are already available in the cache for some users
var cachedInformations = {};
var needRequest = false; //By default the request isn't required
var usersToGetList = "";
for(i in usersID){
//Extract userID
var processUserID = usersID[i];
//Check the local cache
2017-05-27 15:35:10 +02:00
if(this.usersInfos["user-"+processUserID] && !forceRequest){
2017-05-27 15:11:30 +02:00
//Add user information to cached informations
cachedInformations["user-"+processUserID] = this.usersInfos["user-"+processUserID];
2017-05-27 15:11:30 +02:00
}
else {
//Else we'll have to get data
needRequest = true;
2017-05-27 15:35:10 +02:00
usersToGetList += processUserID + ",";
2017-05-27 15:11:30 +02:00
}
}
//Check if an API request is not required
if(!needRequest){
//Go immediatly to the next step
afterGetUserInfos(cachedInformations);
return true;
}
//Perform API request
var apiURI = "user/getInfosMultiple";
var params = {
usersID: usersToGetList,
}
//Specify what to do next
var onceGetUserInfos = function(result){
if(result.error){
//Log error
ComunicWeb.debug.logMessage("ERROR : couldn't get infos about users ID !");
//Returns the error to the next function
afterGetUserInfos(result);
//Something went wrong
return false;
}
else {
//Prepare return
var returnInformations = cachedInformations;
//Save results and prepare return
for(i in result){
//Get user ID
var userID = result[i]['userID'];
//Store
ComunicWeb.user.userInfos.usersInfos["user-"+userID] = result[i];
returnInformations["user-"+userID] = result[i];
2017-05-27 15:11:30 +02:00
}
//Return results
afterGetUserInfos(returnInformations);
}
}
//Perform request
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, onceGetUserInfos);
//Everything is OK
return true;
},
/**
* Empty user informations cache
* Remove all entries from user informations cache
*
* @return {Boolean} True for a success
*/
emptyUserInfosCache: function(){
this.userInfos = undefined; //Mark user info cache as undefined
this.userInfos = {}; //Create a new variable
return true;
},
2017-06-05 14:35:28 +02:00
/**
* Given a query, search for users and return the result
*
* @param {String} query The query to search
* @param {Function} afterSearch What to do once we got results
* @return {Boolean} True for a success
*/
search: function(query, afterSearch){
//Perform a request on the server
apiURI = "user/search";
params = {
query: query,
};
ComunicWeb.common.api.makeAPIrequest(apiURI, params, true, function(response){
//Continue only in case of success
if(response.error){
afterSearch(false);
return false;
}
//Preload users informations
ComunicWeb.user.userInfos.getMultipleUsersInfos(response, function(usersInfos){
//Go to next action
afterSearch(usersInfos);
});
});
2017-06-13 16:42:09 +02:00
},
/**
* Given user IDs (in an array) the function return their names in a string
*
* @param {Array} usersID The users to return as a string
* @param {Function} afterNames What to do once we have got the names
* @return {Boolean} True for a success
*/
getNames: function(usersID, afterNames){
//Get users informations
this.getMultipleUsersInfos(usersID, function(usersInfo){
//Check for errors
if(usersInfo.error){
afterNames("Error");
}
//Prepare conversation name
var usersName = "";
//Process users informations
for(i in usersInfo){
if(usersInfo[i].firstName)
//Add a coma if required
if(usersName != "")
usersName += ", ";
usersName += usersInfo[i].firstName + " " + usersInfo[i].lastName;
}
//Perform next action with result
afterNames(usersName);
});
},
2017-06-14 11:46:10 +02:00
/**
* Empty users cache
*
* @return {Boolean} True for a success
*/
emptyCache: function(){
this.usersInfos = {};
//Success
return true;
}
};
//Register cache cleaner
ComunicWeb.common.cacheManager.registerCacheCleaner("ComunicWeb.user.userInfos.emptyCache");