File: comment_issue.pl

package info (click to toggle)
libjira-rest-perl 0.024-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 192 kB
  • sloc: perl: 588; makefile: 8
file content (107 lines) | stat: -rwxr-xr-x 2,313 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#!/usr/bin/env perl

use 5.016;
use utf8;
use warnings;
use FindBin;
use lib "$FindBin::Bin/lib";
use Getopt::Long::Descriptive;
use JIRACLI qw/get_credentials/;

my ($opt, $usage) = describe_options(
    '%c %o',
    ['jiraurl=s',   "JIRA server base URL", {required => 1}],
    ['issue|i=s',    "Key of the issue to progress", {required => 1}],
    ['comment|c=s', "Comment body", {required => 1}],
    ['visibility' => 'hidden' => {'one_of' => [
        ['group|g=s', "Group to restrict visibility to"],
        ['role|r=s',  "Role to restrict visibility to"],
    ]}],
    ['help|h',      "Print usage message and exit"],
    {show_defaults => 1},
);

if ($opt->help) {
    print $usage->text;
    exit 0;
}

my $jira = JIRA::REST->new(
    $opt->jiraurl,
    get_credentials(),
);

my $comment = {body => $opt->comment};

if (my $type = $opt->visibility) {
    $comment->{visibility} = {
        type  => $type,
        value => $opt->$type,
    }
}

$jira->POST("/issue/@{[$opt->issue]}/comment", undef, $comment);


__END__
=encoding utf8

=head1 NAME

comment_issue.pl - Comment a JIRA issue

=head1 SYNOPSIS

  comment_issue.pl [-ghir] [long options...]
    --jiraurl STR        JIRA server base URL
    -i STR --issue STR   Key of the issue to progress
    -c STR --comment STR Comment body
    -g STR --group STR   Group to restrict visibility to
    -r STR --role STR    Role to restrict visibility to
    -h --help            Print usage message and exit

=head1 DESCRIPTION

This script adds a comment to a JIRA issue.

=head1 OPTIONS

Common options are specified in the L<JIRACLI> documentation. Specific
options are defined below:

=over

=item * B<--issue STR>

Specifies the issue by its key (e.g. HD-1234).

=item * B<--comment STR>

The comment body.

=item * B<--group STR>

Use this option to restrict the comment visibility to the specified group.

=item * B<--role STR>

Use this option to restrict the comment visibility to the specified role.

Note that the B<--group> and B<--role> options are mutually exclusive.

=back

=head1 ENVIRONMENT

See the L<JIRACLI> documentation.

=head1 COPYRIGHT

Copyright 2019-2022 CPQD.

This program is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.

=head1 AUTHOR

Gustavo Chaves <gustavo@cpqd.com.br>