Skip to content

Latest commit

 

History

History
130 lines (71 loc) · 7.9 KB

guidelines.md

File metadata and controls

130 lines (71 loc) · 7.9 KB

GitHub Best Practices Template

The following indications assume that you have admin or owner permissions in the project.

☑️ Checklist

This is the list of actions you should address:

The musts

The shoulds

  • Consider clearly identifying and setting the Code owners in your project.
  • Consider using Templates for your issues/pull requests.

The coulds

💡 Best Practices

In the following, we cover the main elements you should configure to prepare your project.

🧾 Project description

The project description is a short text which tells your community about the work you are developing.

You can edit the project description in the About tab of the repository (click on the gear icon on the top right). Create a descriptive entry for the project, and include at least three tags. If the project has a website, indicate also the URL.

Finally, decide whether your repository page should include Releases, Packages or Environments tabs. In case of doubt, remove them. You can find more information about Releases, Packages and Enviroments in the official GitHub documentation.

👩‍💻 Contributing guidelines

Contributing guidelines describe how people can help with the development of your project. Is the project developed by a single contributor? Can anyone jump in and help on the development? How to send contributions?

Contributing guidelines are generally provided in the well-known file CONTRIBUTING.md file.

This template includes a proposal for CONTIBUTING.md. Please, read carefully the provided template and adapt to your needs. Note that you will have to substitute the YOUR-ORGANIZATION and YOUR-PROJECT placeholders with the name of your organization and project, respectively.

👮‍♀️ Code of Conduct

The Code of conduct (CoC) of your project establishes the set of behavioral rules for the community. How harassment cases will be resolved? To whom you have to contact if you feel attacked?

Code of conduct is often defined in the CODE_OF_CONDUCT.md file.

This template includes a proposal for CODE_OF_CONDUCT.md. Please, read carefully the provided template and adapt to your repository.

🏛️ Governance

Governance rules define the set of norms which are applied to make decisions in your project, and your community. On the one hand, governance project rules address questions such as: who will accept my pull request?, or how much time it will take to be accepted? On the other hand, governance community rules cover questions such as: who will accept me as part of the project leaders?

The explicit definition of governance rules is not a trivial task, but when done, it is usually defined in the GOVERNANCE.md file. You can find a list of typical questions to address when defining governance rules here.

This template includes a proposal for GOVERNANCE.md. Please, read carefully the provided template and adapt to your repository.

👑 Code Owners

The code owners are those contributors that are responsible for code in your project. Thus, code owners are automatically requested for review when someone opens a pull request that modifies code that they own.

In GitHub you define the code owner in the CODEOWNERS file. You can find more information in the official documentation. Please, check the official documentation to be sure that write permissions in the repository are properly set.

This template includes an example proposal for CODEOWNERS extracted from the official documentation.

🖊️ Templates

GitHub supports the definition of templates for the issues and pull requests in the project. This helps your community to better fill in these elements.

This project proposes templates for issues and pull requests. You can find them in the .github folder.

If you do not plan to use these templates, remove the folder.

⚖️ License

The license sets the legal framework for your project.

Choose the most appropriate license is a hard and time-consuming task. There are websites that can help you to pick one, such as Choose a License.

In this template, we have started by the CC-BY-SA license as starter point, but we recommend you to explore the alternatives and change it to the most suitable license for your work.

👮‍♀️ Security policy

Security policy describes how to report security vulnerabilities in your project. If your project does not cover this topic, you can remove the SECURITY.md file.

In GitHub, security policy is defined in the SECURITY.md file.

This template includes a proposal for SECURITY.md. Please, read it carefully and adapt to your needs. You can find more information in the official documentation.

💰 Funding

Funding and sponsor indications helps your community to know how to support your work.

In GitHub, funding and sponsor indications are defined in the FUNDING.yml file.

This template includes a proposal for FUNDING.yml. Please, read it carefully and adapt to your needs. After adapting the file, remember to activate the sponsor button in your repository (Settings / General / Sponsorship)

You can find more information in the official documentation.

📓 Citation

If your work is related to a paper, and you want to facilitate its citation, review the CITATION.cff file.

The provided template will help to fill the gaps, but if you need more help, you can find more information in Citation File Format. Otherwise, just remove the file.

🗒️ Readme

As last step, modify the README.md file. This file summarizes your project, and normally includes sections for:

  • Description: Short description of your project.
  • Requirements & Installation: How to configure/install your work (if required).
  • Repository structure: Describes the main elements of your repository
  • Usage & Examples: Includes some usage indications and illustrative examples.
  • Contributing & Governance: You can refer to CONTRIBUTING.md and GOVERNANCE.md.
  • Code of Conduct: You can refer to CODE_OF_CONDUCT.md.
  • License: You can refer to LICENSE.md