- добавлен React/Vite-лендинг с карточками документаций - добавлена генерация корневого llms.txt из конфига документов - добавлена сборка SLM Design через VitePress - добавлены Dockerfile, Caddyfile и Gitea CI/CD - настроены контекстные Link headers для llms.txt
51 lines
2.8 KiB
Markdown
51 lines
2.8 KiB
Markdown
---
|
||
title: REST-клиент
|
||
description: Настройка REST-клиента сервиса для работы с внешним API.
|
||
keywords: [rest, api, данные, infra, клиент, swr, стратегии]
|
||
---
|
||
|
||
# REST-клиент
|
||
|
||
Настройка REST-клиента сервиса для работы с внешним API.
|
||
|
||
## Настройка
|
||
|
||
Для каждого внешнего сервиса создаётся отдельный API-клиент: `pet-store-api`, `billing-api`, `maps-api`.
|
||
|
||
На этом этапе внешний API оформляется как модуль слоя `infra/`.
|
||
|
||
Клиент отвечает за:
|
||
|
||
- генерацию или ручное описание методов API;
|
||
- настройку `baseUrl`;
|
||
- заголовки и авторизацию;
|
||
- обработку ошибок;
|
||
- кастомизацию и расширение типов;
|
||
- GET-хуки для клиентских компонентов;
|
||
- прямое использование методов клиента в серверном коде и submit-функциях;
|
||
- публичный API модуля.
|
||
|
||
Если у API есть OpenAPI-спецификация — клиент генерируется автоматически. Если OpenAPI нет или он неполный — клиент создаётся вручную.
|
||
|
||
GET-хуки относятся к клиенту, потому что это прозрачные SWR-обёртки над GET-методами этого клиента.
|
||
|
||
Подробнее:
|
||
|
||
- [Настройка REST-клиента](/docs/applied/rest-client/setup/)
|
||
- [Автогенерация из OpenAPI](/docs/applied/rest-client/setup/auto)
|
||
- [Ручное создание](/docs/applied/rest-client/setup/manual)
|
||
- [GET-хуки REST-клиента](/docs/applied/rest-client/setup/hooks)
|
||
- [Использование REST-клиента](/docs/applied/rest-client/usage)
|
||
|
||
## Как читать раздел
|
||
|
||
Если API ещё не подключён — начните с [Настройки REST-клиента](/docs/applied/rest-client/setup/).
|
||
|
||
Если клиент уже создан и нужно вызвать его методы — откройте [Использование REST-клиента](/docs/applied/rest-client/usage).
|
||
|
||
Если клиент уже есть, но непонятно как получить данные — начните с раздела [Получение данных](/docs/applied/data-fetch/).
|
||
|
||
Если данные нужны в Client Component — сначала проверьте, есть ли [GET-хук REST-клиента](/docs/applied/rest-client/setup/hooks).
|
||
|
||
Если в коде появляется бизнес-смысл вроде `isAuth`, `canEdit`, `hasAccess` — это уже не REST-клиент, а `business/`.
|