hcl-to-json
HCL to JSON converter
Last updated 7 years ago by mgg .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ gnpm install hcl-to-json 
SYNC missed versions from official npm registry.

hcl-to-json

Build Status NPM version

HCL to JSON converter for JS applications.

HCL (HashiCorp Configuration Language) is a configuration language built by HashiCorp. The goal of HCL is to build a structured configuration language that is both human and machine friendly for use with command-line tools, but specifically targeted towards DevOps tools, servers, etc.

HCL is also fully JSON compatible. That is, JSON can be used as completely valid input to a system expecting HCL. This helps makes systems interoperable with other systems.

Getting started

You can install with npm i hcl-to-json -g then simply require and pass HCL content to get JSON output. If you have a bad HCL content it's suggested to call in try .. catch block


hcltojson = require 'hcltojson'

hcltojson """

foo "bar" {
  baz = 123
  tex = ["one", "two"]
  mon "test" {
    lar = "bar"
  }
}

"""

will return following JSON object:

{
  "foo": {
    "bar": {
      "baz": 123,
      "tex": [
        "one",
        "two"
      ],
      "mon": {
        "test": {
          "lar": "bar"
        }
      }
    }
  }
}

or you can use the hcltojson cli for any hcl formatted file or standart input;

$ npm install hcl-to-json -g
$ echo "foo=3" | hcltojson
{
    "foo": 3
}

$ echo "foo bar { baz = 123 }" > test.tf
$ hcltojson test.tf
{
    "foo": {
        "bar": {
            "baz": 123
        }
    }
}

In browser you may include the dist/bundle.js which will export hcltojson function into window. You can also try it in your browser from https://runkit.com/npm/hcl-to-json

Syntax

It currently supports the high-level features of the syntax and grammar of HCL. Syntax details can be found here

Status

It's experimental now and in early stages of development, but supports lots of samples listed under test folder.

Development

You can use DEBUG="hcltojson:*" npm test watch while developing for live compile and test results with debug output.

License

MIT (c) 2016 Gokmen Goksel

Current Tags

  • 0.1.1                                ...           latest (7 years ago)

11 Versions

  • 0.1.1                                ...           7 years ago
  • 0.1.0                                ...           7 years ago
  • 0.0.9                                ...           7 years ago
  • 0.0.8                                ...           7 years ago
  • 0.0.7                                ...           7 years ago
  • 0.0.6                                ...           7 years ago
  • 0.0.5                                ...           8 years ago
  • 0.0.4                                ...           8 years ago
  • 0.0.3                                ...           8 years ago
  • 0.0.2                                ...           8 years ago
  • 0.0.1                                ...           8 years ago
Maintainers (1)
Downloads
Today 0
This Week 0
This Month 2
Last Day 0
Last Week 2
Last Month 0
Dependencies (3)
Dev Dependencies (5)
Dependents (1)

Copyright 2013 - present © cnpmjs.org | Home |