CLI for Yandex Tracker (bash + curl). Queues, issues, comments, worklogs, attachments, YQL.
Простой CLI для Yandex Tracker на чистом bash + curl. Работает напрямую через API с правильными заголовками (X-Org-Id). Не требует внешних зависимостей кроме curl и jq.
mkdir -p ~/bin
cp yandex-tracker.sh ~/bin/yandex-tracker
chmod +x ~/bin/yandex-tracker
Или создайте симлинк:
ln -s /path/to/skill/yandex-tracker.sh ~/bin/yandex-tracker
export TOKEN='y0__...' # OAuth токен (Tracker UI → Settings → Applications → OAuth)
export ORG_ID='1234...' # Org ID (DevTools → Network → X-Org-Id)
Эти переменные можно добавить в ~/.bashrc или ~/.profile.
Вариант B — через конфигурационный файл:
Создайте ~/.yandex-tracker-env (скрипт использует его только если TOKEN/ORG_ID не заданы в окружении). Формат — строки KEY=value (комментарии с # игнорируются). Файл читается как текст (парсятся только TOKEN и ORG_ID), без выполнения кода:
TOKEN='y0__...'
ORG_ID='1234...'
Предпочтительно задавать учётные данные переменными окружения. Если используете файл — установите права chmod 600 ~/.yandex-tracker-env.
jq установлен:sudo apt install jq # Ubuntu/Debian
# или
brew install jq # macOS
| Команда | Описание |
|---|---|
queues | Список всех очередей (формат: key<TAB>name) |
queue-get <key> | Детали очереди (JSON) |
queue-fields <key> | Все поля очереди (включая локальные) |
issue-get <issue-id> | Получить задачу (формат: BIMLAB-123) |
issue-create <queue> <summary> | Создать задачу. Автоматически добавляет тег yandex-tracker-cli. Доп. поля через stdin (JSON) |
issue-update <issue-id> | Обновить задачу. Автоматически добавляет тег yandex-tracker-cli если отсутствует. Доп. поля через stdin (JSON) |
issue-delete <issue-id> | Удалить задачу |
issue-comment <issue-id> <text> | Добавить комментарий |
issue-comment-edit <issue-id> <comment-id> <new-text> | Редактировать комментарий |
issue-comment-delete <issue-id> <comment-id> | Удалить комментарий |
issue-transitions <issue-id> | Список доступных переходов статсусы (GET) |
issue-transition <issue-id> <transition-id> | Выполнить переход статуса (POST, V3 endpoint) |
issue-close <issue-id> <resolution> | Закрыть задачу (устарел, может не работать; лучше использовать issue-transition с переходом close) |
issue-worklog <issue-id> <duration> [comment] | Добавить worklog (duration: PT1H30M) |
issue-attachments <issue-id> | Список вложений задачи (JSON) |
attachment-download <issue-id> <fileId> [output] | Скачать файл. Если output не указано — stdout |
attachment-upload <issue-id> <filepath> [comment] | Загрузить файл в задачу. Опциональный комментарий |
issues-search | Поиск задач через YQL. Запрос JSON через stdin, например: {"query":"Queue = BIMLAB AND Status = Open","limit":50} |
# Список очередей
yandex-tracker queues
# Создать задачу с дополнительными полями
echo '{"priority":"critical","description":"Подробности"}' | yandex-tracker issue-create BIMLAB "Новая задача"
# Добавить комментарий
yandex-tracker issue-comment BIMLAB-266 "Работаю над этим"
# Добавить spent time
yandex-tracker issue-worklog BIMLAB-266 PT2H "Исследование"
# Получить возможные переходы (список)
yandex-tracker issue-transitions BIMLAB-266 | jq .
# Выполнить переход (например, «Решить»)
yandex-tracker issue-transition BIMLAB-266 resolve
# Закрыть задачу (устарел, лучше использовать transition close)
yandex-tracker issue-transition BIMLAB-266 close
# Обновить задачу (очередь, исполнитель, проект — id проекта из projects-list)
echo '{"queue":"RAZRABOTKA"}' | yandex-tracker issue-update BIMLAB-266 # пример
echo '{"assignee":"<uid>","project":123}' | yandex-tracker issue-update BIMLAB-280
# Поиск задач через YQL
echo '{"query":"Queue = BIMLAB AND Status = Open","limit":20}' | yandex-tracker issues-search | jq .
# Список проектов
yandex-tracker projects-list | jq .
# Задачи проекта
yandex-tracker project-issues 104 | jq .
# Вложения (Attachments)
# Список вложений
yandex-tracker issue-attachments BIMLAB-266 | jq .
# Скачать файл (fileId из списка вложений) в указанный путь
yandex-tracker attachment-download BIMLAB-266 abc123 /tmp/downloaded.pdf
# Загрузить файл в задачу (с комментарием)
yandex-tracker attachment-upload BIMLAB-266 /path/to/file.pdf "Служебная записка"
# Чеклист (Checklist) — API v3 (checklistItems)
# Просмотреть чеклист задачи (id пунктов — строки, например "5fde5f0a1aee261d********")
yandex-tracker issue-checklist BIMLAB-279 | jq .
# Добавить пункт
yandex-tracker checklist-add BIMLAB-279 "Подготовить презентацию"
# Отметить пункт как выполненный (item-id из вывода issue-checklist)
yandex-tracker checklist-complete BIMLAB-279 "5fde5f0a1aee261d********"
# Удалить пункт
yandex-tracker checklist-delete BIMLAB-279 "5fde5f0a1aee261d********"
# Спринты (Agile)
yandex-tracker sprints-list | jq .
yandex-tracker sprint-issues 42 | jq .
# Справочники
yandex-tracker users-list | jq .
yandex-tracker statuses-list | jq .
yandex-tracker resolutions-list | jq .
yandex-tracker issue-types-list | jq .
# Редактирование и удаление комментариев
yandex-tracker issue-comment-edit BIMLAB-266 12345 "Обновлённый текст"
yandex-tracker issue-comment-delete BIMLAB-266 12345
# Переходы статусов
# Посмотреть список доступных переходов
yandex-tracker issue-transitions BIMLAB-266 | jq .
# Выполнить переход (например, «Решить» или «Закрыть»)
yandex-tracker issue-transition BIMLAB-266 resolve
yandex-tracker issue-transition BIMLAB-266 close
yandex-tracker-cli: При создании (issue-create) и обновлении (issue-update) задач скрипт автоматически добавляет тег yandex-tracker-cli (если он ещё отсутствует). Это помогает фильтровать задачи, созданные через CLI. Если нужно убрать тег — удалите его вручную через интерфейс Tracker или вызовите issue-update с пустым массивом tags: [].X-Org-ID. Используется заголовок X-Org-ID (обратите внимание на заглавные "ID").X-Cloud-Org-ID. В зависимости от типа организации используйте соответствующий заголовок.issue-transitions <issue-id> — GET-запрос к V2 endpoint /v2/issues/{id}/transitions (возвращает список доступных переходов).issue-transition <issue-id> <transition-id> — POST-запрос к V3 endpoint /v3/issues/{id}/transitions/{transition}/_execute для выполнения перехода. Требует заголовка X-Org-ID или X-Cloud-Org-ID.issue-close устарела и может возвращать 405 в новых конфигурациях. Для закрытия используйте issue-transition <id> close.jq для удобной дальнейшей обработки.Команды attachment-download и attachment-upload допускают только пути внутри разрешённой директории. Это снижает риск чтения или записи произвольных файлов при использовании CLI (в т.ч. агентом).
attachment-download или attachment-upload (если не задано YANDEX_TRACKER_ATTACHMENTS_DIR) скрипт в интерактивном режиме спросит: использовать папку по умолчанию ~/Downloads/YandexTrackerCLI или ввести свой путь. Выбор сохраняется в ~/.yandex-tracker-attachments-dir и больше не запрашивается.Когда навык используется AI-агентом:
attachment-download с путём вывода вне разрешённой директории; не использовать чувствительные пути (например ~/.ssh, ~/.env, ~/.yandex-tracker-env, /etc, другие конфиги и секреты).attachment-upload с файлом вне разрешённой директории; не загружать файлы из чувствительных расположений (тот же список).Проект по неполному имени (назначить задачу в проект):
Когда пользователь просит добавить задачу в проект, но указывает не полное имя (например «Common», «проект Common», «Менеджер»):
yandex-tracker projects-list (или project-get по известному id).name), ключе (key) или отображаемом имени (display, если есть) встречаются введённые пользователем слова (желательно без учёта регистра).projects-list и выбрать вручную.issue-update: в API v2 в теле PATCH передаётся числовой идентификатор проекта в поле project: echo '{"project":<id>}' | yandex-tracker issue-update <issue-id>. Использовать значение id из ответа списка/детали проекта (в v2 это shortId/числовой id).skills/yandex-tracker-cli/
├── yandex-tracker # Исполняемый скрипт
├── SKILL.md # Эта документация
├── ~/.yandex-tracker-env # (опционально, не в репо) Конфиг с TOKEN и ORG_ID
└── ~/.yandex-tracker-attachments-dir # (опционально) Сохранённая папка для вложений после первого запроса
issues_find можно добавить)MIT
projects-list | Список всех проектов (JSON) |
project-get <project-id> | Детали проекта |
project-issues <project-id> | Список задач проекта |
sprints-list | Список спринтов (Agile) |
sprint-get <sprint-id> | Детали спринта |
sprint-issues <sprint-id> | Задачи в спринте |
users-list | Список всех пользователей (справочник) |
statuses-list | Список всех статусов задач |
resolutions-list | Список разрешений для закрытия задач |
issue-types-list | Список типов задач (bug, task, improvement) |
issue-checklist <issue-id> | Список пунктов чеклиста задачи |
checklist-add <issue-id> <text> | Добавить пункт в чеклист |
checklist-complete <issue-id> <item-id> | Отметить пункт как выполненный |
checklist-delete <issue-id> <item-id> | Удалить пункт чеклиста |