Your contributions mean a lot to us, and we are excited to include the community at every opportunity.
Our goal is to make the process of contributing seamless and straightforward, whether you're:
- Reporting an issue
- Reviewing the existing code
- Proposing a correction
- Suggesting a new feature
- Interested in becoming a maintainer
We leverage GitHub for hosting our code, managing issues, feature requests, and for processing pull requests.
The most effective way to suggest changes to our codebase is through pull requests, following the Github Flow. We eagerly await your pull requests!
While the following workflow is tailored for Terraform submissions, it generally applies to other codes as well:
- Fork the repository and branch out from
main
. - Ensure you've verified your code with
terraform validate
,tfsec
,checkov
, or other linting/security tools. - Use
terraform fmt -recursive
or another formatter like prettier to format your Terraform code. - Files and variables should adhere to the "What You See Is What You Get" (WYSIWYG) naming guideline. For instance, in a terraform repo:
terraform-${provider}-${purpose}/ # For example, the provider can be 'azurerm' and the purpose can be 'virtual-network'
|
├── ${purpose}.tf # The primary function of the Terraform code, e.g., for a virtual network, it would be named 'vnet.tf'
├── input.tf # For input variables
├── LICENSE # Exclusively the MIT License
├── locals.tf # If locals are required
├── output.tf # For output variables
├── README.md # Documentation
- Every
README.md
must be informative. For Terraform, always include a code example that successfully executes the module, and a markdown-formatted output from terraform-docs:
terraform-docs markdown . >> README.md
- Organize all variables alphabetically. In Terraform, this can be achieved with the following utility script:
curl https://raw.githubusercontent.com/DJBerwick/utils/main/scripts/terraform/tf-sort.sh | bash
- Now, you're ready to submit your pull request!
In essence, when you provide code changes, your contributions automatically fall under the same MIT License that governs the project. If this raises concerns, please reach out to the maintainers.
For tracking and addressing public bugs, we utilize GitHub issues. Simply open a new issue to report a bug. It's that simple!
Exceptional Bug Reports typically include:
- A concise summary or background
- Steps to reproduce the issue
- Be as detailed as possible
- Provide sample code when feasible
- Your initial expectations
- The actual result
- Additional notes or observations, such as potential reasons for the issue or attempted solutions
Comprehensive bug reports are invaluable to us. Truly, we can't emphasize this enough.
By offering your contributions, you consent to license them under the MIT License.