https://github.com/ptrvsrg/places
Приложение для поиска мест, использующее асинхронное сетевое взаимодействие с несколькими публичными API
https://github.com/ptrvsrg/places
api cache java maven reactive-programming spring thymeleaf webflux
Last synced: about 2 months ago
JSON representation
Приложение для поиска мест, использующее асинхронное сетевое взаимодействие с несколькими публичными API
- Host: GitHub
- URL: https://github.com/ptrvsrg/places
- Owner: ptrvsrg
- Created: 2023-10-29T13:04:51.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-11-02T18:01:02.000Z (over 2 years ago)
- Last Synced: 2023-11-02T19:23:13.120Z (over 2 years ago)
- Topics: api, cache, java, maven, reactive-programming, spring, thymeleaf, webflux
- Language: Java
- Homepage: http://places.petrov-projects.ru
- Size: 142 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Места (Асинхронное сетевое взаимодействие)
Используя методы асинхронного программирования (например, `CompletableFuture` для Java) или библиотеки реактивного
программирования (`RxJava`, например) повзаимодействовать с несколькими публично доступными API и сделать приложение с
любым интерфейсом, основанное на этих API. При этом API должны использоваться так:
+ Все вызовы должны делаться с помощью HTTP-библиотеки с асинхронным интерфейсом;
+ Все независимые друг от друга вызовы API должны работать одновременно;
+ Вызовы API, которые зависят от данных, полученных из предыдущих API, должны оформляться в виде асинхронной цепочки
вызовов;
+ Не допускаются блокировки на ожидании промежуточных результатов в цепочке вызовов, допустима только блокировка на
ожидании конечного результата (в случае консольного приложения). Другими словами, вся логика программы должна быть
оформлена как одна функция, которая возвращает `CompletableFuture` (или аналог в вашем ЯП) без блокировок.
## Логика работы
1. В поле ввода пользователь вводит название чего-то (например "Цветной проезд") и нажимает кнопку поиска;
2. Ищутся варианты локаций с помощью метода [1] и показываются пользователю в виде списка;
3. Пользователь выбирает одну локацию;
4. С помощью метода [2] ищется погода в локации и показывается пользователю;
5. С помощью метода [3] ищутся интересные места в локации, далее для каждого найденного места с помощью метода [4] ищутся
описания, всё это показывается пользователю в виде списка.
## Методы API
1. Получение локаций с координатами и названиями: https://docs.graphhopper.com/#operation/getGeocode
2. Получение погоды по координатам https://openweathermap.org/current
3. Получение списка интересных мест по координатам: https://dev.opentripmap.org/docs#/Objects%20list/getListOfPlacesByRadius
4. Получение описания места по его id: https://dev.opentripmap.org/docs#/Object%20properties/getPlaceByXid
5. Отображение карты по координатам: https://yandex.ru/dev/maps/jsbox/2.1/placemark