
Внимание!
Репозиторий переехал в монорепозиторий фронтенда и заморожен.
StarTrek API Client 
Клент для API стартрека. Легкий, простой, прозрачный. Постороен на основе Promise.
Описание API.
Install
npm install st-client --registry=http://npm.yandex-team.ru
Usage
var client = require('st-client').init({ token: '<token>' });
client.getIssue('WEATHER-3300')
.then(function (issue) {
console.log('%s – %s', issue.key, issue.summary)
});
client.issues({ query: 'Queue: WEATHER Key: WEATHER-3300, WEATHER-3301, WEATHER-3302' })
.then(function (issues) {
issues.forEach(function (issue) {
console.log('[%s] %s – %s', issue.status.key, issue.key, issue.summary);
})
});
API
init(options)
Создает клиента.
options
Объект с опциями
options.token
Type: String
OAuth токен. Подробнее в вики.
options.sessionId
Type: String
Значение куки Session_id. Подробнее в вики.
options.tvm
Type: Object
Значение сервисного и клиетского tvm2-тикетов. Объект вида { serviceTicket, clientTicket }. Подробнее в вики.
options.lang
Type: String
Default: ru-RU, ru
Язык. Подробнее в вики.
options.endpoint
Type: String
Default: http://st-api.yandex-team.ru/v2
Адрес API.
options.clientOptions
Type: object
Опции для http-клиента got. Позволяют переопределить, например, таймаут или настройки резолвинга.
Список методов
Методы повторяют структуру API, поэтому описание смотрите на вики
-
Работа с тикетами
-
client.issues(params)
-
client.getIssue(id, params)
-
client.createIssue(data)
-
client.updateIssue(id, data)
-
Аттрибуты тикета
-
Типы тикетов
- client.issueTypes()
- client.getIssueType(id)
- client.createIssueType(data)
- client.updateIssueType(id, data)
-
Приоритеты
- client.priorities()
- client.getPriority(id)
- client.createPriority(data)
- client.updatePriority(id, data)
-
Статусы
- client.statuses()
- client.getStatus(id)
- client.createStatus(data)
- client.updateStatus(id, data)
-
Резолюции
- client.resolutions()
- client.getResolution(id)
- client.createResolution(data)
- client.updateResolution(id, data)
-
Пользователи
- client.users()
- client.getUser(login)
-
Работа с очередями
-
client.queues(params)
-
client.getQueue(id, params)
-
client.createQueue(data)
-
client.updateQueue(id, data)
-
client.deleteQueue(id)
-
Атрибуты очереди
- client.queueComponents(queueId)
- client.queueVersions(queueId)
- client.queueProjects(queueId)
-
Работа с досками
-
Спринты
- client.boardSprints(boardId)
Contribution
Пожалуйста, прочитайте contribution guide перед созданием issue или отправкой пулл-реквеста.
Tests
$ npm run lint
$ npm test