Streamline your workflow with a CLI tool that integrates Git and Jira. Quickly create, name, and delete branches using the Issue Key, ensuring consistency and efficiency in branch management.
- Seamless Branch Creation: Easily create new Git branches by simply passing the Issue Key into the CLI.
- Integration with Git and Jira: Leverages the Git and Jira APIs to streamline your workflow.
- Automated Branch Naming: Automatically generates branch names based on Jira Ticket Summary, ensuring consistent and meaningful branch names.
- Branch Deletion: Conveniently delete branches directly from the CLI for efficient repository management.
- Configure your Jira API settings in the
.env
file.
BRCHA_HOST=example.atlassian.net
BRCHA_EMAIL=[email protected]
BRCHA_TOKEN=api_token
NOTE: for
Bearer
auth leaveBRCHA_EMAIL
field empty!
- Define mappings for your Jira issue types in the configuration the
.env
file. Use zero if you want to ignore a specific type.
BRCHA_TYPE_MAPPING=build:0;chore:0;ci:0;docs:0;feat:0;fix:0;pref:0;refactor:0;revert:0;style:0;test:0
If you have multiple IDs of the same type, separate them with a comma (,
).
BRCHA_TYPE_MAPPING=build:10001,10002,10003;...
You can curl
available issuetype
s from Jira.
curl \
-D- \
-X GET \
-u "[email protected]:token" \
-H "Content-Type: application/json" \
https://{host}/rest/api/2/issuetype
or
curl \
-D- \
-X GET \
-H "Authorization: Bearer {token}" \
-H "Content-Type: application/json" \
https://{host}/rest/api/2/issuetype
- Specify the branch that will serve as the base when checking out before deleting local branches. This ensures consistency and avoids issues during cleanup operations.
BRCHA_DEV_BRANCH_NAME=develop
- Specify any exclusion phrases to be removed from the branch name, if applicable.
BRCHA_EXCLUDE_PHRASES=front,mobile,android,ios,be,web,spike,eval
- Copy
.env
file into~/.config/brcha/
folder.
mkdir -p ~/.config/brcha/ && \
cp .env ~/.config/brcha/
- Compile the tool into an executable file or download compiled executable.
go build
- Move the executable into
/usr/local/bin
for easy global access.
mv brcha /usr/local/bin
brcha [arguments]
Note: Remote branches can only be deleted if a corresponding local branch exists.
help
- Displays help information for all available commands and options in the CLI tool, providing usage instructions
and examples. Use this command to understand how to use the tool effectively.
brcha -help
i <issue-key>
- The branch prefix after branch type. Uses Jira Issue Key.
brcha -i XXX-00
t <branch-type>
- (optional) Overrides the type of branch to create, allowing the branch name ignore mapped Jira
issue types. Branches are named according to the standard.
brcha -i XXX-00 -t ci
Available branch types
build
,b
- Changes that affect the build system or external dependencies (example scopes: gradle, npm)chore
,ch
- Routine tasks that don't affect the functionality or user-facing aspects of a projectci
- Changes to our CI configuration files and scripts (example scopes: Travis, Circle, BrowserStack, SauceLabs)docs
,d
- Documentation only changesfeat
,ft
- A new featurefix
,fx
- A bug fixperf
,p
- A code change that improves performancerefactor
,rf
- A code change that neither fixes a bug nor adds a featurerevert
,rv
- A code that restors to a previous or default conditionstyle
,s
- Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)test
,t
- Adding missing tests or correcting existing tests
clean
- Deletes all local branches which have Jira tickets in 'Done' state.
brcha -clean
r <remote>
- (optional) Allows the deletion of remote branches alongside their corresponding local branches.
brcha -clean -r origin
assignee <username>
- (optional) Specifies the username (from the email) to verify that the Jira issue is assigned to you before permitting remote branch deletion. Use your Jira email, which might match BRCHA_EMAIL
, e.g., [email protected]
.
brcha -clean -r origin -assignee example.user
In case you want to experiment with custom branch formatting or extend existing methods go to branch.go
file.
func BuildName(bt Type, jiraIssue network.JiraIssue, excludePhrases string) string {
summary := replacePhrases(*jiraIssue.Fields.Summary, excludePhrases)
summary = strings.ToLower(summary)
summary = strings.TrimSpace(summary)
summary = stripRegex(summary)
summary = strings.TrimSuffix(summary, wordSeparator)
...
// returns "branchType/jiraIssue.Key_summary"
}
~% brcha -i XX-111
~% branch created: task/XX-111_jira-issue-name
~% brcha -i XX-111 -t fx
~% branch created: fix/XX-111_jira-issue-name
~% brcha -clean
~% branch deleted: fix/XX-111_jira-issue-name
~% brcha -clean -r origin
~% branch deleted: fix/XX-111_jira-issue-name
~% remote branch deleted: origin/fix/XX-111_jira-issue-name
~% brcha -clean -r origin -assignee example.user
~% branch deleted: fix/XX-111_jira-issue-name
~% remote branch deleted: origin/fix/XX-111_jira-issue-name