NAME
JIRA::REST::Class::Issue - A helper class for JIRA::REST::Class that represents an
VERSION
version 0.07
DESCRIPTION
This object represents a JIRA issue as an object. It is overloaded so it returns the key
of the issue when stringified, and the id
of the issue when it is used in a numeric context. If two of these objects are compared as strings, the key
of the issues will be used for the comparison, while numeric comparison will compare the id
s of the issues.
METHODS
add_attachments
Accepts a list of filenames to be added to the issue as attachments.
add_attachment
Accepts a single filename to be added to the issue as an attachment.
add_data_attachment
Accepts a fake filename and a scalar representing the contents of a file and adds it to the issue as an attachment.
add_comment
Adds whatever is passed in as a comment on the issue.
add_label
Adds whatever is passed in as a label for the issue.
remove_label
Removes whatever is passed in from the labels for the issue.
has_label
Returns true if the issue has the specified label.
add_component
Adds whatever is passed in as a component for the issue.
remove_component
Removes whatever is passed in from the components for the issue.
set_assignee
Sets the assignee for the issue to be the user passed in. Can either be a string representing the name or a JIRA::REST::Class::User object.
set_reporter
Sets the reporter for the issue to be the user passed in. Can either be a string representing the name or a JIRA::REST::Class::User object.
add_issue_link
Adds a link from this issue to another one. Accepts the link type (either a string representing the name or a JIRA::REST::Class::Issue::LinkType), the issue to be linked to, and (optionally) the direction of the link (inward/outward). If the direction cannot be determined from the name of the link type, the default direction is 'inward';
add_subtask
Adds a subtask to the current issue. Accepts a hashref with named parameters summary
and description
. If the parameter issuetype
is specified, then a subtask of the specified type is created. If no issuetype is specified, then the project is queried for valid subtask types, and, if there is only one, that type is used. If the project has more than one valid subtask type, an issuetype MUST be specified.
The remaining named parameters are passed to the create issue call as fields.
update
Puts an update to JIRA. Accepts a hash of fields => values to be put.
put_field
Puts a value to a field. Accepts the field name and the value as parameters.
reload
Reload the issue from the JIRA server.
sprints
Generates a list of JIRA::REST::Class::Sprint objects from the fields for an issue. Uses the field_name() accessor on the JIRA::REST::Class::Project object to determine the name of the custom sprint field. Currently, this only really works if you're using Atlassian GreenHopper.
children
Returns a list of issue objects that are children of the issue. Currently requires the ScriptRunner plugin.
start_progress
Moves the status of the issue to 'In Progress', regardless of what the current status is.
start_qa
Moves the status of the issue to 'In QA', regardless of what the current status is.
resolve
Moves the status of the issue to 'Resolved', regardless of what the current status is.
open
Moves the status of the issue to 'Open', regardless of what the current status is.
close
Moves the status of the issue to 'Closed', regardless of what the current status is.
READ-ONLY ACCESSORS
expand
A comma-separated list of fields in the issue that weren't expanded in the initial REST call.
fields
Returns a reference to the fields hash for the issue.
aggregateprogress
Returns the aggregate progress for the issue as a hash reference.
TODO: Turn this into an object.
aggregatetimeestimate
Returns the aggregate time estimate for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
aggregatetimeoriginalestimate
Returns the aggregate time original estimate for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
aggregatetimespent
Returns the aggregate time spent for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
assignee
Returns the issue's assignee as a JIRA::REST::Class::User object.
changelog
Returns the issue's change log as a JIRA::REST::Class::Issue::Changelog object.
comments
Returns a list of the issue's comments as JIRA::REST::Class::Issue::Comment objects. If called in a scalar context, returns an array reference to the list, not the number of elements in the list.
components
Returns a list of the issue's components as JIRA::REST::Class::Project::Component objects. If called in a scalar context, returns an array reference to the list, not the number of elements in the list.
component_count
Returns a count of the issue's components.
created
Returns the issue's creation date as a DateTime object.
creator
Returns the issue's assignee as a JIRA::REST::Class::User object.
description
Returns the description of the issue.
duedate
Returns the issue's due date as a DateTime object.
environment
Returns the issue's environment as a hash reference.
TODO: Turn this into an object.
fixVersions
Returns a list of the issue's fixVersions.
TODO: Turn this into a list of objects.
issuelinks
Returns a list of the issue's links.
TODO: Turn this into a list of objects.
issuetype
Returns the issue type as a JIRA::REST::Class::Issue::Type object.
labels
Returns the issue's labels as an array reference.
lastViewed
Returns the issue's last view date as a DateTime object.
parent
Returns the issue's parent as a JIRA::REST::Class::Issue object.
has_parent
Returns a boolean indicating whether the issue has a parent.
priority
Returns the issue's priority as a hash reference.
TODO: Turn this into an object.
progress
Returns the issue's progress as a hash reference.
TODO: Turn this into an object.
project
Returns the issue's project as a JIRA::REST::Class::Project object.
reporter
Returns the issue's reporter as a JIRA::REST::Class::User object.
resolution
Returns the issue's resolution.
TODO: Turn this into an object.
resolutiondate
Returns the issue's resolution date as a DateTime object.
status
Returns the issue's status as a JIRA::REST::Class::Issue::Status object.
summary
Returns the summary of the issue.
timeestimate
Returns the time estimate for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
timeoriginalestimate
Returns the time original estimate for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
timespent
Returns the time spent for the issue.
TODO: Turn this into an object that can return either seconds or a w/d/h/m/s string.
timetracking
Returns the time tracking of the issue as a JIRA::REST::Class::Issue::TimeTracking object.
transitions
Returns the valid transitions for the issue as a JIRA::REST::Class::Issue::Transitions object.
updated
Returns the issue's updated date as a DateTime object.
versions
versions
votes
votes
watches
watches
worklog
Returns the issue's change log as a JIRA::REST::Class::Worklog object.
workratio
workratio
id
Returns the issue ID.
key
Returns the issue key.
self
Returns the JIRA REST API's full URL for this issue.
url
Returns the JIRA REST API's URL for this issue in a form used by JIRA::REST::Class.
INTERNAL METHODS
make_object
A pass-through method that calls JIRA::REST::Class::Factory::make_object(), but adds a weakened link to this issue in the object as well.
get
Wrapper around JIRA::REST::Class
' get method that defaults to this issue's URL. Allows for extra parameters to be specified.
post
Wrapper around JIRA::REST::Class
' post method that defaults to this issue's URL. Allows for extra parameters to be specified.
put
Wrapper around JIRA::REST::Class
' put method that defaults to this issue's URL. Allows for extra parameters to be specified.
delete
Wrapper around JIRA::REST::Class
' delete method that defaults to this issue's URL. Allows for extra parameters to be specified.
RELATED CLASSES
AUTHOR
Packy Anderson <packy@cpan.org>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2017 by Packy Anderson.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)