Skip to content

Commit

Permalink
[feat] add error message when needed
Browse files Browse the repository at this point in the history
  • Loading branch information
lgrd committed Apr 6, 2023
1 parent 6657264 commit 68df617
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 9 deletions.
22 changes: 15 additions & 7 deletions src/js/service/service.js
Original file line number Diff line number Diff line change
Expand Up @@ -991,9 +991,15 @@ module.exports = class Service {
try {
response = this.computeAdminRequest(request);
} catch(error) {
LOGGER.error("Erreur lors de l'exécution de la requête: " + error);
// C'est un cas particulier : on veut retrouver l'usage des controller d'APIs
// => comme c'est une requête, on fait du throw en cas d'erreur et c'est normal
// ce n'est pas une vraie erreur. Cependant, on veut renvoyer l'erreur au parent
// donc on copie le message
LOGGER.info("Erreur lors de l'exécution de la requête: " + error.message);
error._uuid = request._uuid;
error._errorFlag = true
error._errorFlag = true;
error._message = error.message;
error._stack = error.stack;
process.send(error);
return false;
}
Expand All @@ -1005,7 +1011,9 @@ module.exports = class Service {
// TODO : gestion plus fine du renvoi d'un message, il faudrait que l'administrateur vérifie l'état du canal
LOGGER.error("Erreur lors de l'envoi de la réponse à la requête: " + error);
error._uuid = request._uuid;
error._errorFlag = true
error._errorFlag = true;
error._message = error.message;
error._stack = error.stack;
process.send(error);
return false;
}
Expand Down Expand Up @@ -1134,15 +1142,15 @@ module.exports = class Service {

// On doit utiliser les attributs avec _ car les méthodes ne sont pas disponible dans le cadre d'une communication IPC
let projectionResponse = new ProjectionResponse();
if ( !this._projectionManager.isProjectionLoaded(projectionRequest._projection)){
throw errorManager.createError(`Can't find projection ${projectionRequest._projection}`, 404);
}
else{

if (!this._projectionManager.isProjectionLoaded(projectionRequest._projection)) {
throw errorManager.createError(`Can't find projection ${projectionRequest._projection}`, 404);
} else {
projectionResponse.id = projectionRequest._projection;
}

return projectionResponse;

}

}
4 changes: 2 additions & 2 deletions src/js/service/serviceProcess.js
Original file line number Diff line number Diff line change
Expand Up @@ -206,8 +206,8 @@ module.exports = class ServiceProcess extends ServiceAdministered {

// On vérifie s'il s'agit d'une erreur
if (response._errorFlag) {
// TODO : voir si on fait une fonction pour ajouter la récupération de la stack
throw errorManager.createError(response.error, response.status)
// TODO : voir ce qu'on fait de la stack dispo dans response._stack
throw errorManager.createError(response._message, response.status);
}

return response;
Expand Down

0 comments on commit 68df617

Please sign in to comment.