Skip to content
/ termask Public
forked from farzadmf/termask

A utility to mask property values in the terminal

License

Notifications You must be signed in to change notification settings

m0ps/termask

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

termask

A utility to mask property values in the terminal

It supports different inputs:

  • Terraform (v0.12)
  • JSON

Introduction

Terraform

DISCLAIMER: I created this tool while only using Azure provider, so it is, in theory, possible that there would be bugs when using other providers; I'll do my best to solve any issues opened for other scenarios

Although Terraform allows marking output variables as sensitive, at the time of this writing, it doesn't provide a way to mark arbitrary values as "secret"

Inspired by tfmask, this program allows masking property values (the ones in the form of "property" = "value") in the output of terraform plan and terraform apply

NOTE: it's worth noting that, for the moment, it only supports the -no-color option of Terraform

Installation

You can use go get to download the tool (a proper executable will be available soon)

go get github.com/farzadmf/termask

Usage

Terraform

You can get help by running termask --help:

NAME:
   termask - Mask values in the terminal

USAGE:
   termask [global options] command [command options] [arguments...]

COMMANDS:
   help, h  Shows a list of commands or help for one command

GLOBAL OPTIONS:
   --mode value, -m value      (tf|json) mode determines the type of the input
   --property value, -p value  property whose value we want to mask (can be specified multiple times)
   --ignore-case, -i           case insensitive match (default: false)
   --partial-match, -l         match if property partially contains the specified string (default: false)
   --help, -h                  show help (default: false)

NOTE: by default, any property that contains the word password will be masked (case insensitive), and the options below don't change this; they just add to this.

As mentioned in the help, you can use --property (or -p) to specify properties whose values you want to mask (this flag can be specified multiple times).

By default, matching is done case sensitive, you can disable that by specifying the --ignore-case (or -i) flag.

Also, by default, a property should match the specified string as a whole word, --partial-match (or -l) allows overriding that.

Examples

Let's say you have the following line in your terraform plan output:

+ resource "azurerm_resource_group" "rg" {
    + "name" = "my-secret-resource-group"
    ...
}

If you want to mask the name property, you can do this:

# Don't forget the '-no-color' switch
terraform plan -no-color | termask -m tf -p name

And the output will be:

+ resource "azurerm_resource_group" "rg" {
  + "name" = "***"
  ...
}

You can also mask multiple properties; let's say you have the following output:

+ resource "azurerm_resource_group" "rg" {
    + location = "eastus"
    + name     = "mysecretrgname"
    ...
}

And you want to mask name and location:

terraform plan -no-color | termask -m tf -p name -p location

Which will result in the following output:

+ resource "azurerm_resource_group" "rg" {
    + location = "***"
    + name     = "***"
    ...
}

An example combining multiple options, given the following Terraform output:

+ resource "azurerm_app_service" "main" {
    ...
    app_settings = {
      ~ "MyConnectionString" = "secret-connection-string" -> "new-secret"
    }
    ...
}

We use the following command:

terraform plan -no-color | termask -m tf -p connectionstring -i -l

And we get:

+ resource "azurerm_app_service" "main" {
    ...
    app_settings = {
      ~ "MyConnectionString" = "***" -> "***"
    }
    ...
}

JSON

We have a simialr concept for JSON input. Let's say you a file named my.json with the following content:

{
  "password": "secret",
  "property": "value",
  "name": "John"
}

Since, by default, password is masked, if you run this:

cat my.json | termask -m json

you would see the following output:

{
  "password": "***",
  "property": "value",
  "name": "John"
}

And, you can choose to mask other properties:

cat my.json | termask -m json -p name

Gives you:

{
  "password": "***",
  "property": "value",
  "name": "***"
}

About

A utility to mask property values in the terminal

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%