A guide on how to contribute to this project.
Clone the project
git clone git@github.com:algorandfoundation/nodekit.git
Change to the directory
cd nodekit
Build the project
make build
Launch the TUI. See the full documentation for a complete guide
./bin/nodekit
├── api # Generated API Client and Hand Crafted HTTPInterface
├── cmd # Command Controller
├── internal # Data Models/Fetch Wrappers
└── ui # BubbleTea Interfaces
There are three top level modules (cmd, internal, ui) which align with the GoLang/Charm ecosystem. There is an additional code-generated module called api which should not be edited by hand. See generating rpc package for more information
All submodules and endpoints SHOULD align with the command/ui namespaces.
Example Command:
nodekit status
Example Structure
├── cmd/status.go
├── internal/status.go
└── ui/status/table.go
All submodules SHOULD abstract when appropriate to a submodule.
Example Refactor
├── cmd/status/root.go
├── internal/status/model.go
└── ui/status/table.go
Additional top level modules SHOULD NOT be relied on unless there is a clear reason.
A common abstraction found in other projects is a server
module which handles any local daemons.
Folder for commands that can be run from the cli. Effectively this package is the "controller" in MVC
- SHOULD be used to manage cli commands
- SHOULD mirror the name of the command.
cli-tool command-name
should be represented as./cmd/command-name.go
or./cmd/command-name/root.go
- SHOULD bind the
internal
andui
models - SHOULD NOT contain any model or UI code (only bindings).
Common library code which includes the models and business logic of the application. Its main responsibility is constructing the state used in the TUI. This package is considered the "Model" in MVC
- SHOULD be used to hold models.
- SHOULD mirror the namespace the models relate to.
- SHOULD NOT contain any UI or CLI specific code (example, IsVisible or any tea|cobra interfaces).
Elements to be presented to the user.
This is built on the bubbletea
abstraction.
This package is the ViewModel and View in MVC.
- SHOULD be used to build bubbletea interfaces.
- SHOULD be named by the component it represents.
For example,
./ui/table.go
for a reusable component or./ui/command-name/table.go
for context specific elements - SHOULD contain ViewModel state like "IsVisible"
- SHOULD NOT contain any model or CLI specific code (ViewModels/tea.Models should be composed of internal Models for testability).
The api
package is generated via oapi-codegen.
This is only required when adding new or missing RPC interfaces from the algod specification.
Its configuration is found under generate.yaml
and can be run with the following make command:
make generate
The full command for reference
oapi-codegen -config generate.yaml https://raw.githubusercontent.com/algorand/go-algorand/v3.26.0-stable/daemon/algod/api/algod.oas3.yml
This project follows GitHub flow.
Create a fork and submit changes directly to the main
branch.