Рест ядро магазина. Проект не решает никакой проблемы. Это просто учебный проект.
Особенности проекта:
- Апи сервиса собрано на рест контроллерах Spring Boot 2.1.4.
- В качестве основной бд выбрана PostgreSql 10(версия вообще не принципиальна).
- Для взаимодействия с бд использовались JpaRepository из Spring Data Jpa. Схема бд создаётся на основе созданных jpa сущностей.
- Для модульных и интеграционных тестов использовался junit + mockito.
- С помощью плагина surefire из жизненного цикла сборки проекта исключён каталог с модульными тестами и добавлен с интеграционными.
- Для интеграционных тестов используется postgresql-embedded.
- Для контроля и ограничения доступа к апи, было принято решение использовать io.jsonwebtoken. Был реализован SecurityHandlerInterceptor для фильтрации всех запросов.
Недоработки, которые хотелось бы устранить\обдумать, но лень:
- Можно было разбить всё это дело на микро сервисы/модули. К примеру, отдельно сервер безопасности, отдельно crud-репозиторий с бизнес логикой.
- Вместо Rest api, можно использовать GraphQL. Или как-то их совместить.
- Почему-то я не использовал dto/pojo классы для представления данных. Решил всё делать в сущностях Jpa, думаю это небезопасно, да и неудобно.
- Я попрежнему считаю, что в больших проектах очень странно использовать голые sql запросы, особенно автогенерируемые спрингом/хибернейтом, так-как намного сложнее отлаживать взаимодействие приложения и бд. А найти проблему в случае возникновения ошиюки становится сильно сложнее. Не решена проблема n+1 запросов.
- jpa сущности должны быть всё-таки без геттеров и сеттеров. В них не должно быть намешано ничего постароннего (джексон, использовался как dto/pojo объект).
- Интеграционные тесты лучше проводить не с помощью Junit. В этом проекте было решено использовать junit с синхронным вызовом помеченных аннотацией методовю.
- Для данного проекта не самая лучшая идея в принципе использовать jwt токены. В качестве альтернативы можно было использовать аутентификацию по сертификатам.
- Возможно не лучший плагин был выбран для исключения модульных тестов из фазы сборки проекта. Возможно не лучшая идея была модульные тесты из проекта отключать. Но это можно регулировать добавлением новых фаз и профилей. Плагин surefire подпортил ситуацию с курилицей в проекте.
- Планировалось добавить MongoDB или какую-нибудь другую noSql бд для хранения изображений товаров, но зачем? Слишком много гемора.
- Тема работы со временем не раскрыта. Хотелось хранить время в uts-0 в юникс-тайме, без всяких свистоперделок. Неопределился, так наверно тоже нормально.
- Встроенная бд может забивать оперативную память и процессорное время. Иногда во время разработки можно заметить огромное количество процессов postgresql и ахнуть.
- Хотелось добавить сюда swagger или аналоги ради интереса.