CLI References

humctl is the command line interface for Humanitec

Quick Start

Installation

Visit CLI for instructions how to install the humctl.

Basic usage

humctl follows a standard command structure. The basic usage is:

humctl COMMAND TYPE [arguments...]

Different commands accept different types. Types are types of Humanitec objects such as defined in the API such as apps, envs or sets. Arguments are usually IDs, values or switches. Switches are available in a long form (e.g. --message) or short form (e.g. -m.) Short form switches cannot be combined into a single switch.

The commands supported by the CLI so far include:

Command Types Description
api n/a Make raw authenticated API requests to the Humanitec API.
apply n/a Creates or updates an object based on a Humanitec Manifest.
completion n/a Generate the autocompletion script for the specified shell.
config n/a Show the value of a particular config key.
create app, delta, env Creates a new object.
delete all kinds Deletes an object.
deploy delta, deploy, set, env Starts a new deployment to an environment.
diff sets Returns a delta of the difference between 2 deployment sets.
get all kinds Fetches the requested object.
help n/a Get help on a command. (e.g. humctl help deploy)
login n/a Login to the CLI with the help of a web browser.
resources n/a Commands to manage your resources.
score n/a Commands to operate on Score files.
update delta Makes a change to an object.
version n/a Get the current version of the tool.

Run humctl help COMMAND for details of a specific command.

Output

Errors are written to stderr and fatal errors will result in a non-zero exit code.

Configuration

humctl will read from a config file located by default at .humctl in the users home directory. These configurations can be overridden using Environment Variables.

Environment Variables

humctl understands the following optional environment variables:

Environment Variable Description
HUMANITEC_TOKEN A Humanitec static or session token.
HUMANITEC_ORG The Organization in which to run commands.
HUMANITEC_APP The Application in which to run commands.
HUMANITEC_ENV The Environment in which to run commands.
HUMANITEC_API_PREFIX The Humanitec API to use. (Defaults to https://api.humanitec.io)
HUMANITEC_OUTPUT One of yaml, json or text. (Defaults to text)
HUMANITEC_CONFIG Path to the config file described below. (Defaults to ~/.humctl)

Config File

The humctl config file is a YAML file with the following properties:

Property type Description
api_prefix string The Humanitec API to use. (Defaults to https://api.humanitec.io)
org string The Organization in which to run commands.
app string The Application in which to run commands.
env string The Environment in which to run commands.
output string One of yaml, json or text. (Defaults to text)
token string A Humanitec static or session token

All properties are optional.

IDs, Context and Expansions

Objects in Humanitec exist in a hiearchy. For example, an Environment always belongs to a single Application and an Application always belongs to a single Organization. The fully qualified ID for an object in Humanitec is equivelant to its path in the Humanitec API. For example, the fully qualified ID for an environment called my-env in an application called my-app in organization my-org is:

/orgs/my-org/apps/my-app/envs/my-env

Expansions using Current Context

As most users spend their time working with just one or two environments in a single Application, humctl allows users to define a context which can be used to figure out the full ID from just a fragment. For example, if the context was --org my-org --app my-app --env my-env, then the following expansions could happen:

Type Short ID Fully Qualified ID
apps my-other-app /orgs/my-org/apps/my-other-app
envs second-env /orgs/my-org/apps/my-app/envs/second-env
envs --app my-other-app --env other-apps-env /orgs/my-org/apps/my-other-app/envs/other-apps-env

This also works for other objects that are scoped within an Application or Enviornment:

Type Short ID Fully Qualified ID
sets dRZxTxhPImjJ2JIWXj-ZGiu_4-ov5UfWxK-eUNt6zvh /orgs/my-org/apps/my-app/sets/dRZxTxhPImjJ2JIWXj-ZGiu_4-ov5UfWxK-eUNt6zvh
deltas 18e8fd691c3be9c023f5dc41d0cb2181d524fd01 /orgs/my-org/apps/my-app/deltas/18e8fd691c3be9c023f5dc41d0cb2181d524fd01

Current Context and Active objects

As a further shortcut, the current context value can be used directly by using . in place of the ID alltogether:

Type Short ID Fully Qualified ID
apps . /orgs/my-org/apps/my-app
envs . /orgs/my-org/apps/my-app/envs/my-env

This also works with other objects that can have be active. The last delta created will be remembered by humctl and will be inserted if you use . in place of a delta. The last Deployment in an Environment counts as the “active” Deployment, so if you use . in place of a deployment, you will get the active deployment of the current Environment in the context.

For example, assuming the most recently created deltas has ID 18e8fd691c3be9c023f5dc41d0cb2181d524fd01 and the last deployment an ID of 166a15b85e58dcee:

Type Short ID Fully Qualified ID
deltas . /orgs/my-org/apps/my-app/deltas/18e8fd691c3be9c023f5dc41d0cb2181d524fd01
deploys . /orgs/my-org/apps/my-app/envs/my-env/deploys/166a15b85e58dcee

Sequential objects

A final shortcut applies to objects that have order. This currently only applies to Deployments. Deployments in an Environment have an order as they occur on after eachother in an environment. The sequential shortcut is a + followed by the offset down the list and is used in place of an ID. In this case +0 would get the current item and +2 would get the item next-but-one in the list. For example:

Type Short ID Fully Qualified ID
deploys . /orgs/my-org/apps/my-app/envs/my-env/deploys/166a15b85e58dcee
deploys +0 /orgs/my-org/apps/my-app/envs/my-env/deploys/166a15b85e58dcee
deploys +2 /orgs/my-org/apps/my-app/envs/my-env/deploys/964f2eae8b51a661

The sequential shortcut can also be used in combination with a partial or fully qualified ID:

Type Short ID Fully Qualified ID
deploys --env second-env deploys/+2 /orgs/my-org/apps/my-app/envs/second-env/deploys/eaaa4a64e8b51df0
deploys --org my-org --app my-other-app --env different-env deploys/+1 /orgs/my-org/apps/my-other-app/envs/different-env/deploys/411f9bbe01e4dc62

Humanitec Manifests

Humanitec uses a similar YAML structure to Kubernetes when defining its YAML files. The structure has the following basic format:

apiVersion: entity.humanitec.io/v1b1
kind: Environment
metadata:
  id: dev-2
entity: # modifiable properties
  name: Secondary Dev
  type: development
status: # read-only properties
  created_at: "2020-06-12T07:49:12.720677Z"

The manifests can be used with the apply command to provide an “as code” approach to using Humanitec.

Score integration

With humctl, you can easily operate and deploy your Score files. Currently, the score command supports the following subcommands:

Command Description
available-resource-types List available resource types.
deploy Deploy a Score file.
init Initialize the Score file.
validate Validate the specified score file.

Listing available Resource Types

Depending on your organization, developers might have access to different Resource Types. The humctl tool provides an easy way for developers to discover what is available to them. Use the following commands:

  • List all available resource types: humanitec score available-resource-types
  • Filter the list by a specific Resource Type: humctl score available-resource-types --filter-type TYPE
  • Ensure you are using the correct Resource Types in your Score files: humctl score validate

The latter validation step can prevent errors and streamline the provisioning process by checking your Score file for any incorrect Resource Types and providing feedback on necessary corrections.

For the best developer experience, use the VSCode Extension that displays Resource Types and validates your Score file in real-time. This extension integrates seamlessly with your development workflow, providing instant feedback and helping you adhere to best practices.

Deploying Score files

To deploy a single workload, you can simply use humctl score deploy. It will use the score.yaml file from the directory where the binary was executed. To modify that path, you can use the --file flag. Additionally, you can specify extension files using the --extensions flag and overrides using the --overrides flag.

Removing Workloads

Add the --remove flag to the humctl score deploy command to remove a Workload instead of deploying it, e.g. humctl score deploy -f scoreWithWorkloadToRemove.yaml --remove.

Configuration

To avoid passing extension and override files each time and to deploy multiple workloads at once, you can define a deploy configuration and specify it via the --deploy-config flag. This configuration describes where the Score files are located and matches them with their respective extensions and overrides. An example file looks like this:


deploy-config.yaml (view on GitHub) :

apiVersion: config.humanitec.io/v1b1
kind: ScoreDeployConfig
workloads:
  - name: example-service
    specFile: ./score.example-service.yaml
    extensionsFile: ./score.humanitec.yaml
  - name: another-service
    specFile: ./score.another-service.yaml
    extensionsFile: ./score.humanitec.yaml

Available attributes in your deploy configuration are:

Attribute Type Content
name string (optional) Name to identify the workload inside the deploy configuration. The actual workload name will always be taken from the Score file
specFile string Path to the workload specification file, i.e. the Score file
extensionsFile string (optional) Path to the workload extensions file
image string (optional) Image used for the image: . notation in the Score file
overridesFile string (optional) Path to the workload overrides file
propertyOverrides object (optional) Overrides for the workload properties. Is merged with the content of an overridesFile. Properties from propertyOverrides take precedence over identical properties from the overridesFile

There is no specific order of deployment for the workloads. All the specified changes from the Score files are combined into a single delta and pushed as one deployment.

If an error occurs during the deployment of the combined delta, the entire deployment process fails. The error messages can be found in the pipeline run logs.

Examples

Create a delta to add an environment variable to the main container in the sample-app workload:

humctl create delta --name "add variable"
humctl update delta . add modules/sample-app/spec/containers/main/variables/NEW_VAR '"Hello World!"'

Deploy the current delta to the current environment:

humctl deploy delta . . --comment "Adding NEW_VAR to sample-app"

Comparing what is currently deployed with what was deployed before:

humctl diff sets deploy/+0 deploy/+1

Compare the current environment to the production environment:

humctl diff sets env/. env/production
Top