- Contributions to core code must be GPLv3 (but not libraries)
- If you'd like to work on a feature, please open a ticket and assign it to yourself
- Changes should be made in a new branch
- Please provide meaningful commit messages
- Ensure code passes existing unit tests, or provide updated test(s)
gofmt
your code- Any changes to
vendor/
should be in a distinct commit - Avoid use of
CGO
(limits cross-platform support) - Avoid use of empty interfaces
- Never trust the user, applied in a common-sense way.
- Secure by default, please ensure any contributed code follows this methodology to the best of your ability. It should be difficult to insecurely configure features/servers.
- It is better to fail securely than operate in an insecure manner.
- Avoid incorporating user controlled values when constructing file/directory paths. Ensure any values that must be incorporated into paths are properly canolicalized.
- Never use homegrown or non-peer reveiwed encryption or random number generation algorithms.
- Whenever possible, use the following algorithms/encryption modes:
- AES-GCM-256
- RSA-OAEP-2048 / RSA-OAEP-4096
- SHA2-256 / HMAC-SHA2-256 or higher (e.g. SHA2-384)
- Curves P521, P384, P256
- Never use the following in a security context, and avoid use even in a non-security context:
- MD5
- SHA1
- AES-ECB
- AES-CBC, AES-CTR, etc. -without use case justification
math/random
should always be imported asinsecureRand
and never used to generate values related to a security context.- Always apply the most restrictive file permissions possible.
- Apply obfuscation techniques when possible, but do not rely upon obfuscation for security.