2017-01-04 19:14:27 +01:00
|
|
|
/**
|
|
|
|
* API main functions
|
|
|
|
*
|
|
|
|
* @author Pierre HUBERT
|
|
|
|
*/
|
2018-01-06 10:30:04 +01:00
|
|
|
ComunicWeb.common.api = {
|
|
|
|
/**
|
|
|
|
* Make an API request
|
|
|
|
*
|
|
|
|
* @param {String} apiURI The URI to call in the API
|
|
|
|
* @param {Object} params The params to include in request
|
|
|
|
* @param {Boolean} requireLoginTokens Specify if login tokens are required or not
|
|
|
|
* @param {Function} nextAction What to do next
|
|
|
|
*/
|
|
|
|
makeAPIrequest: function(apiURI, params, requireLoginTokens, nextAction){
|
|
|
|
//Prepare the request URL
|
|
|
|
var requestURL = ComunicWeb.__config.apiURL + apiURI;
|
|
|
|
|
|
|
|
//Add API service tokens
|
|
|
|
params.serviceName = ComunicWeb.__config.apiServiceName;
|
|
|
|
params.serviceToken = ComunicWeb.__config.apiServiceToken;
|
|
|
|
|
|
|
|
//Add login tokens to params if required
|
|
|
|
if(requireLoginTokens){
|
|
|
|
//Get login tokens
|
|
|
|
tokens = ComunicWeb.user.loginTokens.getLoginTokens();
|
|
|
|
|
|
|
|
if(tokens){
|
|
|
|
//Add tokens
|
|
|
|
params.userToken1 = tokens.token1;
|
|
|
|
params.userToken2 = tokens.token2;
|
|
|
|
}
|
2017-01-04 19:14:27 +01:00
|
|
|
|
2017-05-19 18:17:32 +02:00
|
|
|
}
|
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
//Prepare data to send in request
|
|
|
|
var count = 0;
|
|
|
|
var datas = "";
|
|
|
|
for(paramName in params){
|
|
|
|
//We add a "&" if it isn't the first param
|
|
|
|
if(count != 0)
|
|
|
|
datas += "&";
|
2017-01-29 15:49:21 +01:00
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
//We add field value
|
|
|
|
datas += encodeURIComponent(paramName) + "=" + encodeURIComponent(params[paramName]);
|
2017-01-08 15:54:25 +01:00
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
count++; //Increment counter
|
|
|
|
}
|
2017-01-08 15:54:25 +01:00
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
//Create request
|
|
|
|
var apiXHR = new XMLHttpRequest();
|
|
|
|
apiXHR.open("POST", requestURL);
|
2017-01-04 19:14:27 +01:00
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
//Prepare request response
|
|
|
|
apiXHR.onreadystatechange = function(){
|
2018-01-06 15:26:43 +01:00
|
|
|
ComunicWeb.common.api._on_state_change(requestURL, apiXHR, nextAction);
|
2018-01-06 10:30:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//Set request headers
|
|
|
|
apiXHR.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
|
|
|
|
|
|
|
|
//Submit request
|
|
|
|
apiXHR.send(datas);
|
|
|
|
},
|
|
|
|
|
2018-01-06 15:26:43 +01:00
|
|
|
/**
|
|
|
|
* Make an API request with a prepared form data object
|
|
|
|
*
|
|
|
|
* @param {String} apiURI The URI to call in the API
|
|
|
|
* @param {FormData} data The form data object
|
|
|
|
* @param {Boolean} requireLoginTokens Specify if login tokens are required or not
|
|
|
|
* @param {Function} nextAction What to do next
|
|
|
|
*/
|
|
|
|
makeFormDatarequest: function(apiURI, data, requireLoginTokens, nextAction){
|
|
|
|
//Prepare the request URL
|
|
|
|
var requestURL = ComunicWeb.__config.apiURL + apiURI;
|
|
|
|
|
|
|
|
//Add API service tokens
|
|
|
|
data.append('serviceName', ComunicWeb.__config.apiServiceName);
|
|
|
|
data.append('serviceToken', ComunicWeb.__config.apiServiceToken);
|
|
|
|
|
|
|
|
//Add login tokens to params if required
|
|
|
|
if(requireLoginTokens){
|
|
|
|
//Get login tokens
|
|
|
|
tokens = ComunicWeb.user.loginTokens.getLoginTokens();
|
|
|
|
|
|
|
|
if(tokens){
|
|
|
|
//Add tokens
|
|
|
|
data.append('userToken1', tokens.token1);
|
|
|
|
data.append('userToken2', tokens.token2);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//Create request
|
|
|
|
var apiXHR = new XMLHttpRequest();
|
|
|
|
apiXHR.open("POST", requestURL);
|
|
|
|
|
|
|
|
//Prepare request response
|
|
|
|
apiXHR.onreadystatechange = function(){
|
|
|
|
ComunicWeb.common.api._on_state_change(requestURL, apiXHR, nextAction);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Submit request
|
|
|
|
apiXHR.send(data);
|
|
|
|
},
|
|
|
|
|
2018-01-06 10:30:04 +01:00
|
|
|
/**
|
|
|
|
* Handle xhr request chnages
|
|
|
|
*
|
2018-01-06 15:26:43 +01:00
|
|
|
* @param {string} requestURL The URL of the request
|
2018-01-06 10:30:04 +01:00
|
|
|
* @param {XMLHttpRequest} apiXHR The request element
|
|
|
|
* @param {Function} nextAction What to do once the request is done
|
|
|
|
*/
|
2018-01-06 15:26:43 +01:00
|
|
|
_on_state_change: function(requestURL, apiXHR, nextAction){
|
2017-01-04 19:14:27 +01:00
|
|
|
|
|
|
|
//We continue only if request is terminated
|
|
|
|
if(apiXHR.readyState == 4){
|
2017-06-07 17:26:51 +02:00
|
|
|
|
|
|
|
//Check if response code is 0
|
|
|
|
if(apiXHR.status == 0){
|
|
|
|
//An error occured
|
|
|
|
ComunicWeb.common.network.setStatus(false);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
//It is a success
|
|
|
|
ComunicWeb.common.network.setStatus(true);
|
|
|
|
}
|
|
|
|
|
2017-06-25 16:30:38 +02:00
|
|
|
//Check if response is empty
|
|
|
|
if(apiXHR.responseText.length == ""){
|
|
|
|
//Auto-create a response for empty responses (to avoid Javascript errors and allow the script to continue to execute)
|
|
|
|
result = {
|
|
|
|
error : {
|
|
|
|
code: 0,
|
|
|
|
message: "Empty response",
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
else
|
|
|
|
//Prepare result
|
|
|
|
var result = JSON.parse(apiXHR.responseText);
|
2017-01-29 15:49:21 +01:00
|
|
|
|
|
|
|
//We check if we got any error
|
|
|
|
if(result.error){
|
|
|
|
//Log error
|
2017-05-27 11:57:05 +02:00
|
|
|
ComunicWeb.debug.logMessage("Got an error in a XHR request! \n Request URL: "+requestURL+" \n Response : "+apiXHR.responseText);
|
2017-01-29 15:49:21 +01:00
|
|
|
}
|
2017-01-04 19:14:27 +01:00
|
|
|
|
|
|
|
//We can do the next step
|
2017-06-04 16:02:51 +02:00
|
|
|
if(nextAction)
|
|
|
|
nextAction(result);
|
2017-01-04 19:14:27 +01:00
|
|
|
}
|
2018-01-06 10:30:04 +01:00
|
|
|
},
|
|
|
|
}
|