git-profile
SKILL.md
Git Profile Manager
Manage git identity and GPG signing profiles per-repository.
Workflow
sequenceDiagram
participant U as User
participant SK as SKILL.md
participant SH as git-profile.sh
participant AQ as AskUserQuestion
U->>SK: /git-profile [subcommand]
SK->>SK: Parse subcommand (default: doctor)
alt doctor (default)
SK->>SH: doctor
SH-->>SK: Diagnostic JSON
SK->>U: Health report table
end
alt list
SK->>SH: list
SH-->>SK: Profiles JSON
SK->>U: Profile table with current match
end
alt use <profile>
SK->>SH: resolve <profile>
SH-->>SK: Plan JSON + plan-hash
SK->>AQ: "Apply [hash] to local config?" / "Abort"
AQ-->>SK: Approved
SK->>SH: apply --plan-hash <hash>
SH-->>SK: Result JSON
SK->>U: Applied / Error
end
alt remove <profile>
SK->>SH: remove-check <profile>
SH-->>SK: Safety JSON (active repos list)
alt profile is active
SK->>AQ: "Profile active in N repos. Remove anyway?" / "Cancel"
end
SK->>SH: remove-exec <profile> [--force]
SH-->>SK: Result JSON
SK->>U: Removed / Error
end
alt verify
SK->>SH: verify
SH-->>SK: Verification JSON
SK->>U: Verification report
end
Subcommands
doctor (default)
Run diagnostics on current repository's git identity and GPG signing config.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh doctor - Parse the JSON output
- Render a health report table:
## Git Profile Health
| Item | Value | Source | Status |
|------|-------|--------|--------|
| Name | ... | ... | ... |
| Email | ... | ... | ... |
| Signing | ... | ... | ... |
| GPG Key | ... | ... | ... |
| Env Override | ... | ... | ... |
| Worktree | ... | ... | ... |
| Profile Match | ... | ... | ... |
Status: [overall status]
- If
statusishalt: show the issue and stop - If
statusiswarn: show warnings, continue - If registry is missing AND this is the first run: trigger auto-discovery (see below)
list
List all registered profiles.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh list - Parse the JSON output
- Render a profile table with a marker on the currently matched profile
use <profile>
Switch the current repository to use a named profile.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh resolve <profile> - Parse the plan JSON — contains profile data, planned commands, and plan-hash
- Show the user what will be written:
## Apply Profile: <profile-id>
| Config Key | Current | New |
|------------|---------|-----|
| user.name | ... | ... |
| user.email | ... | ... |
| user.signingkey | ... | ... / (unset) |
| commit.gpgsign | ... | true / (unset) |
Note: Keyless profiles unset signing-related keys instead of setting them.
- Use
AskUserQuestionwith options:"Apply [<plan-hash>] to local config (Recommended)""Abort"
- On approval:
bash scripts/run-skill.sh git-profile git-profile.sh apply --plan-hash <hash> - Parse result; if error (hash mismatch, write failure) report and stop
- On success: report applied config
remove <profile>
Remove a profile from the registry.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh remove-check <profile> - If profile is active in any repo, use
AskUserQuestion:"Profile is active in N repos. Remove with --force?""Cancel"
- On approval:
bash scripts/run-skill.sh git-profile git-profile.sh remove-exec <profile> [--force] - Report result
verify
Deep verification of current identity setup.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh verify - Parse the verification JSON
- Render verification report with checks:
- Key expiry (90-day warning threshold)
- Email match between git config and GPG key UID
- Registry consistency
Auto-Discovery
Triggered when: registry file is missing on first doctor run.
Steps:
- Run:
bash scripts/run-skill.sh git-profile git-profile.sh discover - Parse candidates JSON
- Present candidates to user via
AskUserQuestion:"Save N discovered profiles to registry (Recommended)""Skip — I'll configure manually"
- If approved, the discover command already persisted them; confirm to user
- If skipped, create an empty registry to avoid re-prompting
Safety Rules
| Rule | Description |
|---|---|
v1 NEVER writes ~/.gitconfig |
Only --local scope writes |
v1 NEVER enables extensions.worktreeConfig |
Linked worktree: detect + warn only |
| NEVER auto-fix without confirmation | All writes gated by AskUserQuestion |
| NEVER store key material | Registry stores fingerprints only |
| Plan-hash verification | Re-compute hash before apply; reject if stale |
| Atomic registry writes | temp file + chmod 0600 + mv |
Diagnostic Integration
The doctor --json output follows the Shared Diagnostic Contract (see tech spec section 3.2).
Other skills (e.g., /smart-commit Step 1c) can call:
bash scripts/run-skill.sh git-profile git-profile.sh doctor --json
Degradation policy: If the script is not found or fails, the calling skill falls back to its own inline diagnostics. Infrastructure failure = warn-only; identity/signing missing = halt (unchanged).
Weekly Installs
1
Repository
sd0xdev/sd0x-dev-flowGitHub Stars
86
First Seen
7 days ago
Security Audits
Installed on
amp1
cline1
opencode1
cursor1
kimi-cli1
codex1