Giter Club home page Giter Club logo

alkemy-icons-challenge's Introduction

Alkemy-Icons-Challenge

CHALLENGE BACKEND - Java Spring Boot (API) 🚀

Objetivo

Desarrollar una API para explorar los principales íconos geográficos del mundo, la cual permitirá conocer y modificar los íconos geográficos y entender en qué ciudades o países estos se encuentran. Como por ejemplo, la torre Eiffel de París, la Estatua de la Libertad en Nueva York, el Coliseo en Italia. Por otro lado, deberá exponer la información para que cualquier frontend pueda consumirla. 👉 Utilizar Spring Boot. 👉 No es necesario armar el Frontend. 👉 Las rutas deberán seguir el patrón REST. 👉 Utilizar la librería Spring Security. ⚠️ ¡No es indispensable hacer todo! Mientras más completes, mayor puntaje obtendrás, pero puedes enviar la app hasta el estadío que la tengas en base a tu cono

Requerimientos técnicos

  1. Modelado de Base de Datos ● Íconos geográficos: deberá tener, ○ Imagen. ○ Denominación. ○ Fecha de creación. ○ Altura. ○ Historia. ○ Ciudad en la que se encuentra y otras con réplicas. ● Ciudad/País: deberá tener, ○ Imagen. ○ Denominación. ○ Cantidad de habitantes. ○ Superficie total (m2) ○ Íconos geográficos asociados. ● Continente: deberá tener,

○ Imagen. ○ Denominación. ○ Ciudades con íconos geográficos asociadas.

  1. Autenticación de Usuarios Para realizar peticiones a los endpoints subsiguientes el usuario deberá contar con un token que obtendrá al autenticarse. Para ello, deberán desarrollarse los endpoints de registro y login, que permitan obtener el token.

  2. Listado de Íconos geográficos El listado deberá mostrar: ● Imagen (no es necesario que esté persistida en la base de datos). ● Denominación.

  3. Creación, Edición y Eliminación de Íconos geográficos (CRUD) Deberán existir las operaciones básicas de creación, edición y eliminación de íconos geográficos.

  4. Detalle del Ícono geográfico En el detalle deberán listarse todos los atributos del ícono geográfico, como así también los países en los que se encuentran.

  5. Búsqueda de Íconos geográficos Deberá permitir buscar por denominación, y filtrar por fecha de creación, altura o ciudades/países en las que participó. Para especificar el término de búsqueda o filtros se deberán enviar como parámetros de query: ● GET /icons?name=denominación ● GET /icons?date=fecha de creación ● GET /icons?cities=idCity

  6. Listado de Ciudades/Países Deberá mostrar solamente los campos imagen, denominación y cantidad de habitantes. El endpoint deberá ser: ● GET /cities

  7. Detalle de Ciudad /País con sus íconos geográficos Devolverá todos los campos de la ciudad o país junto a los íconos geográficos asociados a la misma.

  8. Creación, Edición y Eliminación de Ciudades/Países (CRUD) Deberán existir las operaciones básicas de creación, edición y eliminación de ciudades o países.

  9. Búsqueda de Ciudades/Países Deberá permitir buscar por denominación, y filtrar por continente. Además, permitir ordenar los resultados por fecha de creación de forma ascendiente o descendiente. El término de búsqueda, filtro u ordenación se deberán especificar como parámetros de query: ● /cities?name=denominación ● /cities?continent=idContinent ● /cities?order=ASC | DESC

10.Envío de emails Al registrarse en el sitio, el usuario deberá recibir un email de bienvenida. Es recomendable, la utilización de algún servicio de terceros como SendGrid.

Documentación

Es deseable documentar los endpoints utilizando alguna herramienta como Postman o Swagger. Tests De forma opcional, se podrán agregar tests de los diferentes endpoints de la APP, verificando posibles escenarios de error:

  • Campos faltantes o con un formato inválido en BODY de las peticiones
  • Acceso a recursos inexistentes en endpoints de detalle Los tests pueden realizarse utilizando JUnit y Mockito.

alkemy-icons-challenge's People

Contributors

vladimirmorote avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.