npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

greytape

v0.6.1

Published

A library to create CLI tools

Downloads

38

Readme

Greytape

Greytape is a Node.js library to create custom command line tools from shell commands. The original use case was to create helpers for a Docker development environment, but really anything that can be done in a shell can be integrated as a greytape command.

Installation

Simply install greytape with npm...

npm install --save greytape

... and require it in your script :

const greytape = require('greytape')

Basic usage

At its simplest, greytape allows you to map your tool's commands to actual shell commands. Let's say you want to create an application named cli to manage your docker containers. cli could be used like this :

# cli up
// executes docker-compose up
# cli down
// docker-compose down
# cli api ssh
// ssh into the api container
# cli frontend build
// builds the frontend

With greytape, this would look like :

const greytape = require('greytape')

// The configuration is passed as an object to greytape
greytape({
  // The __core block contains the commands that don't have a prefix
  __core: {
    up: { commands: 'docker-compose up' },
    down: { commands: 'docker-compose down' },
  },
  // The api prefix
  api: {
    ssh: { commands: 'docker exec -it api_container /bin/bash' }
  },
  // The frontend prefix
  frontend: {
  	// commands can be supplied as an array, they are executed sequentially and synchronously
    build: { commands: ['cd ./frontend', 'npm run build'] }
  }
})

Advanced usage

(See API Reference for complete instructions)

Arguments management

Greytape commands can handle arguments. You can specify defaults, and even manipulate the arguments before they are sent to the shell commands.

At minimum, you need to provide :

  • options : an array of parameter names
  • commands : instead of a string or array of strings, commands can be a function. It will be executed with the options provided by the user, and must return a string or an array of strings.
greytape({
  __core: {
    data: {
      options: ['database'],
      commands: options => `psql -d ${options.database}`
    }
  },
})

See the API reference for advanced instructions.

Taking the user to a different shell

Because greytape pipes stdin & stdout to the commands, you can take the user to a different shell, for example by connecting to a server with ssh, or by using any REPL like node or psql (see previous example).

Doing this blocks the execution, so if you have provided an array of commands the next one won't execute until this process ends (for example when the user quits the shell).

Executing commands in containers

For each greytape command, you can specify a Docker container name with the inContainer option. The command is executed inside the container by wrapping it with docker exec -it <container> /bin/bash -c <command>.

greytape({
  data: {
    explore: {
      inContainer: 'db_container_1',
      commands: 'psql -d apidata'
    }
  }
})

Configuration management

For the moment, the only configuration option available is cwd, which indicates the directory in which all commands will be executed. (Don't hesitate and just raise an issue if you need other configuration options :) )

Greytape handles the configuration with a dotfile, located in your home folder, and named after the __root of your application (in our example, ~/.cli.json). See the API reference for more details.

Self-documentation

Greytape can generate the documentation of your application if you provide a __root option, indicating the name of the application, and if your commands have hints indicating what they do.

Let's add some documentation to our cli application :

const greytape = require('greytape')

greytape({
  // The application's name
  __root: 'cli',
  __core: {
    up: {
      // The hint for the up command
      hint: 'Starts the containers',
      commands: 'docker-compose up'
    },
    down: {
      hint: 'Stops the containers',
      commands: 'docker-compose down'
    },
    data: {
      hint: "Connect to a database",
      options: ['database'],
      commands: options => `psql -d ${options.database}`
    }
  },
  // The api prefix
  api: {
    ssh: {
      hint: 'SSH into the API container',
      commands: 'docker exec -it api_container /bin/bash'
    }
  }
  // The frontend prefix
  frontend: {
    build: {
      hint: 'Build the frontend with webpack',
      commands: ['cd ./frontend', 'npm run build']
    }
  }
})

The documentation can be accessed by calling cli with no arguments, or with -h, --help or help.

# cli -h
- Core commands
cli up : Starts the containers
cli down : Stops the containers
cli data [database] : Connect to a database
- api commands
cli api ssh : SSH into the API container
- frontend commands
cli frontend build : Build the frontend with webpack

Installing your application

You can call a greytape application with node cli.js command arguments but in most cases you will want your application to be installed globally.

You simply need to add a bin section to your package.json, specifying the binary's name and the js file that should be executed :

{
  "name": "cli",
  "version": "1.0.0",
  "description": "An example CLI application made with greytape.js",
  "bin": {
    "cli": "index.js"
  },
  "author": "Damien BUTY",
  "license": "MIT",
  "dependencies": {
    "greytape": "^0.5.0"
  }
}

Then go to your application's folder and npm install -g (you will probably need sudo privileges).

This makes the application accessible from anywhere in your system by creating a symlink in a folder of your PATH (in general /usr/bin).