Thanks for your interest! We're so glad you're here. Thanks for helping make Tinkerbell better 😍!
There are many areas we can use contributions - ranging from code, documentation, feature proposals, issue triage, samples, and content creation.
First, please read and understand the code of conduct found here. By participating, you're expected to uphold this code.
There are multiple repositories within the Tinkerbell organization. Each repository has beginner-friendly issues that are a great place to get started on your contributor journey. For example, a list of issues for Tink repository can be found here. If there is something that you find interesting and would like to work on, go ahead. You can filter issues with label "good first issue", which are relatively self sufficient issues and great for first time contributors.
- If you are going to pick up an issue, it would be good to add a comment stating the intention.
- If the contribution is a big change/new feature, please raise an issue and discuss the needs, design in the issue in detail.
Do reach out on Slack or Twitter and we are happy to help.
- Drop by the Slack channel.
- Say "Hi!" on Twitter.
Not ready to contribute code, but see something that needs work? While the community encourages everyone to contribute code, it is also appreciated when someone reports an issue. Issues should be filed under the appropriate Tinkerbell subrepository. For example, a documentation issue should be opened in tinkerbell/tinkerbell-docs. Make sure to adhere to the prompted submission guidelines while opening an issue.
All submissions are more than welcome. There are multiple repositories within the Tinkerbell organization. Before you submit a change, you must fork the repository and submit a pull request with the change(s). Please ensure that you adhere to the prompted submission guidelines while raising a pull request. We will try to review and provide feedback as soon as possible.
Please read and understand the DCO found here.
Building is handled by make
, please see the Makefile for available targets.
This repo's build environment can be reproduced using nix
.
Follow the Nix installation guide to setup Nix on your box.
Loading build dependencies is as simple as running nix-shell
or using lorri.
If you have direnv
installed the included .envrc
will make that step automatic.
Please ensure protobuf related files are generated along with any change to a protobuf file.
In the future CI will enforce this, but for the time being does not.
Handling of protobuf deps and generating the go files are both handled by the protoc.sh script.
Both go
, and protoc
are required by protoc.sh
.
One must support their proposed changes with unit tests. As you submit a pull request(PR) the CI generates a code coverage report. It will help you identify parts of the code that are not yet covered in unit tests.
There should be two groups of import blocks, one for stdlib and the other for everything else.
This is a nonexhaustive list important packages that happen to cover most of the code base.
The cmd
package is home for three core binaries for Tinkerbell:
tink-cli
- the CLI for interacting with thetink-server
tink-server
- the tink API servertink-worker
- responsible for executing the workload
.
├── cmd
│ ├── tink-cli
│ │ └── cmd
│ │ ├── delete
│ │ ├── get
│ │ ├── hardware
│ │ ├── template
│ │ └── workflow
│ ├── tink-server
│ └── tink-worker
│ ├── cmd
│ └── internal
The db
holds everything you need to deal with the database.
We use PostgreSQL as the data store.
The package contains database migrations, and an API to interact with database.
.
├── db
│ ├── migration
│ ├── mock
│ └── testdata
The deploy
directory contains all the essentials to setup Tinkerbell stack.
You can setup a local stack with docker-compose
or Vagrant.
.
├── deploy
│ ├── db
│ ├── registry
│ ├── tls
│ └── vagrant
│ └── scripts
The grpc-server
exposes a gRPC API that connects everything together.
It has a base server that implements the API.
.
├── grpc-server
│ ├── grpc_server.go
│ ├── hardware.go
│ ├── hardware_test.go
│ ├── template.go
│ ├── template_test.go
│ ├── tinkerbell.go
│ ├── tinkerbell_test.go
│ ├── workflow.go
│ └── workflow_test.go
The protos
package contains all the protobuf files used by the gRPC server.
Handling of protobuf deps and generating the go files are both handled buf via make pbfiles
.
The protubuf/grpc files are not generated as part of the build pipeline to keep builds fast.
CI will ensure generated files are up to date.
.
├── protos
│ ├── hardware
│ ├── packet
│ ├── template
│ └── workflow
Tink Server, CLI, and Worker environment variables are documented here.