# Test task ## Тестовая задача для Social Media Holding на сайте hh.ru ### ТЗ: Используя сайт https://dummyjson.com/docs/products сделать по апи добавление, получение с сохранением в базе всех продуктов "iPhone". Желательно сделать так, чтобы можно было быстро сделать потом и для recipes, posts, users. Для решения задачи был выбран фреймворк Laravel и БД SQLite. Были написаны миграции и модели в соответствии с документацией, с небольшими отклонениями: - в именах полей БД использовался snake_case - некоторые вложенные поля продукта были вынесены на уровень выше Была создана основная таблица products и связанные с ней по принципу один-ко-многим product_images и product_reviews, а также связанная по принципу многие-ко-многим таблица tags. Непосредственно получение данных и запись в БД реализовано через консольные команды Laravel. Был создан абстрактный класс для получения данных от DummyJSON и на его основе класс, который получив нужные данные преобразует их и записывает в БД. Валидация данных в данном случае не реализована, т.к. проект тестовый. Для поиска продуктов по строке был выбран метод api search. Команда работает по принципу обновить или создать, то есть исключено дублирование данных. Данные в связанных таблицах пересоздаются при каждом обновлении, т.к. нет поля, позволяющего однозначно идентифицировать запись. Для получения других данных, таких как users, posts etc нужно создать структуры БД и модели, создать команду, унаследовав класс SearchDummyJson, написать метод получения данных и метод записи в БД с обработкой и валидацией.