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
JavaScript
"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',
}),
};