# 2. Подписка GraphQL

Диаграмма последовательности для GraphQL-подписок иллюстрирует, как воспользоваться событийно-ориентированной архитектурой, реализованной в ядре GeoPard. При любых изменениях связанных сущностей

API GeoPard незамедлительно генерирует событие, фиксирующее затронутые сущности и соответствующую операцию (`ВСТАВКА`, `ИЗМЕНЕНИЕ`, `УДАЛЕНИЕ`). Область охвата этих подписок обширна и включает все сущности, такие как Ферма, Участок, СпутниковоеИзображение, НаборДанныхПочвы, НаборДанныхНанесения, НаборДанныхУрожая, КартаТопографии, Заметки и т.д.&#x20;

GraphQL-подписка ([Запрос 1 или R1](/geopard-tutorials/ru/dokumentaciya-api/obzor-zaprosov-api-geopard/1.-podpiska-poluchit-sobytiya.md)) работает по WebSocket, где все события доставляются почти в реальном времени, обеспечивая немедленную передачу любых изменений.&#x20;

{% hint style="danger" %}
Приемник событий подписки должен функционировать как базовый сервис, отвечающий за маршрутизацию полученных событий в последующий сервис, где применяется логика обработки. Крайне важно, чтобы этот приемник сам не выполнял никаких задач по обработке.
{% endhint %}

Кроме того, в случае пропущенных или утерянных событий пользователи имеют возможность их получить. Это достигается выполнением GraphQL-запроса, настроенного на определенный диапазон дат и сущности (Пользователь, Ферма, Участок), что фактически позволяет полностью восстановить прошлые события ([Запрос 2 или R2](/geopard-tutorials/ru/dokumentaciya-api/obzor-zaprosov-api-geopard/82.-izmenenie-vosstanovit-sobytiya-podpiski.md)). Такой уровень функциональности гарантирует, что никакая информация не потеряется, сохраняя целостность и согласованность данных пользователя.

<figure><img src="/files/d29faf5cda70ddc861e4e614943bed987086d261" alt=""><figcaption><p>Диаграмма последовательности: Работа с событиями подписки</p></figcaption></figure>


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.geopard.tech/geopard-tutorials/ru/dokumentaciya-api/diagrammy-s-bazovymi-scenariyami/2.-podpiska-graphql.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
