Skip to main content

HCL configuration parser for python

Project description

pyhcl

Implements a parser for HCL (HashiCorp Configuration Language) in Python. This implementation aims to be compatible with the original golang version of the parser.

pyhcl does not support HCL2 (which is what modern terraform uses). You might try https://pypi.org/project/python-hcl2/ instead (though I’ve never personally tried it).

The grammar and many of the tests/fixtures were copied/ported from the golang parser into pyhcl. All releases are tested with a variety of python versions from Python 2.7 onward.

This version has been modified to work with terraform 0.12 syntax. It should be backward compatible with earlier versions. It doesn’t cover every situation. See discussion in pull request: https://github.com/virtuald/pyhcl/pull/57

Installation

pip install pyhcl

Usage

This module is intended to be used in mostly the same way that one would use the json module in python, and load/loads/dumps are implemented.

import hcl

with open('file.hcl', 'r') as fp:
    obj = hcl.load(fp)

Currently the dumps function outputs JSON, and not HCL.

Convert HCL to JSON

pyhcl comes with a script that you can use to easily convert HCL to JSON, similar to the json.tool that comes with python:

hcltool INFILE [OUTFILE]

Structure Validation

Similar to JSON, the output of parsing HCL is a python dictionary with no defined structure. The golang library for HCL implements support for parsing HCL according to defined objects, but this implementation does not currently support such constructs.

Instead, I recommend that you use tools designed to validate JSON, such as the schematics library.

Syntax

  • Single line comments start with # or //

  • Multi-line comments are wrapped in /* and */

  • Values are assigned with the syntax key = value (whitespace doesn’t matter). The value can be any primitive: a string, number, boolean, object, or list.

  • Strings are double-quoted and can contain any UTF-8 characters. Example: "Hello, World"

  • Numbers are assumed to be base 10. If you prefix a number with 0x, it is treated as a hexadecimal. If it is prefixed with 0, it is treated as an octal. Numbers can be in scientific notation: “1e10”.

  • Boolean values: true, false

  • Arrays can be made by wrapping it in []. Example: ["foo", "bar", 42]. Arrays can contain primitives and other arrays, but cannot contain objects. Objects must use the block syntax shown below.

Objects and nested objects are created using the structure shown below:

variable "ami" {
    description = "the AMI to use"
}

Testing

To run the tests:

pip install -r testing-requirements.txt
tests/run_tests.sh

Debug Mode

To enable debug mode:

import hcl
hcl.parser.DEBUG = True

Authors

Dustin Spicuzza (dustin@virtualroadside.com)

Note: This project is not associated with Hashicorp

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyhcl-0.4.5.tar.gz (61.8 kB view details)

Uploaded Source

Built Distribution

pyhcl-0.4.5-py3-none-any.whl (50.2 kB view details)

Uploaded Python 3

File details

Details for the file pyhcl-0.4.5.tar.gz.

File metadata

  • Download URL: pyhcl-0.4.5.tar.gz
  • Upload date:
  • Size: 61.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for pyhcl-0.4.5.tar.gz
Algorithm Hash digest
SHA256 c47293a51ccdd25e18bb5c8c0ab0ffe355b37c87f8d6f9d3280dc41efd4740bc
MD5 bc426b4242875e2af665d578f9423b7a
BLAKE2b-256 20b9ff5019eef43b613f49a4695253d8814f8a7012745ae570158e5b64967200

See more details on using hashes here.

File details

Details for the file pyhcl-0.4.5-py3-none-any.whl.

File metadata

  • Download URL: pyhcl-0.4.5-py3-none-any.whl
  • Upload date:
  • Size: 50.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for pyhcl-0.4.5-py3-none-any.whl
Algorithm Hash digest
SHA256 30ee337d330d1f90c9f5ed8f49c468f66c8e6e43192bdc7c6ece1420beb3070c
MD5 2d3099daf8b7d0f7b77cd9f30e55d0b0
BLAKE2b-256 a8b4b766fd33774b55cc15f240916219c4ce9c1bd7bef4acd997ad36ff3622d0

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page