32 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const errorHandling      = require('../../utils/errorHandling');
 | |
| const { requiredFields } = require('../../config/errors');
 | |
| 
 | |
| /** 
 | |
|  * @description Génère un nombre aléatoire entre un minimum inclus et un maximum inclus. 
 | |
|  * @param {Number} min Nombre Minimum 
 | |
|  * @param {Number} max Nombre Maximum 
 | |
|  * @returns {Number} Nombre aléatoire 
 | |
|  * @examples randomNumber(1, 2) → retourne soit 1 ou 2
 | |
|  */ 
 | |
| function randomNumber(min, max) {
 | |
|     return Math.floor(Math.random() * (max - min +1)) + min;
 | |
| }
 | |
| 
 | |
| /* OUTPUTS */
 | |
| exports.randomNumberOutput = ({ res, next }, argsObject) => {
 | |
|     let { min, max } = argsObject;
 | |
|     
 | |
|     // S'il n'y a pas les champs obligatoire
 | |
|     if (!(min && max)) {
 | |
|         return errorHandling(next, requiredFields);
 | |
|     }
 | |
|     
 | |
|     // Si ce ne sont pas des nombres
 | |
|     min = parseInt(min);
 | |
|     max = parseInt(max);
 | |
|     if (isNaN(min) || isNaN(max)) {
 | |
|         return errorHandling(next, { message: "Les paramètres min et max doivent être des nombres...", statusCode: 400 });
 | |
|     }
 | |
| 
 | |
|     return res.status(200).json({ result: randomNumber(min, max) });
 | |
| } |