open-vault/vendor/github.com/hashicorp/go-slug
Clint 2aff402279
Bundle new Vault plugin: Terraform secrets (#10931)
* Bundle Terraform secrets engine

* update go.mod/sum

* vendor update

* add changelog entry

* add secrets terraform
2021-02-19 16:38:56 -06:00
..
.gitignore Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00
go.mod Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00
LICENSE Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00
README.md Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00
slug.go Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00
terraformignore.go Bundle new Vault plugin: Terraform secrets (#10931) 2021-02-19 16:38:56 -06:00

go-slug

Build Status GitHub license GoDoc Go Report Card GitHub issues

Package go-slug offers functions for packing and unpacking Terraform Enterprise compatible slugs. Slugs are gzip compressed tar files containing Terraform configuration files.

Installation

Installation can be done with a normal go get:

go get -u github.com/hashicorp/go-slug

Documentation

For the complete usage of go-slug, see the full package docs.

Example

Packing or unpacking a slug is pretty straight forward as shown in the following example:

package main

import (
	"bytes"
	"io/ioutil"
	"log"
	"os"

	slug "github.com/hashicorp/go-slug"
)

func main() {
	// First create a buffer for storing the slug.
	buf := bytes.NewBuffer(nil)

	// Then call the Pack function with a directory path containing the
	// configuration files and an io.Writer to write the slug to.
	if _, err := slug.Pack("testdata/archive-dir", buf, false); err != nil {
		log.Fatal(err)
	}

	// Create a directory to unpack the slug contents into.
	dst, err := ioutil.TempDir("", "slug")
	if err != nil {
		log.Fatal(err)
	}
	defer os.RemoveAll(dst)

	// Unpacking a slug is done by calling the Unpack function with an
	// io.Reader to read the slug from and a directory path of an existing
	// directory to store the unpacked configuration files.
	if err := slug.Unpack(buf, dst); err != nil {
		log.Fatal(err)
	}
}

Issues and Contributing

If you find an issue with this package, please report an issue. If you'd like, we welcome any contributions. Fork this repository and submit a pull request.