This project accepts contributions. In order to contribute, you should pay attention to a few things:
- your code must follow the The Bastion design choices, see DESIGN.md
- your code must follow the coding style rules
- your code must be added to the unit and/or integration tests where applicable
- your code must be documented
- your work must be signed (see below)
- you may contribute through GitHub Pull Requests
- All languages
- Code must be indented with 4-spaces, no tabs. Vim modelines are present in all source files, so if you use vim, you should be good to go
- Perl
- Code must be tidy (see
bin/dev/perl-tidy.sh
) - Code must not raise any perlcritic warning (see
bin/dev/perl-critic.sh
) - One must refrain using any non-core Perl module (check
corelist
)- If not possible, the module should be packaged at least under Debian,
all supported versions, and available at least in trusted third party
repositories on other supported OSes. No
cpan install
.
- If not possible, the module should be packaged at least under Debian,
all supported versions, and available at least in trusted third party
repositories on other supported OSes. No
- Code must be tidy (see
- POSIX shell and Bash
- Code must not raise any shellcheck warning (see
bin/dev/shell-check.sh
)
- Code must not raise any shellcheck warning (see
The contributions should be submitted through Github Pull Requests and follow the DCO which is defined below.
The Bastion is licensed under the Apache License 2.0. Anything contributed to The Bastion must be released under this license.
When introducing a new file into the project, please make sure it has a copyright header making clear under which license it's being released.
To improve tracking of contributions to this project we will use a process modeled on the modified DCO 1.1 and use a "sign-off" procedure on patches that are being emailed around or contributed in any other way.
The sign-off is a simple line at the end of the explanation for the patch, which certifies that you wrote it or otherwise have the right to pass it on as an open-source patch. The rules are pretty simple, if you can certify the below:
By making a contribution to this project, I certify that:
(a) The contribution was created in whole or in part by me and I have the right to submit it under the open source license indicated in the file; or
(b) The contribution is based upon previous work that, to the best of my knowledge, is covered under an appropriate open source License and I have the right under that license to submit that work with modifications, whether created in whole or in part by me, under the same open source license (unless I am permitted to submit under a different license), as indicated in the file; or
(c) The contribution was provided directly to me by some other person who certified (a), (b) or (c) and I have not modified it.
(d) The contribution is made free of any other party's intellectual property claims or rights.
(e) I understand and agree that this project and the contribution are public and that a record of the contribution (including all personal information I submit with it, including my sign-off) is maintained indefinitely and may be redistributed consistent with this project or the open source license(s) involved.
then you just add a line saying
Signed-off-by: Random J Developer <[email protected]>
using your real name (sorry, no pseudonyms or anonymous contributions.)