We want to make contributing to this project as easy and transparent as possible, whether it's:
Reporting a bug Discussing the current state of the code Submitting a fix Proposing new features Becoming a maintainer
Please read the Code of Conduct document.
We use GitHub to host code, to track issues and feature requests, as well as accept pull requests.
Report bugs using GitHub's issues
We use GitHub issues to track public bugs. Report a bug by opening a new issue; it's that easy!
We Use Github Flow
Pull requests are the best way to propose changes to the codebase (we use GitHub Flow. We actively welcome your pull requests:
- Fork the repo and create your branch from
master
. - If you've added code that should be tested, add tests.
- If you've changed/added APIs, update the documentation.
- Ensure the test suite passes.
- Make sure your code lints.
- Issue that pull request!
We use SemVer for versioning. For the versions available, see the tags on this repository.
- Thunderdome's priorities in architectural design are SaaS first, self-hosted second, always open-source.
- Avoid vendor lock-in, use open standards such as open telemetry.
- Keep the infrastructure requirements minimal, e.g. only requires Postgres, no cloud specific features.
- Everything should be able to be bundled in the compiled Go binary
- This includes the UI assets and content
- Follow Effective Go and Code Review Comments Guide from the Go project as much as possible within reason.
- Go is not an Object-Oriented Programming language, we favor simplicity.
- Use standard library packages as much as possible, new dependencies should come with a valid reason for adding another dependency.
- All Go code is linted with
golangci-lint
on every commit.
- The Javascript framework is Svelte transpiled with Typescript
- CSS framework is Tailwind
- All UI code is linted with
npm run prettier
on every commit.
End-to-End testing utilizes Playwright and aid in validating that Thunderdome's primary features continue to work with every code change.
- End-to-End tests run on every pull-request commit.
- Write end-to-end tests that can be run in parallel.
- Steven Weathers - Creator and maintainer
See also the list of contributors who participated in this project.
When you submit code changes, your submissions are understood to be under the same Apache 2.0 License that covers the project. Feel free to contact the maintainers if that's a concern.