NAME
JIRA::Client - An extended interface to JIRA's SOAP API.
VERSION
Version 0.10
SYNOPSIS
use JIRA::Client;
my $jira = JIRA::Client->new('http://jira.example.com/jira', 'user', 'passwd');
my $issue = $jira->create_issue(
{
project => 'TST',
type => 'Bug',
summary => 'Summary of the bug',
assignee => 'gustavo',
components => ['compa', 'compb'],
fixVersions => ['1.0.1'],
}
);
$issue = $jira->getIssue('TST-123');
$jira->set_filter_iterator('my-filter');
while (my $issue = $jira->next_issue()) {
# ...
}
DESCRIPTION
JIRA is a proprietary bug tracking system from Atlassian (http://www.atlassian.com/software/jira/).
This module implements an Object Oriented wrapper around JIRA's SOAP API, which is specified in http://docs.atlassian.com/software/jira/docs/api/rpc-jira-plugin/latest/com/atlassian/jira/rpc/soap/JiraSoapService.html. (This version was tested against JIRA 3.13.4.)
Moreover, it implements some other methods to make it easier to do some common operations.
API METHODS
With the exception of the API login
and logout
methods, which aren't needed, all other methods are available through the JIRA::Client object interface. You must call them with the same name as documented in the specification but you should not pass the token
argument, because it is supplied transparently by the JIRA::Client object.
Some of the API methods require hard-to-build data structures as arguments. This module tries to make them easier to call by accepting simpler structures and implicitly constructing the more elaborated ones before making the actual SOAP call. Note that this is an option, i.e, you can either pass the elaborate structures by yourself or the simpler ones in the call.
- addComment
-
The second argument can be a string instead of a
RemoteComment
object. - progressWorkflowAction
-
The third argument can be a hash mapping field ids to field values instead of an array of RemoteFieldValue objects.
- updateIssue
-
The second argument can be a hash mapping field ids to field values instead of an array of RemoteFieldValue objects.
EXTRA METHODS
This module implements some extra methods to add useful functionality to the API. They are described below. Note that their names don't follow the CamelCase convention used by the native API methods but the more Perlish underscore_separated_words convention so that you can distinguish them and we can avoid future name clashes.
- new JIRAURL, USER, PASSWD
-
The JIRA::Client constructor needs three arguments. JIRAURL is JIRA's base URL from which will be constructed it's WSDL descriptor as
$JIRAURL/rpc/soap/jirasoapservice-v2?wsdl
. USER and PASSWD are the credentials that will be used to authenticate into JIRA. - create_issue HASH_REF
-
Creates a new issue given a hash containing the initial values for its fields. The hash must specify at least the fields
project
,summary
, andtype
.This is an easier to use version of the createIssue API method. It's easier because it accepts symbolic values for some of the issue fields that the API method does not. Specifically:
type
can be specified by name instead of by id.priority
can be specified by name instead of by id.component
can be specified by a list of component names or ids instead of a list ofRemoteComponent
objects.affectsVersions
andfixVersions
can be specified by a list of version names or ids instead of a list ofRemoteVersion
objects.
- get_issue_types
-
Returns a hash mapping the server's issue type names to the RemoteIssueType objects describing them.
- get_priorities
-
Returns a hash mapping a server's priorities names to the RemotePriority objects describing them.
- get_custom_fields
-
Returns a hash mapping JIRA's custom field names to the RemoteField representing them. It's useful since when you get a RemoteIssue object from this API it doesn't contain the custom field's names, but just their identifiers. From the RemoteField object you can obtain the field's id, which is useful when calling the updateIssue method.
The method calls the getCustomFields API method the first time and keeps the custom fields information in a cache.
- set_custom_fields HASHREF
-
Passes a hash mapping JIRA's custom field names to the RemoteField representing them to populate the custom field's cache. This can be useful if you don't have administrative priviledges to the JIRA instance, since only administrators can call the getCustomFields API method.
- get_components PROJECT_KEY
-
Returns a hash mapping a project's components names to the RemoteComponent objects describing them.
- get_versions PROJECT_KEY
-
Returns a hash mapping a project's versions names to the RemoteVersion objects describing them.
- set_filter_iterator FILTER_NAME
-
Sets up an interator for the filter identified by FILTER_NAME. It must be called before calls to next_issue.
- next_issue
-
This must be called after a call to set_filter_iterator. Each call returns a reference to the next issue from the filter. When there are no more issues it returns undef.
- progress_workflow_action_safelly ISSUE, ACTION, PARAMS
-
This is a safe and easier to use version of the progressWorkflowAction API method which is used to progress an issue through a workflow's action while making edits to the fields that are shown in the action screen. The API method is dangerous because if you forget to provide new values to all the fields shown in the screen, then the fields not provided will become undefined in the issue. The problem has a pending issue on Atlassian's JIRA http://jira.atlassian.com/browse/JRA-8717.
This method plays it safe by making sure that all fields shown in the screen that already have a value are given new (or the same) values so that they don't get undefined. It calls the getFieldsForAction API method to grok all fields that are shown in the screen. If there is any field not set in the ACTION_PARAMS then it calls getIssue to grok the missing fields current values. As a result it constructs the necessary RemoteFieldAction array that must be passed to progressWorkflowAction.
The method is also easier to use because its arguments are more flexible:
ISSUE
can be either an issue key or a RemoteIssue object returned by a previous call to, e.g.,getIssue
.ACTION
can be either an action id or an action name.PARAMS
can be either an array of RemoteFieldValue objects or a hash mapping field names to field values.
For example, instead of using this:
my $action_id = somehow_grok_the_id_of('close'); $jira->progressWorkflowAction('PRJ-5', $action_id, [ RemoteFieldValue->new(2, 'new value'), ..., # all fields must be specified here ]);
And risking to forget to pass some field you can do this:
$jira->progress_workflow_action_safelly('PRJ-5', 'close', {2 => 'new value'});
OTHER CONSTRUCTORS
The JIRA SOAP API uses several types of objects (i.e., classes) for which the Perl SOAP interface does not provide the necessary constructors. This module implements some of them.
- RemoteFieldValue->new ID, VALUES
-
The RemoteFieldValue object represent the value of a field of an issue. It needs two arguments:
- ID
-
The field name, which must be a valid key for the ISSUE hash.
- VALUES
-
A scalar or an array of scalars.
- RemoteComponent->new ID, NAME
- RemoteVersion->new ID, NAME
AUTHOR
Gustavo Chaves, <gnustavo@cpan.org>
BUGS
Please report any bugs or feature requests to bug-jira-client at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=JIRA-Client. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc JIRA::Client
You can also look for information at:
RT: CPAN's request tracker
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
Search CPAN
COPYRIGHT & LICENSE
Copyright 2009 CPqD, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.