Se desea implementar un sistema que permita administrar la reserva de turnos para una clínica odontológica. Esta necesita informatizar su operatoria. Por lo cual, te solicitan un sistema que debe cumplir con los siguientes requerimientos:
-
Administración de datos de odontólogos: listar, agregar, modificar y eliminar odontólogos. Registrar apellido, nombre y matrícula de los mismos.
-
Administración de datos de los pacientes: listar, agregar, modificar y eliminar pacientes. Al registrar un paciente los datos que se le solicitan son:
- Apellido
- Nombre
- DNI
- Fecha de alta
- Domicilio
- Calle
- Número
- Localidad
- Provincia
Además, le agregaremos un ID autoincremental tanto a los pacientes como a los domicilios.
Se pide utilizar H2 como base de datos, aplicar el patrón DAO y testear con JUnit. Tener en cuenta que el modelado de clases debe contar con al menos dos clases: PACIENTE y DOMICILIO, con la consideración de que los pacientes podrán tener solo un domicilio.
Crear solo una clase de servicio, PacienteService, y crear por cada entidad un DAO, es decir, DomicilioDAOH2 y PacienteDAOH2. Al guardar y buscar un paciente en PacienteDAOH2 deberás invocar el guardar y buscar de DomicilioDAOH2.
-
Registrar turno: se tiene que poder permitir asignar a un paciente un turno con un odontólogo a una determinada fecha y hora.
-
Login: validar el ingreso al sistema mediante un login con usuario y password. Se debe permitir a cualquier usuario logueado (ROLE_USER) registrar un turno, pero solo a quienes tengan un rol de administración (ROLE_ADMIN) poder gestionar odontólogos y pacientes. Un usuario podrá tener un único rol y los mismos se ingresarán directamente en la base de datos.
La aplicación debe ser desarrollada en capas:
-
Capa de entidades de negocio: son las clases Java de nuestro negocio modelado a través del paradigma orientado a objetos.
-
Capa de acceso a datos (Repository): son las clases que se encargarán de acceder a la base de datos.
-
Capa de datos (base de datos): es la base de datos de nuestro sistema modelado a través de un modelo entidad-relación. Utilizaremos la base H2 por su practicidad.
-
Capa de negocio: son las clases service que se encargan de desacoplar el acceso a datos de la vista.
-
Capa de presentación: son las pantallas web que tendremos que desarrollar utilizando el framework de Spring Boot MVC con los controladores y alguna de estas dos opciones: HTML+JavaScript para la vista.
Es importante realizar el manejo de excepciones logueando cualquier excepción que se pueda generar y la realización de test unitarios para garantizar la calidad de los desarrollos.
Tests de integración:
- Realizar test de integración para el controller de turnos, odontólogos y pacientes.
- Utilizando MockMvc, testear el endpoint que nos retorna un listado de turnos, odontólogos y pacientes.
- El test debe comprobar que el código de respuesta es 200 y que en el body nos retorna un listado de turnos, odontólogos y pacientes con datos.
- Utilizando MockMvc, testear el endpoint que nos permite registrar un nuevo turno, odontólogo y paciente.
- El test debe comprobar que el código de respuesta es 200 y que en el body nos retorne el turno, odontólogo y paciente cargado.
- Utilizando MockMvc, testear el endpoint que nos permite actualizar un turno, odontólogo y paciente.
- El test debe comprobar que el código de respuesta es 200 y que en el body nos retorne el turno, odontólogo y paciente cargado.
- Utilizando MockMvc, testear el endpoint que nos permite eliminar un turno, odontólogo y paciente.
-
Listar todos los odontólogos:
Método: GET.
PATH: /odontologos
-
Buscar un odontólogo:
Método: GET.
PATH: /odontologos/{id}
-
Guardar odontólogo:
Método: POST
PATH: /odontologos
-
Eliminar odontólogo:
Método: DELETE.
PATH: /odontologos/eliminar/{id}
-
Actualizar odontólogo:
Método: PUT
PATH: /odontologos
-
Listar todos los pacientes:
Método: GET.
PATH: /pacientes
-
Buscar un paciente:
Método: GET.
PATH: /pacientes/{id}
-
Buscar un paciente por email:
Método: GET.
PATH: /pacientes/email/{email}
-
Guardar paciente:
Método: POST
PATH: /pacientes
-
Eliminar paciente:
Método: DELETE.
PATH: /pacientes/eliminar/{id}
-
Actualizar paciente:
Método: PUT
PATH: /pacientes
-
Listar todos los turnos:
Método: GET.
PATH: /turnos
-
Buscar un turno:
Método: GET
PATH: /turnos/{id}
-
Guardar turno:
Método: POST
PATH: /turnos
-
Eliminar turno:
Método: DELETE
PATH :/turnos/{id}
-
Actualizar turno:
Método: PUT
PATH: /turnos
-
Guardar usuario:
Método: POST
PATH: /register/user
Para poder revisar la documentación, al tener implementado security, primero te pedirá tus credenciales, las cuales deberás ingresarlas como se muestra a continuación:
Pantalla de login
Luego ir a la url: http://localhost:8080/swagger-ui.html y podrás tener toda la información acerca de las APIS:
1era Pantalla de swagger
2da Pantalla de swagger
3era Pantalla de swagger
Primero debemos registrarnos para poder loguearnos, para esto iremos a la url registro.html
Pantalla de registro de usuario
Llenamos nuestros datos, tenemos la opción de registrarnos como user o admin, una vez llenamos y nos registramos nos dirigimos a la opción de login
Pantalla de registro de usuario
En esta vista te pedirá ingresar las credenciales:
Pantalla de login
Si ingresamos con un tipo admin:
Pantalla de login - admin
En esta vista podemos ver las opciones que tenemos siendo admin:
Pantalla de menu - admin
En esta vista se observa el menu pacientes
Pantalla de menu pacientes
Si deseamos agregar un paciente, ingresamos a Guardar, agregamos los datos y le damos en Guardar
Pantalla de agregar paciente
En esta vista se listan los pacientes
Pantalla de listado de pacientes
Si queremos editar algun paciente le damos click al botón celeste al lado del item de nuestro interés, llenamos los datos y le damos a modificar. En caso queramos eliminarlo le damos click a la x
Pantalla de actualizar paciente
En esta vista se observa el menu odontólogos
Pantalla de menu odontólogos - admin
Si deseamos agregar un odontólogo, ingresamos a Guardar, agregamos los datos y le damos en Guardar
Pantalla de agregar odontólogo
En esta vista se listan los odontólogos
Pantalla de listado de ondotólogos
Si queremos editar algun odontólogo le damos click al botón celeste al lado del item de nuestro interés, llenamos los datos y le damos a modificar. En caso queramos eliminarlo le damos click a la x
Pantalla de actualizar odontólogo
En caso queramos cambiar de usuario le damos click a Log Out de la parte superior derecha
Pantalla de logout
En esta vista te mostrará el login con un mensaje de deslogueado:
Pantalla de login
Si ingresamos con un tipo user:
Pantalla de login - user
En esta vista podemos ver las opciones que tenemos siendo user:
Pantalla de menu - user
En esta vista se observa el menu turnos
Pantalla de menu turnos
Si deseamos agregar un turno, ingresamos a Guardar, podemos escoger al paciente y al odóntologo desde los selects, y escoger fecha y hora desde el calendar.
Pantalla de agregar turno
Agregamos los datos y le damos en Guardar
Pantalla de agregar turno
En esta vista se listan los turnos
Pantalla de listado de turnos
Si queremos editar algun turno le damos click al botón celeste al lado del item de nuestro interés, llenamos los datos y le damos a modificar. En caso queramos eliminarlo le damos click a la x
Pantalla de actualizar turno
En caso queramos cambiar de usuario le damos click a Log Out de la parte superior derecha
Pantalla de logout
Realizado por : Sammy Gigi Cantoral Montejo (sgcm14)