You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

185 lines
4.3 KiB
JavaScript

const fs = require("fs");
// Nombre del fichero donde se guardan las preguntas.
// Es un fichero de texto con el JSON de quizzes.
const DB_FILENAME = "quizzes.json";
// Modelo de datos.
//
// En esta variable se mantienen todos los quizzes existentes.
// Es un array de objetos, donde cada objeto tiene los atributos question
// y answer para guardar el texto de la pregunta y el de la respuesta.
//
// Al arrancar la aplicación, esta variable contiene estas cuatro preguntas,
// pero al final del módulo se llama a load() para la cargar las preguntas
// guardadas en el fichero DB_FILENAME.
let quizzes = [
{
question: "Capital de Italia",
answer: "Roma"
},
{
question: "Capital de Francia",
answer: "París"
},
{
question: "Capital de España",
answer: "Madrid"
},
{
question: "Capital de Portugal",
answer: "Lisboa"
}
];
/**
* Carga las preguntas guardadas en el fichero.
*
* Este método carga el contenido del fichero DB_FILENAME en la variable
* quizzes. El contenido de ese fichero está en formato JSON.
* La primera vez que se ejecute este método, el fichero DB_FILENAME no
* existe, y se producirá el errro ENOENT. En este caso se salva el
* contenido inicial almacenado en quizzes.
* Si se produce otro tipo de error, se lanza una excepción que abortará
* la ejecución del programa.
*/
const load = () => {
fs.readFile(DB_FILENAME, (err, data) => {
if (err) {
// La primera vez no existe el fichero
if (err.code === "ENOENT") {
save(); // valores iniciales
return;
}
throw err;
}
let json = JSON.parse(data);
if (json) {
quizzes = json;
}
});
};
/**
* Guarda las preguntas en el fichero.
*
* Guarda en formatro JSON el valor de quizzes en el fichero DB_FILENAME.
* Si se produce algún tipo de error, se lanza una excepción que abortará
* la ejecución del programa.
*/
const save = () => {
fs.writeFile(DB_FILENAME,
JSON.stringify(quizzes),
err => {
if (err) throw err;
});
};
//
/**
* Devuelve el número total de preguntas existentes.
*
* @returns {number} número total de preguntas existentes.
*/
exports.count = () => quizzes.length;
/**
* Añade un nuevo quiz.
*
* @param question String con la pregunta.
* @param answer String con la respuesta.
*/
exports.add = (question, answer) => {
quizzes.push({
question: (question || "").trim(),
answer: (answer || "").trim()
});
save();
};
/**
* Actualiza el quiz situado en la posicion index.
*
* @param id Clave que identifica el quiz a actualizar.
* @param question String con la pregunta.
* @param answer String con la respuesta.
*/
exports.update = (id, question, answer) => {
const quiz = quizzes[id];
if (typeof quiz === "undefined") {
throw new Error(`El valor del parámetro id no es válido.`);
}
quizzes.splice(id, 1, {
question: (question || "").trim(),
answer: (answer || "").trim()
});
save();
};
/**
* Devuelve todos los quizzes existentes.
*
* Devuelve un clon del valor guardado en la variable quizzes, es decir devuelve un
* objeto nuevo con todas las preguntas existentes.
* Para clonar quizzes se usa stringify + parse.
*
* @returns {any}
*/
exports.getAll = () => JSON.parse(JSON.stringify(quizzes));
/**
* Devuelve un clon del quiz almacenado en la posición dada.
*
* Para clonar el quiz se usa stringify + parse.
*
* @param id Clave que identifica el quiz a devolver.
*
* @returns {question, answer} Devuelve el objeto quiz de la posición dada
*/
exports.getByIndex = id => {
const quiz = quizzes[id];
if (typeof quiz === "undefined") {
throw new Error(`El valor del parámetro id no es válido.`);
}
return JSON.parse(JSON.stringify(quiz));
};
//
/**
* Elimina el quiz situado en la posición dada.
*
* @param id Clave que identifica el quiz a borrar.
*/
exports.deleteByIndex = id => {
const quiz = quizzes[id];
if (typeof quiz === "undefined") {
throw new Error(`El valor del parámetro id no es válido.`);
}
quizzes.splice(id, 1);
save();
};
// Carga los quizzes almacenados en el fichero.
load();