How to Contribute
How to contribute
Create a case in the Ed-Fi Community Hub, providing the following information:
- Project Name:
- Brief Description:
- Contact name/email:
- Ed-Fi version supports (if applicable):
- License terms:
- Ed-Fi-hosted repo needed?
- A member of the Ed-Fi technical team will follow up with you via the ticket.
Tips for a Smooth Contribution Process
-
Carefully review your code for security and privacy:
-
Ensure there are no private keys and secrets, access tokens, or passwords
-
Make sure there are no live student data
-
If there are realistic-looking, yet fake, student data, it might be worth stating that clearly in the project Readme to head off concerns that real data might have leaked out.
-
-
Read Signing Git Commits - the Git commits needs to be signed in order to prove identity.
-
Provide a useful README file describing the functionality.
-
Provide installation instructions. These do not need to be absolutely foolproof; they need only be good enough to set someone in the right direction.
Example: Readme and Deployment instructions from the SDCOE Data Hub
Creating a New Exchange Repository on GitHub
These notes are primarily for the internal audience of users who can create new repositories for community contributions. The community may find them helpful in thinking about creating their own repositories as well.
- Preferably create the repository from the "Template-For-GitHub" repository (this is an option on the "Create Repository" page). (warning) This only applies to authorized users when they are creating a repository inside the Ed-Fi-Exchange-OSS organization on GitHub.
-
Once created, update the README, NOTICES, and CONTRIBUTORS files. Just read the text and the required updates should hopefully be clear.
-
Go to the Settings page: disable Wikis. If the project will be supported by the Ed-Fi / MSDF team, best to disable Issues so that people are forced to post in Tracker rather than in GitHub. But third parties might like to have the Issues.
-
In settings, click on Branches, then setup branch protection rules. Branch name pattern: main. Enable: require a pull request before merging; require status checks to pass before merging; require signed commits; require linear history. If someone else really doesn't want these features, we can turn off - except "Require signed commits".
-
Give WRITE access to the contributor.