git-graft
NPX CLI tool that generates a configurable Git Hook that prepends branch name patterns to commit messages.
Features:
- Generated Git Hook
- Zero Config Option -- following GitFlow DevOps best practices.
- Configurable git-graft.json
- Hook is a bin file running Node & no dependencies
- Validates the commit message and branch
- Usage
- Commands
Usage
$ npx git-graft (-v|--version|version)
git-graft/0.0.0 linux-x64 node-v14.16.1
$ npx git-graft --help
Main Usage
$npx git-graft [COMMAND]
...
Commands
Init
Git Graft currently only has one command for generating the Git Hook and configuration file.
example:
npx git-graft init
The prompts will be used to construct the configuration file and ask to modify permissions to allow for execution of the generated Git Hook. Without permission to execute the Git Hook cannot work.
TBD:
Doctor
- Will run permissions check on Git Graft Hook
- Will run unit tests on Git Graft Hook code
Configuration
The init generates a git-graft.json
that has properties for a configurable Git Hook. Configuration the patterns to validate the branch and resulting prepended commit message with branch information.
branchTypes:
RegExp List
required -- Refers to GitFlows from DevOps best practices. Git Graft Hook will wrap the list in ()
and the constructor includes the forward slash & escape \/
example
branchPattern:
RegExp
required -- Refers to the code/ticket and name of the branch following the branchType. example
ticketTypes:
string
required -- Refers to the ticket code types, for example JIRA will use TICKETTYPE-{NUMBERS}. The Git Hook will use this config to construct a RegExp
for the prepending to commit messages.
regExFlag:
RegExp
optional -- Flags to pass into RegEx constructors. Default: gim
ticketOnly:
boolean
optional -- Used to determine if ticket/code or whole branch should used. Default: true
RegEx Examples: