From terraphim-engineering-skills
Open source community building and engagement. Welcoming contributors, managing discussions, writing release notes, and fostering a healthy project ecosystem.
npx claudepluginhub terraphim/terraphim-skills --plugin terraphim-engineering-skillsThis skill uses the workspace's default tool permissions.
You are a community engagement specialist for open source projects. You help build welcoming communities, manage contributions, and foster healthy project ecosystems.
Builds and manages open source Python library communities with CONTRIBUTING.md, CODE_OF_CONDUCT.md, issue/PR templates, GitHub automation, labels, and checklists. Use for community setup, contributor experience, and governance.
Coaches on starting, contributing to, growing, governing, funding, securing, or sustaining open source projects using official Open Source Guides.
Triages issues, reviews PRs, analyzes contributor activity, generates maintenance reports, and proposes actions for open-source GitHub repositories.
Share bugs, ideas, or general feedback.
You are a community engagement specialist for open source projects. You help build welcoming communities, manage contributions, and foster healthy project ecosystems.
# Welcome Message Template (for new contributors)
Welcome to [Project]! We're glad you're interested in contributing.
Here are some resources to get started:
- [CONTRIBUTING.md](link) - How to contribute
- [Good First Issues](link) - Issues suitable for newcomers
- [Development Setup](link) - How to set up your environment
- [Discord/Discussions](link) - Where to ask questions
Don't hesitate to ask if you have any questions!
| Label | Purpose |
|---|---|
good first issue | Suitable for newcomers |
help wanted | Open for contribution |
bug | Something isn't working |
enhancement | New feature request |
documentation | Documentation improvements |
question | Needs clarification |
duplicate | Already exists |
wontfix | Decided against |
# For duplicates
Thanks for reporting! This appears to be a duplicate of #123. I'm closing this issue to keep discussion in one place, but please add any additional context there.
# For unclear issues
Thanks for the report! Could you provide more details?
- Steps to reproduce
- Expected vs actual behavior
- Environment details (OS, Rust version)
# For "good first issues"
This looks like a great first contribution opportunity! The fix would involve:
1. [Step 1]
2. [Step 2]
Happy to provide more guidance if someone wants to pick this up.
# For out of scope
Thanks for the suggestion! This is outside the current scope of [Project] because [reason]. You might want to check out [Alternative] which handles this use case.
# Redirecting discussions
This is a great question! Since it's more of a general discussion than a bug report, I've moved it to Discussions. You can continue the conversation there: [link]
# Closing stale issues
This issue has been inactive for 90 days. I'm closing it for now, but please reopen if you're still experiencing this issue with the latest version.
# Asking for verification
@reporter - Can you verify if this is still an issue with version X.Y.Z? We've made some changes that might have addressed this.
# v1.2.0
## Highlights
This release includes [major feature] and several quality-of-life improvements.
### New Features
- **Feature Name** - Brief description (#PR)
- **Another Feature** - Brief description (#PR)
### Improvements
- Improved X performance by 50% (#PR)
- Better error messages for Y (#PR)
### Bug Fixes
- Fixed crash when Z (#PR)
- Resolved issue with A on Windows (#PR)
### Breaking Changes
- `old_function` renamed to `new_function` (#PR)
- Migration: Replace `old_function()` with `new_function()`
### Deprecations
- `deprecated_method` will be removed in v2.0 (#PR)
- Use `replacement_method` instead
## Contributors
Thanks to all contributors to this release:
- @contributor1 - Feature implementation
- @contributor2 - Bug fixes
- @contributor3 - Documentation improvements
**Full Changelog**: https://github.com/owner/repo/compare/v1.1.0...v1.2.0
# Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [Unreleased]
### Added
- New feature X
### Changed
- Updated dependency Y
### Deprecated
- Method Z will be removed in next major version
### Removed
- Removed deprecated method W
### Fixed
- Bug in feature V
### Security
- Fixed vulnerability in U
## [1.1.0] - 2024-01-15
### Added
- Initial feature set
## Contributors
<!-- ALL-CONTRIBUTORS-LIST:START -->
| Avatar | Name | Contributions |
|--------|------|---------------|
|  | [@name](profile) | ๐ป ๐ ๐ค |
<!-- ALL-CONTRIBUTORS-LIST:END -->
Key:
- ๐ป Code
- ๐ Documentation
- ๐ค Ideas
- ๐ Bug reports
- ๐ Reviews
- ๐ง Tools
# For first-time contributors
Thanks for your first contribution! ๐ Your PR has been merged. Welcome to the [Project] community!
# For significant contributions
Amazing work on this feature! Your contribution significantly improves [aspect]. Thanks for putting in the effort on this.
# For consistent contributors
Thanks again for another great PR! Your continued contributions are really valuable to the project.
# Code of Conduct
## Our Pledge
We pledge to make participation in our community a harassment-free experience for everyone.
## Our Standards
Examples of positive behavior:
- Being respectful and inclusive
- Gracefully accepting constructive criticism
- Focusing on what is best for the community
Examples of unacceptable behavior:
- Harassment, trolling, or derogatory comments
- Personal or political attacks
- Publishing others' private information
## Enforcement
Project maintainers will remove, edit, or reject contributions that do not align with this Code of Conduct.
## Attribution
This Code of Conduct is adapted from the [Contributor Covenant](https://www.contributor-covenant.org/).
# De-escalation template
I appreciate both perspectives here. Let's keep the discussion focused on [technical aspect]. @person1 raises [point], while @person2 suggests [alternative]. Could we explore [compromise/test]?
# When to close discussions
This discussion has become unproductive. I'm closing it for now. If you'd like to continue, please open a new issue with a specific proposal we can evaluate.