mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-12-27 08:48:56 +01:00
Merge pull request #4259 from apjanke/jira-prefix-and-help-and-stuff
jira: prefix variable dashboard, default action, and completion
This commit is contained in:
commit
c084a13df2
21
plugins/jira/_jira
Normal file
21
plugins/jira/_jira
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
#compdef jira
|
||||||
|
#autoload
|
||||||
|
|
||||||
|
local -a _1st_arguments
|
||||||
|
_1st_arguments=(
|
||||||
|
'new:create a new issue'
|
||||||
|
'dashboard:open the dashboard'
|
||||||
|
'reported:search for issues reported by a user'
|
||||||
|
'assigned:search for issues assigned to a user'
|
||||||
|
)
|
||||||
|
|
||||||
|
_arguments -C \
|
||||||
|
':command:->command' \
|
||||||
|
'*::options:->options'
|
||||||
|
|
||||||
|
case $state in
|
||||||
|
(command)
|
||||||
|
_describe -t commands "jira subcommand" _1st_arguments
|
||||||
|
return
|
||||||
|
;;
|
||||||
|
esac
|
@ -1,90 +1,118 @@
|
|||||||
# To use: add a .jira-url file in the base of your project
|
# CLI support for JIRA interaction
|
||||||
# You can also set JIRA_URL in your .zshrc or put .jira-url in your home directory
|
|
||||||
# .jira-url in the current directory takes precedence
|
|
||||||
#
|
#
|
||||||
# If you use Rapid Board, set:
|
# Setup:
|
||||||
#JIRA_RAPID_BOARD="true"
|
# Add a .jira-url file in the base of your project
|
||||||
# in you .zshrc
|
# You can also set $JIRA_URL in your .zshrc or put .jira-url in your home directory
|
||||||
|
# A .jira-url in the current directory takes precedence.
|
||||||
|
# The same goes with .jira-prefix and $JIRA_PREFIX.
|
||||||
#
|
#
|
||||||
# Setup: cd to/my/project
|
# For example:
|
||||||
|
# cd to/my/project
|
||||||
# echo "https://name.jira.com" >> .jira-url
|
# echo "https://name.jira.com" >> .jira-url
|
||||||
# Usage: jira # opens a new issue
|
#
|
||||||
|
# Variables:
|
||||||
|
# $JIRA_RAPID_BOARD - set to "true" if you use Rapid Board
|
||||||
|
# $JIRA_DEFAULT_ACTION - action to do when `jira` is called witn no args
|
||||||
|
# defaults to "new"
|
||||||
|
# $JIRA_NAME - Your JIRA username. Used as default for assigned/reported
|
||||||
|
# $JIRA_PREFIX - Prefix added to issue ID arguments
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Usage:
|
||||||
|
# jira # Performs the default action
|
||||||
|
# jira new # opens a new issue
|
||||||
|
# jira reported [username]
|
||||||
|
# jira assigned [username]
|
||||||
|
# jira dashboard
|
||||||
# jira ABC-123 # Opens an existing issue
|
# jira ABC-123 # Opens an existing issue
|
||||||
open_jira_issue () {
|
# jira ABC-123 m # Opens an existing issue for adding a comment
|
||||||
if [ -f .jira-url ]; then
|
|
||||||
|
: ${JIRA_DEFAULT_ACTION:=new}
|
||||||
|
|
||||||
|
function jira() {
|
||||||
|
local action=${1:=$JIRA_DEFAULT_ACTION}
|
||||||
|
|
||||||
|
local jira_url jira_prefix
|
||||||
|
if [[ -f .jira-url ]]; then
|
||||||
jira_url=$(cat .jira-url)
|
jira_url=$(cat .jira-url)
|
||||||
elif [ -f ~/.jira-url ]; then
|
elif [[ -f ~/.jira-url ]]; then
|
||||||
jira_url=$(cat ~/.jira-url)
|
jira_url=$(cat ~/.jira-url)
|
||||||
elif [[ "x$JIRA_URL" != "x" ]]; then
|
elif [[ -n "${JIRA_URL}" ]]; then
|
||||||
jira_url=$JIRA_URL
|
jira_url=${JIRA_URL}
|
||||||
else
|
else
|
||||||
echo "JIRA url is not specified anywhere."
|
_jira_url_help
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -f .jira-prefix ]; then
|
if [[ -f .jira-prefix ]]; then
|
||||||
jira_prefix=$(cat .jira-prefix)
|
jira_prefix=$(cat .jira-prefix)
|
||||||
elif [ -f ~/.jira-prefix ]; then
|
elif [[ -f ~/.jira-prefix ]]; then
|
||||||
jira_prefix=$(cat ~/.jira-prefix)
|
jira_prefix=$(cat ~/.jira-prefix)
|
||||||
|
elif [[ -n "${JIRA_PREFIX}" ]]; then
|
||||||
|
jira_prefix=${JIRA_PREFIX}
|
||||||
else
|
else
|
||||||
jira_prefix=""
|
jira_prefix=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "$1" ]; then
|
|
||||||
|
if [[ $action == "new" ]]; then
|
||||||
echo "Opening new issue"
|
echo "Opening new issue"
|
||||||
open_command "${jira_url}/secure/CreateIssue!default.jspa"
|
open_command "${jira_url}/secure/CreateIssue!default.jspa"
|
||||||
elif [[ "$1" = "assigned" || "$1" = "reported" ]]; then
|
elif [[ "$action" == "assigned" || "$action" == "reported" ]]; then
|
||||||
jira_query $@
|
_jira_query $@
|
||||||
|
elif [[ "$action" == "dashboard" ]]; then
|
||||||
|
echo "Opening dashboard"
|
||||||
|
open_command "${jira_url}/secure/Dashboard.jspa"
|
||||||
else
|
else
|
||||||
local addcomment=''
|
# Anything that doesn't match a special action is considered an issue name
|
||||||
|
local issue_arg=$action
|
||||||
|
local issue="${jira_prefix}${issue_arg}"
|
||||||
|
local url_fragment=''
|
||||||
if [[ "$2" == "m" ]]; then
|
if [[ "$2" == "m" ]]; then
|
||||||
addcomment="#add-comment"
|
url_fragment="#add-comment"
|
||||||
echo "Add comment to issue #$1"
|
echo "Add comment to issue #$issue"
|
||||||
else
|
else
|
||||||
echo "Opening issue #$1"
|
echo "Opening issue #$issue"
|
||||||
fi
|
fi
|
||||||
|
if [[ "$JIRA_RAPID_BOARD" == "true" ]]; then
|
||||||
if [[ "x$JIRA_RAPID_BOARD" = "xtrue" ]]; then
|
open_command "${jira_url}/issues/${issue}${url_fragment}"
|
||||||
open_command "$jira_url/issues/$jira_prefix$1$addcomment"
|
|
||||||
else
|
else
|
||||||
open_command "$jira_url/browse/$jira_prefix$1$addcomment"
|
open_command "${jira_url}/browse/${issue}${url_fragment}"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
jira_name () {
|
function _jira_url_help() {
|
||||||
if [[ -z "$1" ]]; then
|
cat << EOF
|
||||||
if [[ "x${JIRA_NAME}" != "x" ]]; then
|
JIRA url is not specified anywhere.
|
||||||
jira_name=${JIRA_NAME}
|
Valid options, in order of precedence:
|
||||||
else
|
.jira-url file
|
||||||
echo "JIRA_NAME not specified"
|
\$HOME/.jira-url file
|
||||||
return 1
|
JIRA_URL environment variable
|
||||||
fi
|
EOF
|
||||||
else
|
|
||||||
jira_name=$@
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
jira_query () {
|
function _jira_query() {
|
||||||
verb="$1"
|
local verb="$1"
|
||||||
if [[ "${verb}" = "reported" ]]; then
|
local jira_name lookup preposition query
|
||||||
|
if [[ "${verb}" == "reported" ]]; then
|
||||||
lookup=reporter
|
lookup=reporter
|
||||||
preposition=by
|
preposition=by
|
||||||
elif [[ "${verb}" = "assigned" ]]; then
|
elif [[ "${verb}" == "assigned" ]]; then
|
||||||
lookup=assignee
|
lookup=assignee
|
||||||
preposition=to
|
preposition=to
|
||||||
else
|
else
|
||||||
echo "not a valid lookup $verb"
|
echo "not a valid lookup: $verb" >&2
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
shift 1
|
jira_name=${2:=$JIRA_NAME}
|
||||||
jira_name $@
|
if [[ -z $jira_name ]]; then
|
||||||
if [[ $? = 1 ]]; then
|
echo "JIRA_NAME not specified" >&2
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Browsing issues ${verb} ${preposition} ${jira_name}"
|
echo "Browsing issues ${verb} ${preposition} ${jira_name}"
|
||||||
open_command "${jira_url}/secure/IssueNavigator.jspa?reset=true&jqlQuery=${lookup}+%3D+%22${jira_name}%22+AND+resolution+%3D+unresolved+ORDER+BY+priority+DESC%2C+created+ASC"
|
query="${lookup}+%3D+%22${jira_name}%22+AND+resolution+%3D+unresolved+ORDER+BY+priority+DESC%2C+created+ASC"
|
||||||
|
open_command "${jira_url}/secure/IssueNavigator.jspa?reset=true&jqlQuery=${query}"
|
||||||
}
|
}
|
||||||
|
|
||||||
alias jira='open_jira_issue'
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user