Skip to content

Commit

Permalink
Merge pull request #119 from Arquisoft/jota
Browse files Browse the repository at this point in the history
Fix repositori y package-locks
  • Loading branch information
UO277938 authored Apr 26, 2024
2 parents a518e3d + 9a8b174 commit 8668d3b
Show file tree
Hide file tree
Showing 49 changed files with 2,077 additions and 266 deletions.
1 change: 1 addition & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ on:
- develop
- LaraFMz
- Pablo-Arreglos
- jota
pull_request:
types: [opened, synchronize, reopened]
jobs:
Expand Down
26 changes: 13 additions & 13 deletions docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
version: '3'
services:
mongodb:
container_name: mongodb-${teamname:-defaultASW}
container_name: mongodb-${teamname:-wiq5a}
image: mongo
profiles: ["dev", "prod"]
volumes:
Expand All @@ -12,8 +12,8 @@ services:
- mynetwork

questionservice:
container_name: questionservice-${teamname:-defaultASW}
image: ghcr.io/arquisoft/wiq_es05a/questionservice:latest
container_name: questionservice-${teamname:-wiq5a}
image: ghcr.io/arquisoft/wiq_5a/questionservice:latest
profiles: ["dev", "prod"]
build: ./questionservice
ports:
Expand All @@ -25,8 +25,8 @@ services:
- mynetwork

authservice:
container_name: authservice-${teamname:-defaultASW}
image: ghcr.io/arquisoft/wiq_es05a/authservice:latest
container_name: authservice-${teamname:-wiq5a}
image: ghcr.io/arquisoft/wiq_5a/authservice:latest
profiles: ["dev", "prod"]
build: ./userservice/authservice
depends_on:
Expand All @@ -39,8 +39,8 @@ services:
MONGODB_URI: mongodb://mongodb:27017/userdb

userservice:
container_name: userservice-${teamname:-defaultASW}
image: ghcr.io/arquisoft/wiq_es05a/userservice:latest
container_name: userservice-${teamname:-wiq5a}
image: ghcr.io/arquisoft/wiq_5a/userservice:latest
profiles: ["dev", "prod"]
build: ./userservice/userservice
depends_on:
Expand All @@ -53,8 +53,8 @@ services:
MONGODB_URI: mongodb://mongodb:27017/userdb

gatewayservice:
container_name: gatewayservice-${teamname:-defaultASW}
image: ghcr.io/arquisoft/wiq_es05a/gatewayservice:latest
container_name: gatewayservice-${teamname:-wiq5a}
image: ghcr.io/arquisoft/wiq_5a/gatewayservice:latest
profiles: ["dev", "prod"]
build: ./gatewayservice
depends_on:
Expand All @@ -72,8 +72,8 @@ services:
QUESTION_SERVICE_URL: http://questionservice:8003

webapp:
container_name: webapp-${teamname:-defaultASW}
image: ghcr.io/arquisoft/wiq_es05a/webapp:latest
container_name: webapp-${teamname:-wiq5a}
image: ghcr.io/arquisoft/wiq_5a/webapp:latest
profiles: ["dev", "prod"]
build: ./webapp
depends_on:
Expand All @@ -83,7 +83,7 @@ services:

prometheus:
image: prom/prometheus
container_name: prometheus-${teamname:-defaultASW}
container_name: prometheus-${teamname:-wiq5a}
profiles: ["dev"]
networks:
- mynetwork
Expand All @@ -94,7 +94,7 @@ services:

grafana:
image: grafana/grafana
container_name: grafana-${teamname:-defaultASW}
container_name: grafana-${teamname:-wiq5a}
profiles: ["dev"]
networks:
- mynetwork
Expand Down
Binary file removed docs/images/03_2_contexto_tecnico.png
Binary file not shown.
Binary file added docs/images/03_2_contexto_tecnico2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/images/05_2_nivel_2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/images/05_nivel_2.png
Binary file not shown.
Binary file removed docs/images/05_sistema-general-caja-blanca.png
Binary file not shown.
Binary file added docs/images/05_sistema-general-caja-blanca_2.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/images/06_acceso2.png
Binary file not shown.
Binary file added docs/images/06_acceso3.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/images/06_pregunta2.png
Binary file not shown.
Binary file added docs/images/06_pregunta4.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/images/07_DiagramaDespliegue5.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
14 changes: 7 additions & 7 deletions docs/src/01_introduction_and_goals.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ These include
* relevant stakeholders and their expectations
****

El objetivo es crear una aplicación web llamada WIQ_es05 basada en el programa de televisión "Saber y Ganar".
El objetivo es crear una aplicación web llamada QuizMaster basada en el programa de televisión "Saber y Ganar".
La aplicación permitirá registrarse a los usuarios para poder jugar. Dicho juego consiste en una serie de preguntas generadas aleatoriamente, de diferentes temáticas y respuestas, que deberán responderse en un tiempo determinado.
Por cada respuesta correcta se obtendrá un premio.

Expand Down Expand Up @@ -53,7 +53,7 @@ See https://docs.arc42.org/section-1/[Introduction and Goals] in the arc42 docum
* *Acceso a Información de Usuarios vía API*: Otros sistemas podrán acceder a los datos de los usuarios a través de un API.
* *Acceso a Información de Preguntas vía API*: Otros sistemas podrán acceder a los detalles de las preguntas generadas mediante un API.

Mira los https://docs.google.com/document/d/1pahOfYFY--Wi7_9bbxiKOGevB_9tOSyRm78blncgBKg/edit[Requisitos de la práctica] para obtener más información.
Mira los (https://docs.google.com/document/d/1pahOfYFY--Wi7_9bbxiKOGevB_9tOSyRm78blncgBKg/edit)[Requisitos de la práctica] para obtener más información.


=== Metas de Calidad
Expand All @@ -80,10 +80,10 @@ A table with quality goals and concrete scenarios, ordered by priorities
[cols="e,2e" options="header"]
|===
|Nombre|Descripción
|*Usabilidad*| _La aplicación tiene que poder usarse por el mayor tipo de usuarios, promoviendo una experiencia intuitiva y accesible desde el primer contacto. Además, a medida que los usuarios interactúan más con la aplicación, esta se vuelva más fácil de usar._
|*Rendimiento*| _El tiempo de respuesta de la aplicación debe ser rápido_
|*Usabilidad*| _La aplicación tiene que poder usarse por el mayor tipo de usuarios, promoviendo una experiencia intuitiva y accesible desde el primer contacto.Conforme los usuarios se familiarizan y exploran más la aplicación, su uso se vuelve más intuitivo y sencillo, gracias a la curva de aprendizaje._
|*Rendimiento*| _La aplicación debe de ofrecer un tiempo de respuesta rápido para garantizar una experiencia fluida y eficiente para los usuarios._
|*Testeable*| _Las pruebas deben ser capaces de detectar errores de manera rápida y precisa, fáciles de mantener y actualizar a medida que el código base cambia. Esto implica que las pruebas estén bien estructuradas y documentadas._
|*Disponibilidad*| _La aplicación debe estar disponible y caerse lo menos posible_
|*Disponibilidad*| _Debemos asegurar que la aplicación esté funcional y operativa durante la mayor parte del tiempo._
|===
=== Stakeholders

Expand Down Expand Up @@ -113,7 +113,7 @@ Table with role names, person names, and their expectations with respect to the
| *Profesor* | _Aplicar correctamente los conocimientos y competencias adquiridos en la asignatura Arquitectura del Software_ | _Profesor de la asignatura_
| *HappySw* | _Una aplicación buena para atraer al mayor número de usuarios_ | _Equipo de desarrollo_
| *Wikidata* | _Usar su aplicacion con precaución, sin sobrecargar sus servicios_ | _Empresa que nos facilita la API para obtener información_
| *Usuarios Registrados* | _Poder jugar en la aplicación que recrea el juego sin tener que participar en el programa._ | _Usuarios que ya han jugado anteriormente_
| *Usuarios No Registrados* | _Poder registrarse lo más rápido posible para empezar a jugar al juego de preguntas y respuestas_ | _Usuarios que nunca jugaron antes_
| *Usuarios Registrados* | _Poder jugar en la aplicación que recrea el juego sin tener que participar en el programa._ | _Usuarios registrados en la plataforma, pudiendo haber jugado una o más partidas._
| *Usuarios No Registrados* | _Poder registrarse lo más rápido posible para empezar a jugar al juego de preguntas y respuestas_ | _Usuarios que nunca se han registrado antes_
| *RTVE* | _Versión mejorada de "Saber y Ganar" para ganar mayor audiencia e interés social._ | _Dueño del producto_
|===
11 changes: 6 additions & 5 deletions docs/src/02_architecture_constraints.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@ y realizar las pruebas pertinentes._

|*Wikidata*
|_En la asignatura se requiere que esta sea la fuente de información principal para generar aleatoriamente tanto las preguntas como las respuestas correctas e incorrectas del juego._

|*APIs rest*
|_Son una limitación por varias razones, no proporcionan seguridad avanzada, no ofrecen un esquema de datos detallados, pueden no ser ideales para
operaciones mas complejas y requieren endpoints predefinidos._
|===

=== Limitaciones organizativas
Expand Down Expand Up @@ -87,15 +91,12 @@ a través de nuestro grupo de WhatsApp y en casos necesarios realizamos reunione
|Restricción |Explicación

|*Diseño del software*
|_Para lograr un buen diseño es indispensable que el código de la aplicación sea flexible, mantenible y comprensible. Además se espera un código limpio ('clean code'),
es decir, que sea fácil de entender, mantener y modificar, y que garantize la claridad, simplicidad y legibilidad._
|_Para lograr un buen diseño es indispensable que el código de la aplicación sea flexible, mantenible y comprensible. Además se espera un que sigamos los principios de "codigo limpio"
en cuanto a modularidad, limpieza, nombrado de métodos y variables._

|*Documentación*
|_Para crearla usaremos la plantilla Arc42 con la finalidad de que sea sencilla y práctica._

|*Accesibilidad*
|_Nos esforzaremos para que nuestra aplicación sea accesible para todos los usuarios, independientemente de su perfil o características individuales._

|*Estructura*
|_Debe seguir una estructura de paquetes fija y bajo los mismos estandares. Los diferentes modulos estarán separados en carpetas: 'userservice' para la gestión de
usuarios (registro y autentificación), 'questionservice' para la comunicación con wikidata y 'webapp' para el desarrollo de la aplicación. Todos estos
Expand Down
24 changes: 13 additions & 11 deletions docs/src/03_system_scope_and_context.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ together with a mapping table showing the relationships between channels and inp
****

image::03_2_contexto_tecnico.png["Diagrama de contexto técnico"]
image::03_2_contexto_tecnico2.png["Diagrama de contexto técnico"]

[options="header",cols="1e,2"]
|===
Expand All @@ -95,36 +95,38 @@ image::03_2_contexto_tecnico.png["Diagrama de contexto técnico"]
|Contiene el frontend y backend de la aplicación.

|*MongoDB*
|Base de datos no relacional para el almacenamiento de usuarios.
|Base de datos no relacional para el almacenamiento de usuarios y registro de sus partidas.

|*Usuario*
|El usuario final de la aplicación.
|Persona que interactua con nuestra aplicación web a través del navegador.

|*Wikidata API*
|API de donde obtendremos las preguntas y respuesta correcta para el juego de la aplicación.
|API de donde obtendremos las preguntas y respuestas correctas y falsas para el juego de la aplicación, todas estas preguntas serán cargadas al inicio del juego.

|*Javascript*
|Lenguaje de programación principal de la aplicación.
|Lenguaje de programación principal de la aplicación permite una sintaxis uniforme en toda la aplicación y facilita el mantenimiento del código. Además, al usar JavaScript en el frontend y el backend, se puede compartir lógica entre ambas partes para un desarrollo más eficiente.

|*Express JS*
|Framework para la creación de aplicaciones web en Javascript, utilizado en el backend.
|Express es un framework de aplicación web para Node.js, que te permite crear aplicaciones web robustas y escalables en JavaScript para el backend.

|*React*
|Biblioteca de Javascript para creación de interfaces de usuario, utilizado en el frontend.

|*Bootstrap*
|Biblioteca para el diseño de aplicaciónes web.

|Biblioteca de código abierto que proporciona herramientas y estilos para el diseño de aplicaciones web y sitios responsivo. Podemos crear interfaces de usuario atractivas y funcionales de manera rápida y sencilla

|*webapp*
|Módulo del sistema que se encarga de la interfaz del sistema.

|*questionservice*
|Módulo del sistema que se encarga de la creación de preguntas con la API de Wikidata.
|Módulo del sistema que se encarga de crear preguntas obteniendo tanto preguntas como respuestas correctas e incorrectas de la API Wikidata

|*gateway*
|Módulo del sistema que se encarga de coordinar el resto de modulos del sistmea.
|Módulo del sistema que funcina como puerta de enlace para coordinar el resto de modulos del sistema.

|*userservice*
|Módulo del sistema que se encarga de tener los modelos y hacer las consultas para el almacenamiento correcto de los usuarios de la aplicación.
|Módulo del sistema que se encarga de tener los modelos y hacer las consultas para el almacenamiento correcto de los usuarios de la aplicación y del registro de partidas con la ayuda de nuestra base de datos MongoDB.

|*authservice*
|Módulo del sistema que se encarga de gestionar la autenticación del usuario.
|===
4 changes: 2 additions & 2 deletions docs/src/04_solution_strategy.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -31,13 +31,13 @@ See https://docs.arc42.org/section-4/[Solution Strategy] in the arc42 documentat
****

* *JavaScript*: Este lenguaje es muy buena opción para utilizar en proyectos en que se empleé la biblioteca REACT. Nos pareció mejor opción que otros lenguajes como TypeScript debido a que su compresión y manejo es más sencillo.
* *JavaScript*: Este lenguaje es muy buena opción para utilizar en proyectos en que se empleé la biblioteca REACT. Nos pareció mejor opción que otros lenguajes como TypeScript debido a que su compresión y manejo es más sencillo. Además usamos Express es una infraestructura de aplicaciones web en Node.js que ofrece una solución rápida, minimalista y flexible para desarrollar aplicaciones web y móviles1

* *React*: Esta libreria de JavaScript permite la creación de interfaces de usuario para la aplicacion web de forma sencilla.

* *Docker*: Utilizaremos esta plataforma para desplegar la aplicacion web, de manera que puedan realizarse pruebas aisladas de esta misma.

* *Firebase*: Esta API nos servirá como sistema de autenticación del usuario para poder llevar un registro de su historial de partidas, así como algunas de sus estadísticas.
* *Mongo-DB*: Esta API nos servirá como sistema de autenticación del usuario para poder llevar un registro de su historial de partidas, así como algunas de sus estadísticas.

* *Microservicios:* Enfoque arquitectónico donde el software está compuesto por pequeños servicios independientes. Lo hemos elegido debido a la facilidad para modificar una parte de la aplicación sin afectar al resto.

Expand Down
25 changes: 14 additions & 11 deletions docs/src/05_building_block_view.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,7 @@ In the best case you will get away with examples or simple signatures.
****

image::05_sistema-general-caja-blanca.png["Sistema General de Caja Blanca"]
image::05_sistema-general-caja-blanca_2.png["Sistema General de Caja Blanca"]


Motivación::
Expand All @@ -78,13 +78,10 @@ Bloques de construcción contenidos::
|Nombre |Responsabilidad

|*Usuario*
|_Usuario que interactua con la aplicación._

|*Administrador*
|_Persona(s) que tienen acceso completo a la aplicación y puede administrarla._
|_Cuando alguien usa nuestra aplicación, se comunica con ella a través de Internet usando un lenguaje especial llamado HTTP. Cuando se registra en la aplicación, los datos que ingresa se guardan en una base de datos especial llamada MongoDB. Para que esto suceda, usamos una herramienta llamada Mongoose, que nos ayuda a conectarnos y comunicarnos con la base de datos de una manera fácil y segura. Entonces, cada vez que alguien se registra en nuestra aplicación, Mongoose se asegura de guardar esos datos en la base de datos para que puedan ser utilizados más tarde._

|*WIQ*
|_La propia aplicación._
|_La propia aplicación, encargada de pedir las preguntas a wikidata para poder llevar a cabo la partida._

|*Wikidata*
|_Servicio externo desde donde obtenemos los datos para generar las preguntas._
Expand All @@ -93,7 +90,7 @@ Bloques de construcción contenidos::

=== Nivel 2: WIQ

image::05_nivel_2.png["Nivel 2 de la aplicación: WIQ"]
image::05_2_nivel_2.png["Nivel 2 de la aplicación: WIQ"]

Bloques de construcción contenidos::
[cols="e,2e" options="header"]
Expand All @@ -104,21 +101,27 @@ Bloques de construcción contenidos::
|_La interfaz con la que interactua el usuario._

|*gatewayservice*
|_Servicio de puerta de enlace que actúa como intermediario entre los clientes y otros servicios,
|_Servicio de puerta de enlace que actúa como intermediario entre los usuario que quieran juagar y otros servicios,
reenviando las solicitudes a los servicios correspondientes y devolviendo las respuestas al cliente._

|*authservice*
|_Servicio de autenticación de usuarios._
|_Servicio que se encarga de verificar las credenciales de los usuarios al iniciar sesión en la aplicación. Si las credenciales son correctas, se genera un token de acceso que permite al usuario autenticado acceder a partes protegidas de la aplicación._

|*userservice*
|_Servicio para registro de usuarios._
|_Servicio que gestiona el registro de nuevos usuarios en la aplicación. Cuando un usuario se registra, se asegura de que se proporcionen los campos necesarios y luego cifra la contraseña antes de guardarla. También ofrece funciones para actualizar las estadísticas del usuario y obtener información de usuario._

|*questionservice*
|_Servicio para el manejo de datos de Wikidata._
|_Este servicio se encarga de proporcionar preguntas y respuestas basadas en datos de Wikidata. Utiliza consultas SPARQL para obtener información de Wikidata y luego genera preguntas aleatorias basadas en estos datos para ser utilizadas en la aplicación."_

|*Wikidata*
|_Servicio externo desde donde obtenemos los datos para generar las preguntas._

|*MongoDB*
|_MongoDB es un sistema de gestión de bases de datos NoSQL utilizado en la aplicación para almacenar y organizar los datos de manera eficiente. Su responsabilidad principal es gestionar la persistencia de los datos de la aplicación, permitiendo el almacenamiento, consulta y manipulación de la información de manera escalable y flexible._

|*OpenAPI*
|_Encargado de la especificación utilizada junto a swagger para la creación de una documentacio de todos los métodos que se realizan en gateway._

|===


Loading

0 comments on commit 8668d3b

Please sign in to comment.