Описание
Сервис для работы с торговыми поручениями.
Выставить заявку
Одна из главных функций торгового робота — выставление заявок на бирже.
Для этого можно использовать unary-метод postOrder. Через него можно выставлять все типы заявок — и рыночные, и лимитные.
В запросе метода передается параметр instrument_id
— идентификатор инструмента, который принимает значения figi
или instrument_uid
. Подробнее об идентификаторах.
Подробнее о торговых поручениях, их видах и особенностях исполнения на биржах
Чтобы исключить дублирование заявок, используется параметр order_id
— его нужно сгенерировать любым удобным
способом перед вызовом метода. Если сервис получит несколько запросов с одинаковым order_id
, на биржу
выставится только одно торговое поручение. Все последующие запросы с одним order_id
будут возвращать
ошибку выставления — 30057
.
Сейчас у нас есть два параметра с одинаковым названием:
order_id
как входной параметр — ключ идемпотентности. Уникальность значений отслеживается только за последний месяц.order_id
как выходной параметр — биржевой идентификатор заявки, который в дальнейшем используется для отслеживания статуса заявки.
При выполнении операций с облигациями также учитывайте накопленный купонный доход.
Размер НКД можно узнать через методы получения информации по облигациям или метод выставления торгового поручения — для этого используется параметр aci_value
.
Обратите внимание: в параметре aci_value
возвращается размер НКД в валюте расчетов за 1 лот. То есть при покупке облигаций к стоимости сделки будет добавлено произведение НКД на количество лотов в сделке (aci_value
∗quantity
), при продаже — сумма сделки будет уменьшена на это произведение.
Выставлять заявку с отрицательным значением цены можно только для фьючерсов — в остальных случаях метод вернет ошибку.
Сейчас выставить заявку стоимостью больше 30 млн рублей через T-Invest API нельзя — ее нужно подтверждать по СМС. Поэтому мы рекомендуем разбивать такие заявки на заявки меньшего размера.
Получить список активных заявок по счету
Чтобы торговый робот более эффективно управлял торговыми поручениями, ему нужно иметь возможность получать список активных заявок на данный момент.
Для этого можно использовать метод getOrders. Обратите внимание: метод возвращает только активные торговые поручения — после исполнения заявка пропадает из возвращаемого списка.
Получить статус торгового поручения
Статус исполнения поданного торгового поручения можно
используя метод getOrderState. Помимо статуса он возвращает стадии выполнения заявки — массив stages
.
Метод не предусмотрен для получения глубокой истории и может не возвращать информацию по поручениям, которым больше одного дня.
Идентификатор ключа идемпотентности
Пример. Вы оформляете заявку на покупку ценной бумаги. Запрос может потеряться в пути, и вы пробуете отправить его еще раз. Проблема в том, что мог потеряться не запрос, а ответ — и тогда будут созданы две заявки.
Поэтому для таких операций есть требование идемпотентности — это значит, что при повторном вызове операции результат будет тот же, что и при первом. В нашем примере — вне зависимости от того, сколько раз был отправлен запрос, должна быть создана только одна заявка или ни одной, если возникнет ошибка.
Стандартный способ достичь идемпотентности — генерация ключа идемпотентности на стороне клиента. Это некое уникальное значение: на стороне обработки запроса выполняется только та операция, ключ которой еще не встречался. Таким образом можно делать повторные вызовы безопасно.
Для сохранения единообразия параметр order_id
означает:
- В запросах метода postOrder — ключ идемпотентности, передаваемый от клиента.
- В ответах метода postOrder — биржевой идентификатор заявки.
В ответах других методов ключ идемпотентности, который передается клиентом, — это параметр order_request_id
.
В запросе метода getOrderState в параметре order_id
нужно передавать order_id
из ответа метода postOrder — то есть биржевой идентификатор заявки.
Повторное использование одного и того же order_id
в запросах метода postOrder приведет к ошибке, если уже существует успешно размещенная заявка с таким order_id
.
Отменить торговое поручение
Не все торговые поручения, которые выставляются на торговую площадку, могут и должны быть исполнены.
Ситуация на рынке меняется динамично, поэтому торговому роботу нужна возможность отменять выставленные заявки — для этого используйте метод cancelOrder.
Стрим исполнения поручений пользователя
T-Invest API предоставляет стрим с трансляцией исполнения сделок. В этот стрим попадают все совершенные сделки по всем счетам пользователя.
Чтобы сохранять стабильное подключение при отсутствии данных в stream-соединении, сервер периодически отправляет ping-пакет. Клиенту не нужно на него реагировать.
Изменить выставленную заявку
Чтобы изменять уже выставленные поручения, используйте метод replaceOrder. Через него можно отменить существующую выставленную заявку и выставить новую с измененными параметрами.
Чтобы использовать метод, понадобится идентификатор заявки на бирже, который вы получили при выставлении заявки через метод postOrder.
Во время использования метода на этапах исполнения могут произойти разные события, и вернется ошибка. Например:
- Если поручение нельзя отменить, вернется ошибка с кодом
30059
и описанием причины вmessage
. - Если после отмены поручения нельзя выставить новое, вернется ошибка метода postOrder с соответствующим кодом и описанием.
Стрим совершенных сделок пользователя
В T-Invest API есть gRPC server-side TradesStream получения сделок с биржи. Стрим предназначен для получения событий по поручениям пользователя по факту их исполнения.
TradesStream используется для быстрого получения информации об исполнении поручения и выполненных сделках в рамках поручения с отображением номера счета, на котором выполнилось поручение.
Для работы со стрим-соединениями есть ограничения.
Получить торговые статусы инструментов и расписание торгов
Торговые статусы инструментов и расписание торгов
Также рекомендуем смотреть актуальную информацию по режимам и статусам торгов на сайтах Московской биржи и СПБ биржи.
Выставить заявки по опционам
Сейчас для работы с опционами в T-Invest API доступны только лимитные заявки. Рыночная заявка, тейк-профиты и стоп-заявки в разработке.