This is a proof-of-concept implementation of a command-line client for
Shipwright's Build operator, which uses the same pattern than kubectl
/oc
and
can be used as a staandalone binary and as a kubectl
plugin.
You can expect to read developer's documentation below, the focus on final users with extend usage documentation will come in the near future.
To install it run:
go get -u github.com/otaviof/shp/cmd/shp
Or clone the repository, and run make
to build the binary at _output
directory:
make
Installation under /usr/local/bin
is executed via make install
target.
In order to compile the project as a kubectl plugin, run:
make kubectl-install
By having a kubectl
named binary in $PATH
, it behaves a plugin. So, run kubectl shp
in your
terminal afterwards.
You can also use make run
, to go run
the command-line project directly. For instance:
make run ARGS='--help'
make run ARGS='run build --help'
To execute all tests available in the project, run:
make test
TBD.
The project is divided in cmd
and pkg
sub-folders, where the cmd
is a straight forward main
for the command-line. The primary business logic lives under pkg
directory.
The most relevant packages are:
pkg/shp/cmd
: contains the rootcobra.Command
, and wires up all other CLI sub-commands. It describes theSubCommand
interface, and contains aRunner
implementing sub-commands lifecycle;pkg/shp/buildrun
: contains the actions taken againstBuildRun
resources, therefore commands likerun build
andcreate build-run
are handled by this package, which implementsSubCommand
interface;pkg/shp/flags
: contains a Golang flag generator forBuildRun
resources, and will store all other flags that could be reused in more than one package;pkg/shp/util
: contains utility functions and definitions used in most packages;
You can also read the full Golang docs here.
The CLI follows the same structure than kubectl
/oc
, and also uses a number of the base packages
employed on those projects.
To name a few of them:
k8s.io/cli-runtime/pkg/genericclioptions
: defines the global flags needed to stablish connection with the API-Server;k8s.io/kubectl/pkg/cmd/util
: exposes a factory interface with helpers to use global flags to create the Kubernetes client configuration, and instantiate the API-Server client itself;k8s.io/kubectl/pkg/util/templates
: helps to organize the command-line interface in categories;
In addition to upstream kubectl
packages, shp
also implements the same lifecycle for
sub-commands, implemented on this project as SubCommand
interface and Runner
. The interface
defines how the sub-command package is structured, and Runner
calls functions in a pre-defined
sequence feeding a instantiated API client and information available during execution.
A more complete example of sub-command implementation can be taken from pkg/shp/buildrun
package,
where you can observe interactions with the API-Server. Furthermore, package pkg/shp/initialize
is
placeholder for a future shp init
.
The SubCommand
interface defines the lifecycle of the components, as per:
Complete()
: will collect the values in command-line flags, and "complete" the context need for the upcoming steps. It can also return errors when there's not enough data, or not able to perform actions;Validate()
: given all necessary data have been collected by previous step (Complete()
), now is time to apply validation logic against the context accumulated, and return errors accordingly;Run()
: execute the primary sub-command logic;
This project will be evaluated by the Shipwright contributors. If we agree on this proof-of-concept as a starting point, the code base will be moved to a new organization and all current commits should be rewritten during the migration process.