Skip to content

Java program that returns the source and content of the help message

Notifications You must be signed in to change notification settings

cesar0914/quasar-fire-operation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Proyecto Operación Fuego de Quásar

Este proyecto es una aplicación en Java que resuelve el desafío de la Operación Fuego de Quásar. La aplicación permite determinar la ubicación y el mensaje de auxilio de una nave a partir de la información recibida en diferentes satélites. Se utiliza Spring Boot como framework de desarrollo y MongoDB como base de datos para almacenar la información.


Config

Uso:

Esta aplicación se encuentra desplegada en una instancia de oracle compute, para probar cada endpoint desde cualquier parte, simplemente accede a la URL de Swagger que se menciona posteriormente y utiliza la interfaz de Swagger para interactuar con los diferentes endpoints de la aplicación Operación Fuego de Quásar. Desde allí, podrás realizar pruebas, enviar solicitudes y recibir respuestas según la funcionalidad proporcionada por cada endpoint.

La disponibilidad y accesibilidad de la aplicación y las herramientas dependen del estado y la configuración de la instancia de Oracle Compute en Oracle Cloud.

Swagger:

Al acceder a esta URL, se abrirá la interfaz de Swagger, que proporciona una documentación detallada de los endpoints disponibles en la aplicación Operación Fuego de Quásar. Desde Swagger, se pueden probar los endpoints y ver su descripción, parámetros y respuestas.

Mongo-express:

Al acceder a esta URL, se abrirá la interfaz de Mongo Express para la base de datos "quasar" en MongoDB. Desde Mongo Express, se pueden administrar y visualizar los datos almacenados en la base de datos.

Ejecución entorno local

Requisitos:

Asegúrate de tener los siguientes requisitos antes de ejecutar el proyecto en entorno local:

Java 11 o superior

Docker y Docker Compose

Puertos 8081, 9500, 27017

Proceso:

  • Clona el repositorio a tu máquina local
git clone https://github.com/tu-usuario/quasar-fire-operation.git
  • Ingresa al directorio del proyecto
cd quasar-fire-operation
  • Accede a la carpet docker y levanta los contenedores de mongo y mongo-express
docker-compose up -d mongo mongo-express
  • Construye el archivo JAR:
./mvnw clean package
  • Una vez que hayas construido el archivo JAR, puedes ejecutar la API localmente utilizando el siguiente comando:
java -jar target/quasar-fire-operation.jar

API

La API Quasar Fire Operation proporciona los siguientes endpoints:

Obtener la posición y el mensaje secreto

  • Método: POST
  • Ruta: /api/v1/quasar/topsecret
  • Descripción: Este servicio permite obtener la posición y el mensaje secreto de la nave.
  • Parámetros de entrada:
    • Cuerpo (application/json):
{
  "satellites": [
    {
      "name": "kenobi",
      "distance": 100.0,
      "message": ["este", "", "", "mensaje", ""]
    },
    {
      "name": "skywalker",
      "distance": 115.5,
      "message": ["", "es", "", "", "secreto"]
    },
    {
      "name": "sato",
      "distance": 142.7,
      "message": ["este", "", "un", "", ""]
    }
  ]
}

Actualizar la distancia y el mensaje de un satélite específico.

  • Método: POST
  • Ruta: /api/v1/quasar/topsecret_split/{satelliteName}
  • Descripción: Permite actualizar la distancia y el mensaje de un satélite específico.
  • Parámetros de entrada:
    • Cuerpo (application/json):

{
  "distance": 100.0,
  "message": ["este", "", "", "mensaje", ""]
}

Obtener la posición y el mensaje secreto previamente registrados.

  • Método: GET
  • Ruta: /api/v1/quasar/topsecret_split
  • Descripción:  Permite obtener la posición y el mensaje secreto a partir de la información previamente registrada de los satélites.

Pruebas

El proyecto incluye pruebas unitarias utilizando JUnit 5 y Mockito. Para ejecutar las pruebas, puedes utilizar el siguiente comando:

./mvnw test

Diagramas


Config

Controller

Service

Model

Exception

Repository

Utils

Arquitectura:

La arquitectura del proyecto de Operación Fuego de Quásar sigue un enfoque basado en microservicios. Está compuesta por los siguientes componentes:

Microservicio principal: Este microservicio es responsable de recibir las solicitudes HTTP, procesar la información y devolver la posición de la nave y el mensaje decodificado. Está implementado en Java utilizando el framework Spring Boot.

Base de datos MongoDB: Se utiliza una base de datos MongoDB para almacenar la información de los satélites y sus mensajes. El microservicio interactúa con la base de datos para almacenar y recuperar la información necesaria.

Mongo Express: Es una interfaz de usuario web que permite visualizar y administrar la base de datos MongoDB de manera sencilla. Se utiliza para facilitar la verificación y manipulación de los datos almacenados.

La comunicación entre los componentes se realiza a través de solicitudes HTTP utilizando el protocolo RESTful. El microservicio principal expone endpoints para recibir las solicitudes POST y GET, y se encarga de procesar los datos utilizando algoritmos específicos para determinar la posición y el mensaje. La información necesaria para realizar estos cálculos se almacena y recupera de la base de datos MongoDB.

El proyecto también incluye pruebas unitarias para garantizar la calidad y el correcto funcionamiento del código. Estas pruebas se ejecutan utilizando JUnit 5 y Mockito, y se centran en verificar el comportamiento esperado de los diferentes componentes.

Además, se utiliza Docker y Docker Compose para facilitar la ejecución del proyecto en diferentes entornos y simplificar la configuración de los servicios necesarios, como la base de datos MongoDB y Mongo Express.

Esta arquitectura modular y basada en microservicios permite una mayor flexibilidad, escalabilidad y mantenibilidad del proyecto. Cada componente tiene responsabilidades específicas y puede ser desarrollado, probado y desplegado de manera independiente, lo que facilita la evolución y la gestión del sistema en su conjunto.

Conclusiones:

Este proyecto puede servir como base para la implementación de sistemas más complejos de rastreo de naves espaciales o comunicaciones en tiempo real. Se pueden realizar mejoras adicionales, como la autenticación y autorización de la API, la implementación de un mecanismo de persistencia más robusto o la integración con otros sistemas.

About

Java program that returns the source and content of the help message

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages