Create a new Git Flow hotfix branch from main for emergency production fixes
Create emergency hotfix branch from main for critical production fixes. Use only for security vulnerabilities, production-breaking bugs, or data loss issuesโnot regular bug fixes.
/plugin marketplace add huangdijia/oh-my-claude-code-plugins/plugin install git@claude-plugins<hotfix-name>Create emergency hotfix branch: $ARGUMENTS
git branch --show-currentgit status --porcelaingit describe --tags --abbrev=0 origin/main 2>/dev/null || echo "No tags on main"git log main..origin/main --oneline 2>/dev/null | head -3 || echo "No remote tracking for main"git log $(git describe --tags --abbrev=0 origin/main 2>/dev/null)..origin/main --oneline 2>/dev/null | wc -l | tr -d ' 'Create a Git Flow hotfix branch for emergency production fixes:
Critical Checks:
$ARGUMENTS is provided and descriptive
critical-security-patch, payment-gateway-fix, auth-bypass-fixfix, hotfix1, bugmain branch is presentโ ๏ธ IMPORTANT: Hotfix Usage Guidelines
Hotfixes are ONLY for:
NOT for:
# Switch to main branch
git checkout main
# Pull latest production code
git pull origin main
# Create hotfix branch from main
git checkout -b hotfix/$ARGUMENTS
# Set up remote tracking
git push -u origin hotfix/$ARGUMENTS
Analyze the latest tag to suggest hotfix version:
Current production version: v1.2.0
Hotfix version: v1.2.1
Version bump: PATCH (third number incremented)
Hotfix Version Rules:
โ Switched to main branch
โ Pulled latest production code from origin/main
โ Created branch: hotfix/$ARGUMENTS
โ Set up remote tracking: origin/hotfix/$ARGUMENTS
โ Pushed branch to remote
๐ฅ Hotfix Branch Ready: hotfix/$ARGUMENTS
Branch: hotfix/$ARGUMENTS
Base: main (production)
Will merge to: main AND develop
Suggested version: v1.2.1
โ ๏ธ CRITICAL HOTFIX WORKFLOW
This is an EMERGENCY production fix. Follow these steps:
1. ๐ Identify the Issue
- Reproduce the bug
- Understand the root cause
- Document the impact
2. ๐ ๏ธ Implement the Fix
- Make MINIMAL changes
- Focus ONLY on the critical issue
- Avoid refactoring or improvements
- Add tests to prevent regression
3. ๐งช Test Thoroughly
- Test the specific fix
- Run full regression tests
- Test on production-like environment
- Verify no side effects
4. ๐ Document the Fix
- Update version in package.json
- Add entry to CHANGELOG.md
- Document the bug and fix
- Include reproduction steps
5. ๐ Deploy Process
- Create PR to main
- Get expedited review
- Run /finish to merge and tag
- Deploy to production immediately
- Monitor for issues
๐ฏ Next Steps:
1. Fix the critical issue (MINIMAL changes only)
2. Test thoroughly: npm test
3. Update version: v1.2.1
4. Create emergency PR: gh pr create --label "hotfix,critical"
5. Get fast-track approval
6. Run /finish to merge to main AND develop
7. Deploy to production
8. Monitor systems closely
โ ๏ธ Remember:
- Hotfix will be merged to BOTH main and develop
- Tag v1.2.1 will be created on main
- Production deployment should happen immediately
- Team should be notified of the hotfix
No Hotfix Name Provided:
โ Hotfix name is required
Usage: /hotfix <hotfix-name>
Examples:
/hotfix critical-security-patch
/hotfix payment-processing-failure
/hotfix auth-bypass-vulnerability
โ ๏ธ IMPORTANT: Hotfixes are for CRITICAL production issues only!
For non-critical fixes, use:
/feature <name> - Regular bug fixes
Invalid Hotfix Name:
โ Invalid hotfix name: "fix"
Hotfix names should be:
- Descriptive of the issue
- Use kebab-case format
- Indicate severity/urgency
Examples:
โ
critical-security-patch
โ
payment-gateway-timeout
โ
user-data-corruption-fix
โ fix
โ bug1
โ hotfix
Uncommitted Changes:
โ ๏ธ Uncommitted changes detected in working directory:
M src/file.js
A test.js
Hotfixes require a clean working directory.
Options:
1. Commit your changes first
2. Stash them: git stash
3. Discard them: git checkout .
โ ๏ธ This is an emergency hotfix. Please clean your working directory.
Main Branch Behind Remote:
โ ๏ธ Local main is behind origin/main by 2 commits
โ Pulling latest production code...
โ Fetched 2 commits
โ Main is now synchronized with production
โ Ready to create hotfix branch
Not a Critical Issue:
โ ๏ธ Hotfix Confirmation Required
Is this a CRITICAL production issue that requires immediate attention?
Critical issues include:
- Security vulnerabilities
- Production system failures
- Data loss or corruption
- Payment/transaction failures
If this is NOT critical, consider:
- Creating a feature branch instead
- Waiting for the next release cycle
- Using regular bug fix workflow
Proceed with hotfix? [y/N]
๐ฅ Emergency Hotfix Checklist
Issue Identification:
- [ ] Bug is confirmed and reproducible
- [ ] Root cause is identified
- [ ] Impact is documented
- [ ] Stakeholders are notified
Development:
- [ ] Fix is minimal and focused
- [ ] No unnecessary changes included
- [ ] Tests added to prevent regression
- [ ] Code reviewed (if time permits)
Testing:
- [ ] Fix verified in local environment
- [ ] Unit tests passing
- [ ] Integration tests passing
- [ ] Tested on production-like environment
- [ ] No side effects detected
Documentation:
- [ ] CHANGELOG.md updated
- [ ] Version bumped (PATCH)
- [ ] Bug description documented
- [ ] Fix explanation documented
- [ ] Deployment notes prepared
Deployment:
- [ ] PR created with "hotfix" and "critical" labels
- [ ] Fast-track approval obtained
- [ ] Production deployment plan ready
- [ ] Rollback plan documented
- [ ] Monitoring alerts configured
- [ ] Team notified of deployment
Post-Deployment:
- [ ] Fix verified in production
- [ ] Systems monitored for issues
- [ ] Metrics show improvement
- [ ] Hotfix merged back to develop
- [ ] Post-mortem scheduled (if needed)
After implementing the fix, update the version:
# Update package.json version (PATCH bump)
npm version patch --no-git-tag-version
# Update CHANGELOG.md
cat >> CHANGELOG.md << EOF
## [v1.2.1] - $(date +%Y-%m-%d) - HOTFIX
### ๐ฅ Critical Fixes
- Fix $ARGUMENTS: [brief description]
- Root cause: [explanation]
- Impact: [who/what was affected]
- Resolution: [what was fixed]
EOF
# Commit version bump
git add package.json CHANGELOG.md
git commit -m "chore(hotfix): bump version to v1.2.1
Critical fix for $ARGUMENTS
๐ค Generated with Claude Code
Co-Authored-By: Claude <noreply@anthropic.com>"
gh pr create \
--title "๐ฅ HOTFIX v1.2.1: $ARGUMENTS" \
--body "$(cat <<'EOF'
## ๐ฅ Emergency Hotfix
**Severity**: Critical
**Version**: v1.2.1
**Issue**: $ARGUMENTS
## Problem Description
[Detailed description of the production issue]
## Root Cause
[Explanation of what caused the issue]
## Fix Implementation
[Description of the fix applied]
## Testing
- [x] Issue reproduced locally
- [x] Fix verified locally
- [x] Unit tests passing
- [x] Integration tests passing
- [x] Tested on staging environment
## Deployment Plan
1. Merge to main
2. Tag as v1.2.1
3. Deploy to production immediately
4. Monitor for 30 minutes
5. Merge back to develop
## Rollback Plan
[How to rollback if issues occur]
## Monitoring
[What to monitor post-deployment]
---
**โ ๏ธ This is a critical production hotfix requiring immediate deployment**
๐ค Generated with Claude Code
EOF
)" \
--base main \
--head hotfix/$ARGUMENTS \
--label "hotfix,critical,priority-high" \
--assignee @me \
--reviewer team-leads
Hotfix Workflow in Git Flow:
main (v1.2.0) โโโโโโโฌโโโโโโโโโโโโโโบ (after hotfix merge) v1.2.1
โ
โโโบ hotfix/$ARGUMENTS
โ
โโโบ (merges back to both)
โ
develop โโโโโโโโโโโโโโโโโโโโโดโโโโโโโโโโโโโโบ (receives hotfix)
Important:
main (production)main AND developmain after mergeGIT_FLOW_MAIN_BRANCH: Main branch name (default: "main")GIT_FLOW_DEVELOP_BRANCH: Develop branch name (default: "develop")GIT_FLOW_PREFIX_HOTFIX: Hotfix prefix (default: "hotfix/")/finish - Complete hotfix (merge to main and develop, create tag, deploy)/git-flow:status - Check current Git Flow status/feature <name> - Create feature branch (for non-critical fixes)/release <version> - Create release branchDO:
DON'T:
After successful hotfix deployment:
Verify Fix in Production
Update Documentation
Merge to Develop
Post-Mortem (if needed)
Cleanup