Filebeat is an open source project and we love to receive contributions from our community — you!
There are many ways to contribute, from writing tutorials or blog posts, improving the documentation, submitting bug reports and feature requests or writing code for implementing a whole new protocol.
If you have a bugfix or new feature that you would like to contribute to Filebeat, please start by opening a topic on the forums. It may be that somebody is already working on it, or that there are particular issues that you should know about before implementing the change.
We enjoy working with contributors to get their code accepted. There are many approaches to fixing a problem and it is important to find the best approach before writing too much code.
The process for contributing to any of the Elastic repositories is similar.
- Test your changes! Run the test suite (
make test
) - Please make sure you have signed our Contributor License Agreement. We are not asking you to assign copyright to us, but to give us the right to distribute your code without restriction. We ask this of all contributors in order to assure our users of the origin and continuing existence of the code. You only need to sign the CLA once.
- Send a pull request! Push your changes to your fork of the repository and submit a pull request. In the pull request, describe what your changes do and mention any bugs/issues related to the pull request.
Filebeat is a Go program, so install golang if you don't have it already.
The location where you clone is important. Please clone under the source
directory of your GOPATH
. If you don't have GOPATH
already set, you can
simply set it to your home directory (export GOPATH=$HOME
).
$ mkdir -p $GOPATH/src/github.com/elastic
$ cd $GOPATH/src/github.com/elastic
$ git clone https://github.com/elastic/filebeat.git
and then compile it with:
$ cd filebeat
$ make
Before you open a pull request, run make clean
go apply gofmt.