Skip to content

Latest commit

 

History

History

app-config-exec

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

App Config Exec Plugin

Run arbitrary programs or shell commands to generate config.

$exec: echo Hello World!

Usage

Basic:

$exec: echo Hello World!

Auto-parse output as YAML/TOML/JSON/JSON5:

$exec:
  command: curl https://my-api.example.com
  parseOutput: true

Build a custom script to generate config:

$exec: node ./my-custom-config-generator.js

Retrieve arbitrary information:

Node v8 version:

$exec: node -p -e "process.versions.v8"

System's architecture:

$exec: uname -p

Retrieve list of AWS S3 buckets via aws & jq CLI:

$exec:
  command: aws s3api list-buckets --output json | jq -r '.Buckets'
  parseOutput: true

Note: When possible, we encourage you to build a dedicated extension to better support features you are looking for (and help out the community). eg. $aws directive instead of the above.

Installing

Install and use:

yarn add @app-config/exec

In .app-config.meta.yml file:

parsingExtensions:
  - '@app-config/exec'

Options

The following options can be passed to each $exec directive:

$exec:
  command: echo Hello World!
  trimWhitespace: true
  parseOutput: false
  failOnStderr: false

command: string:

The command to run. Should be a single string containing both command and arguments. The command's stdout will be used as the resulting value. Runs in a shell, /bin/sh on Unix and process.env.ComSpec on Windows.

trimWhitespace: boolean:

If true, automatically trim whitespace from the start and end of the command's output. Useful to remove the trailing newline produced by most commands. If false, output will be left in its raw form. Default true.

parseOutput: boolean:

If true, automatically guess output content type (YAML, TOML, JSON, or JSON5) and parse. Throws if parse fails. If false, output will be read as a string. Default false.

failOnStderr: boolean:

If true, fail if any output is found in command's stderr. Default false.