Telegram Group & Telegram Channel
API. Проектирование параметров: от концепции ➡️ к реальным запросам

Когда мы описываем ресурс, хочется просто «вынести наружу» все его поля. Но API‑дизайн требует дисциплины: параметр должен передавать только то, что реально нужно клиенту — и только то, что он способен прислать. Смотрим, как это работает на примере создания‑обновления‑замены товара.

➡️ Один ресурс — разные представления
Концепция товара хранит всё: reference, name, price, dateAdded, supplier

Запрос на  добавление:
🔚клиент не знает reference и dateAdded — их генерирует сервер.
🔚supplier упрощаем до  supplierReference: строку легко взять со штрих‑кода или из другого эндпойнта.

Запрос на  обновление/замену:
🔚reference уже в  URL  /products/{reference} — в теле повторять нечего.
🔚всё остальное — только то, что реально меняем.
Итог: одна и та же сущность представлена по‑разному в разных контекстах.

➡️ Правило минимального набора
Параметр должен предоставлять необходимые данные, но не более того.

🔚Убираем всё, что рассчитывается или хранится сервером.
🔚Стреляем по воде: сложные вложенные объекты → ссылки (supplierReference).
🔚Если поле не нужно для выполнения операции — безжалостно вон.

➡️ Чек‑лист Откуда берётся каждое свойство?
вопрос → действие

Клиент уже знает значение? → Берём как есть.
Можно вытянуть из свежего ответа API? → Расширяем нужный эндпойнт.
Данные генерирует сервер? → Убираем из  тела запроса.
Поле всё‑таки нужно, но  источника нет → Добавляем недостающую цель/эндпойнт.
Так мы гарантируем, что клиент всегда способен составить запрос без магии и угадывания.

➡️ Параметр free‑query: свободный текстовый поиск
Это строка фильтра для поиска: имя, часть описания или ссылка.
Тот же принцип: удобство клиента > идеальная модель. Главное — понятно задокументировать, как именно сервер трактует ввод.

➡️ Помним о  постоянном совершенствовании
При переходе от концепции к параметрам нередко всплывают пробелы: А  как клиент узнает supplierReference?.
Это нормально:
🔚выявили дыру
🔚добавили недостающий эндпойнт или уточнили существующий
🔚пересмотрели параметры
Так слой за слоем API становится стройнее и  дружелюбнее.

Оптимальный параметр — это не короткая копия ответа, а точно выверенный набор данных, который клиент способен предоставить здесь и сейчас. Режем лишнее, генерируем серверное, даём ссылки вместо вложенностей и всегда задаём вопрос: Откуда у клиента эти данные?
➡️  Следуйте чек‑листу, и ваши эндпойнты будут простыми, предсказуемыми и приятными в работе.

PS
Когда вы решите использовать определенный тип API, важно знать, что иногда можно столкнуться с ограничениями. Вы можете изо всех сил пытаться найти представление цели, которая соответствует выбранной модели API, или получить представление, соответствующее модели, но оно будет не таким удобным для пользователя, как вы ожидали. Иногда идеального представления не существует, поэтому вам, как проектировщику API, придется искать компромисс.


#навыкАналитика #REST #api #чек_лист #проектирование #IT
Please open Telegram to view this post
VIEW IN TELEGRAM
6👍6🔥32



group-telegram.com/BalticAnalyst/595
Create:
Last Update:

API. Проектирование параметров: от концепции ➡️ к реальным запросам

Когда мы описываем ресурс, хочется просто «вынести наружу» все его поля. Но API‑дизайн требует дисциплины: параметр должен передавать только то, что реально нужно клиенту — и только то, что он способен прислать. Смотрим, как это работает на примере создания‑обновления‑замены товара.

➡️ Один ресурс — разные представления
Концепция товара хранит всё: reference, name, price, dateAdded, supplier

Запрос на  добавление:
🔚клиент не знает reference и dateAdded — их генерирует сервер.
🔚supplier упрощаем до  supplierReference: строку легко взять со штрих‑кода или из другого эндпойнта.

Запрос на  обновление/замену:
🔚reference уже в  URL  /products/{reference} — в теле повторять нечего.
🔚всё остальное — только то, что реально меняем.
Итог: одна и та же сущность представлена по‑разному в разных контекстах.

➡️ Правило минимального набора

Параметр должен предоставлять необходимые данные, но не более того.

🔚Убираем всё, что рассчитывается или хранится сервером.
🔚Стреляем по воде: сложные вложенные объекты → ссылки (supplierReference).
🔚Если поле не нужно для выполнения операции — безжалостно вон.

➡️ Чек‑лист Откуда берётся каждое свойство?
вопрос → действие

Клиент уже знает значение? → Берём как есть.
Можно вытянуть из свежего ответа API? → Расширяем нужный эндпойнт.
Данные генерирует сервер? → Убираем из  тела запроса.
Поле всё‑таки нужно, но  источника нет → Добавляем недостающую цель/эндпойнт.
Так мы гарантируем, что клиент всегда способен составить запрос без магии и угадывания.

➡️ Параметр free‑query: свободный текстовый поиск
Это строка фильтра для поиска: имя, часть описания или ссылка.
Тот же принцип: удобство клиента > идеальная модель. Главное — понятно задокументировать, как именно сервер трактует ввод.

➡️ Помним о  постоянном совершенствовании
При переходе от концепции к параметрам нередко всплывают пробелы: А  как клиент узнает supplierReference?.
Это нормально:
🔚выявили дыру
🔚добавили недостающий эндпойнт или уточнили существующий
🔚пересмотрели параметры
Так слой за слоем API становится стройнее и  дружелюбнее.

Оптимальный параметр — это не короткая копия ответа, а точно выверенный набор данных, который клиент способен предоставить здесь и сейчас. Режем лишнее, генерируем серверное, даём ссылки вместо вложенностей и всегда задаём вопрос: Откуда у клиента эти данные?
➡️  Следуйте чек‑листу, и ваши эндпойнты будут простыми, предсказуемыми и приятными в работе.

PS
Когда вы решите использовать определенный тип API, важно знать, что иногда можно столкнуться с ограничениями. Вы можете изо всех сил пытаться найти представление цели, которая соответствует выбранной модели API, или получить представление, соответствующее модели, но оно будет не таким удобным для пользователя, как вы ожидали. Иногда идеального представления не существует, поэтому вам, как проектировщику API, придется искать компромисс.


#навыкАналитика #REST #api #чек_лист #проектирование #IT

BY Аналитик на Балтике | Всё о карьере в IT




Share with your friend now:
group-telegram.com/BalticAnalyst/595

View MORE
Open in Telegram


Telegram | DID YOU KNOW?

Date: |

Markets continued to grapple with the economic and corporate earnings implications relating to the Russia-Ukraine conflict. “We have a ton of uncertainty right now,” said Stephanie Link, chief investment strategist and portfolio manager at Hightower Advisors. “We’re dealing with a war, we’re dealing with inflation. We don’t know what it means to earnings.” Following this, Sebi, in an order passed in January 2022, established that the administrators of a Telegram channel having a large subscriber base enticed the subscribers to act upon recommendations that were circulated by those administrators on the channel, leading to significant price and volume impact in various scrips. The regulator said it had received information that messages containing stock tips and other investment advice with respect to selected listed companies are being widely circulated through websites and social media platforms such as Telegram, Facebook, WhatsApp and Instagram. Channels are not fully encrypted, end-to-end. All communications on a Telegram channel can be seen by anyone on the channel and are also visible to Telegram. Telegram may be asked by a government to hand over the communications from a channel. Telegram has a history of standing up to Russian government requests for data, but how comfortable you are relying on that history to predict future behavior is up to you. Because Telegram has this data, it may also be stolen by hackers or leaked by an internal employee. To that end, when files are actively downloading, a new icon now appears in the Search bar that users can tap to view and manage downloads, pause and resume all downloads or just individual items, and select one to increase its priority or view it in a chat.
from ye


Telegram Аналитик на Балтике | Всё о карьере в IT
FROM American