Thanks for your interest in contributing to grype-server! Here are a few general guidelines on contributing and reporting bugs that we ask you to review. Following these guidelines helps to communicate that you respect the time of the contributors managing and developing this open source project. In return, they should reciprocate that respect in addressing your issue, assessing changes, and helping you finalize your pull requests. In that spirit of mutual respect, we endeavor to review incoming issues and pull requests within 10 days, and will close any lingering issues or pull requests after 60 days of inactivity.
Please note that all of your interactions in the project are subject to our Code of Conduct. This includes creation of issues or pull requests, commenting on issues or pull requests, and extends to all interactions in any real-time space e.g., Slack, Discord, etc.
- Troubleshooting and Debugging
- Reporting Issues
- Development
- Sending Pull Requests
- Other Ways to Contribute
Please see the troubleshooting and debugging guide here.
Before reporting a new issue, please ensure that the issue was not already reported or fixed by searching through our issues list.
When creating a new issue, please be sure to include a title and clear description, as much relevant information as possible, and, if possible, a test case.
If you discover a security bug, please do not report it through GitHub. Instead, please see security procedures in SECURITY.md.
make build
will build the grype-server binary.
make docker
can be used to build the grype-server container.
make push-docker
is also provided as a shortcut for building and then
publishing the grype-server container to a registry. You can override the
destination registry like:
DOCKER_REGISTRY=docker.io/tehsmash make push-docker
You must be logged into the docker registry locally before using this target.
After making changes to the API schema for example api/swagger.yaml
, you can run make api
to regenerate the model, client and server code.
make test
can be used run all the unit tests in the repo. Alternatively you
can use the standard go test CLI to run a specific package or test e.g.
go test ./... -run <test name regex>
Before sending a new pull request, take a look at existing pull requests and issues to see if the proposed change or fix has been discussed in the past, or if the change was already implemented but not yet released.
We expect new pull requests to include tests for any affected behavior, and, as we follow semantic versioning, we may reserve breaking changes until the next major version release.
We welcome anyone that wants to contribute to grype-server to triage and reply to open issues to help troubleshoot and fix existing bugs. Here is what you can do:
- Help ensure that existing issues follows the recommendations from the Reporting Issues section, providing feedback to the issue's author on what might be missing.
- Review and update the existing content of our Wiki with up-to-date instructions and code samples.
- Review existing pull requests, and testing patches against real existing applications that use grype-server.
- Write a test, or add a missing test case to an existing test.
Thanks again for your interest on contributing to grype-server!
❤️