UNPKG

cli-stash

Version:

CLI application to manage and work with Atlassian Stash. Work with your Stash project and repositories from Command lines.

101 lines (100 loc) 4.68 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const core_1 = require("@oclif/core"); const stash_connector_1 = require("stash-connector"); const baseCommand_1 = require("../../../../../libs/core/baseCommand"); const stashResponse_1 = require("../../../../../libs/core/stashResponse"); const tables_1 = require("../../../../../libs/core/tables"); const ux_1 = require("../../../../../libs/core/ux"); class List extends baseCommand_1.BaseCommand { async run() { const response = new stashResponse_1.StashCLIResponse(); const connector = new stash_connector_1.StashConnector(this.localConfig.getConnectorOptions(this.flags.alias)); try { let result = new stash_connector_1.Page(); if (this.flags.all) { let tmp = await connector.projects.repos(this.flags.project).pullRequests(this.flags.slug).activities(this.flags.pull).list({ fromType: this.flags.type, fromId: this.flags.from, pageOptions: this.allPageOptions, }); result.values.push(...tmp.values); result.isLastPage = true; result.start = tmp.start; while (!tmp.isLastPage) { tmp = await connector.projects.repos(this.flags.project).pullRequests(this.flags.slug).activities(this.flags.pull).list({ fromType: this.flags.type, fromId: this.flags.from, pageOptions: { start: tmp.nextPageStart, limit: 100, } }); result.values.push(...tmp.values); } result.size = result.values.length; } else { result = await connector.projects.repos(this.flags.project).pullRequests(this.flags.slug).activities(this.flags.pull).list({ fromType: this.flags.type, fromId: this.flags.from, pageOptions: this.pageOptions, }); } response.result = result; response.status = 0; response.message = this.getRecordsFoundText(result.values.length, 'Pull Request'); this.ux.log(response.message); this.ux.table(result.values, tables_1.PullRequestActivityColumns, { csv: this.flags.csv, extended: this.flags.extended || this.flags.csv }); } catch (error) { this.processError(response, error); } return response; } } exports.default = List; List.description = 'Retrieve a page of activity associated with a pull request. ' + ux_1.UX.processDocumentation('<doc:PullRequestActivity>'); List.examples = [ `$ stash projects:repos:pulls:activities:list -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --pull 1234 --all --csv`, `$ stash projects:repos:pulls:activities:list -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --pull 1234 --type COMMENT -l 100 -s 50 --json`, `$ stash projects:repos:pulls:activities:list -a MyStashAlias --project "ProjectKey" --slug "MyRepoSlug" --pull 1234 --from 5678 --type ACTIVITY --limit 30`, ]; List.flags = { ...baseCommand_1.BaseCommand.flags, csv: baseCommand_1.BuildFlags.csv, extended: baseCommand_1.BuildFlags.extended, alias: baseCommand_1.BuildFlags.alias, ...baseCommand_1.BuildFlags.pagination, project: core_1.Flags.string({ description: 'The Project Key (or user slug like ~userSlug) to retrieve repository pull requests activities', required: true, name: 'Project' }), slug: core_1.Flags.string({ description: 'The Repository slug to retrieve the pull requests activities', required: true, name: 'Slug' }), pull: core_1.Flags.integer({ description: 'The Pull Request Id to retrieve activities', required: true, name: 'Pull Request Id', }), from: core_1.Flags.integer({ description: 'The id of the activity item to use as the first item in the returned page', required: true, name: 'From Pull Request Id', dependsOn: ['type'] }), type: core_1.Flags.string({ description: 'The type of the activity item specified by fromId', required: true, options: ['COMMENT', 'ACTIVITY'], type: "option", name: 'From Type', }), };