48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
const errorHandling = require('../../utils/errorHandling')
|
|
const { requiredFields } = require('../../config/errors')
|
|
const formatNumberResult = require('../secondary/formatNumberResult')
|
|
|
|
/**
|
|
* @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 */
|
|
const 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
|
|
})
|
|
}
|
|
|
|
const result = randomNumber(min, max)
|
|
return res
|
|
.status(200)
|
|
.json({
|
|
result,
|
|
resultHTML: `<p>Nombre aléatoire compris entre ${min} inclus et ${max} inclus : <strong>${formatNumberResult(
|
|
result
|
|
)}</strong></p>`
|
|
})
|
|
}
|
|
|
|
exports.randomNumber = randomNumber
|
|
exports.randomNumberOutput = randomNumberOutput
|